From d2ba8693e772b83e80746ffadc1efc36c836caf0 Mon Sep 17 00:00:00 2001 From: Eric <5089238+emizzle@users.noreply.github.com> Date: Thu, 19 Sep 2024 14:25:41 +1000 Subject: [PATCH] Remove return value for `reserveSlot` Not needed, as a slot that cannot be added due to already being included would revert anyway. --- contracts/SlotReservations.sol | 5 ++--- test/SlotReservations.test.js | 13 ++++--------- 2 files changed, 6 insertions(+), 12 deletions(-) diff --git a/contracts/SlotReservations.sol b/contracts/SlotReservations.sol index 5117186..5ab0439 100644 --- a/contracts/SlotReservations.sol +++ b/contracts/SlotReservations.sol @@ -11,11 +11,10 @@ contract SlotReservations { uint8 private constant _MAX_RESERVATIONS = 3; - function reserveSlot(SlotId slotId) public returns (bool) { + function reserveSlot(SlotId slotId) public { address host = msg.sender; require(canReserveSlot(slotId), "Reservation not allowed"); - // returns false if set already contains address - return _reservations[slotId].add(host); + _reservations[slotId].add(host); } function canReserveSlot(SlotId slotId) public view returns (bool) { diff --git a/test/SlotReservations.test.js b/test/SlotReservations.test.js index c2042c3..a45700c 100644 --- a/test/SlotReservations.test.js +++ b/test/SlotReservations.test.js @@ -8,6 +8,7 @@ describe("SlotReservations", function () { let provider, address1, address2, address3 let request let slot + let id // can't use slotId because it'll shadow the function slotId beforeEach(async function () { let SlotReservations = await ethers.getContractFactory( @@ -22,6 +23,8 @@ describe("SlotReservations", function () { request: requestId(request), index: request.ask.slots / 2, } + + id = slotId(slot) }) function switchAccount(account) { @@ -29,13 +32,10 @@ describe("SlotReservations", function () { } it("allows a slot to be reserved", async function () { - let id = slotId(slot) - let reserved = await reservations.callStatic.reserveSlot(id) - expect(reserved).to.be.true + expect(reservations.reserveSlot(id)).to.not.be.reverted }) it("contains the correct addresses after reservation", async function () { - let id = slotId(slot) await reservations.reserveSlot(id) expect(await reservations.contains(id, provider.address)).to.be.true @@ -45,7 +45,6 @@ describe("SlotReservations", function () { }) it("has the correct number of addresses after reservation", async function () { - let id = slotId(slot) await reservations.reserveSlot(id) expect(await reservations.length(id)).to.equal(1) @@ -59,7 +58,6 @@ describe("SlotReservations", function () { }) it("cannot reserve a slot more than once", async function () { - let id = slotId(slot) await reservations.reserveSlot(id) await expect(reservations.reserveSlot(id)).to.be.revertedWith( "Reservation not allowed" @@ -68,13 +66,11 @@ describe("SlotReservations", function () { }) it("reports a slot cannot be reserved if already reserved", async function () { - let id = slotId(slot) await reservations.reserveSlot(id) expect(await reservations.canReserveSlot(id)).to.be.false }) it("cannot reserve a slot if reservations are at capacity", async function () { - let id = slotId(slot) switchAccount(address1) await reservations.reserveSlot(id) switchAccount(address2) @@ -90,7 +86,6 @@ describe("SlotReservations", function () { }) it("reports a slot cannot be reserved if reservations are at capacity", async function () { - let id = slotId(slot) switchAccount(address1) await reservations.reserveSlot(id) switchAccount(address2)