Skip to content

Commit

Permalink
added unit test
Browse files Browse the repository at this point in the history
  • Loading branch information
Tien Ngo committed Oct 23, 2023
1 parent c514e11 commit a01cd98
Show file tree
Hide file tree
Showing 2 changed files with 426 additions and 125 deletions.
48 changes: 24 additions & 24 deletions contracts/FeralfileEnglishAuction.sol
Original file line number Diff line number Diff line change
Expand Up @@ -67,18 +67,16 @@ contract FeralfileEnglishAuction is Ownable, FeralfileSaleData, ECDSASigner {
return message;
}

function auctionOngoing(bytes32 aucId_) public view returns (uint256) {
function auctionOngoing(bytes32 aucId_) public view returns (bool) {
// check the auction status and return
require(
auctions[aucId_].id != 0,
"FeralfileEnglishAuction: auction not found"
);

return block.timestamp;

// return
// auctions[aucId_].startAt <= block.timestamp &&
// auctions[aucId_].endAt >= block.timestamp;
return
auctions[aucId_].startAt <= block.timestamp &&
auctions[aucId_].endAt >= block.timestamp;
}

function setEnglishAuctions(
Expand All @@ -95,7 +93,7 @@ contract FeralfileEnglishAuction is Ownable, FeralfileSaleData, ECDSASigner {
);

require(
auctions_[i].startAt > block.timestamp,
auctions_[i].startAt >= block.timestamp,
"FeralfileEnglishAuction: auction start time should be in the future"
);

Expand Down Expand Up @@ -145,15 +143,10 @@ contract FeralfileEnglishAuction is Ownable, FeralfileSaleData, ECDSASigner {
auction_.id.length > 0,
"FeralfileEnglishAuction: auction not found"
);
// check if auction started
require(
auction_.startAt < timestamp_,
"FeralfileEnglishAuction: auction not started"
);
// check if now() under auction end time
// check if auction is on going
require(
auction_.endAt > timestamp_,
"FeralfileEnglishAuction: auction already ended"
auction_.startAt <= timestamp_ && timestamp_ <= auction_.endAt,
"FeralfileEnglishAuction: auction not started or ended"
);
// check if current winner not equal to current bidder (optional)
require(
Expand Down Expand Up @@ -277,28 +270,35 @@ contract FeralfileEnglishAuction is Ownable, FeralfileSaleData, ECDSASigner {
bytes32 r_,
bytes32 s_,
uint8 v_,
address tokenContractAddr_,
address tokenAddr_,
address vaultAddr_,
SaleData memory saleData_
) external onlyOwner {
// transfer winning bid amount to Feral File Vault contract if winning bid is crypto bid
bytes32 aucId_ = keccak256(
abi.encodePacked(
getAuctionID(tokenContractAddr_, saleData_.tokenIds)
)
);
bytes32 aucId_ = getAuctionID(tokenAddr_, saleData_.tokenIds);

EnglishAuction memory auction_ = auctions[aucId_];
require(auction_.id != 0, "FeralfileEnglishAuction: auction not found");

require(
auction_.id.length > 0,
"FeralfileEnglishAuction: auction not found"
auction_.endAt < block.timestamp,
"FeralfileEnglishAuction: auction not ended"
);

Bid memory lastBid_ = auctionLatestBid[aucId_];
require(
lastBid_.bidder != address(0),
"FeralfileEnglishAuction: no bid"
);

saleData_.price = lastBid_.amount;
saleData_.destination = lastBid_.bidder;
FFV4(tokenContractAddr_).buyArtworks(r_, s_, v_, saleData_);
saleData_.payByVaultContract = true;

if (!lastBid_.fromFeralFile) {
payable(vaultAddr_).transfer(lastBid_.amount);
}
FFV4(tokenAddr_).buyArtworks(r_, s_, v_, saleData_);
}

event NewBid(
Expand Down
Loading

0 comments on commit a01cd98

Please sign in to comment.