Skip to content

Commit

Permalink
Drafts tests for panic errors support
Browse files Browse the repository at this point in the history
Signed-off-by: Konstantina Blazhukova <[email protected]>
  • Loading branch information
konstantinabl committed Oct 20, 2023
1 parent 85a0600 commit 2f45016
Show file tree
Hide file tree
Showing 3 changed files with 169 additions and 0 deletions.
62 changes: 62 additions & 0 deletions contracts/solidity/errors/Panic.sol
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.20;

contract Panic {
uint[] someArray;
uint[] anotherArray = [1, 2, 3];

enum Button {
ON,
OFF
}
constructor() {
}

function testPanicError0x01() external pure {
assert(false);
}

function testPanicError0x11() external pure returns(uint8) {
uint8 test = 255;
uint8 test2 = 1;
return test + test2;
}

function testPanicError0x12() external pure returns(uint8) {
uint8 number1 = 5;
uint8 number2 = 12-12;
return number1 / number2;
}

function testPanicError0x21() external pure {
int testValue = -1;
Button value = Button(testValue);
}

function testPanicError0x22() external pure returns(uint8) {
return 0;
}

function testPanicError0x31() external {
someArray.pop();
}

function testPanicError0x32() external view returns(uint) {
return anotherArray[5];
}

function testPanicError0x41() external pure returns(uint[] memory) {
uint[] memory largeArray = new uint[](2**64);
}

function testPanicError0x51() external pure returns(uint) {
function (uint, uint) internal pure returns (uint) funcPtr;

return funcPtr(5, 6);
}

function getSomeArray() external view returns(uint[] memory) {
return someArray;
}

}
4 changes: 4 additions & 0 deletions test/constants.js
Original file line number Diff line number Diff line change
Expand Up @@ -105,6 +105,7 @@ const Contract = {
Transaction: 'Transaction',
MessageFrameAddresses: 'MessageFrameAddresses',
New: 'New',
<<<<<<< HEAD
AssemblyAddress: 'AssemblyAddress',
AddressContract: 'AddressContract',
Recipient: 'Recipient',
Expand All @@ -114,6 +115,9 @@ const Contract = {
FunctionsParent: 'FunctionsParent',
Scoping: 'Scoping',
Arithmetic: "Arithmetic"
=======
Panic: 'Panic'
>>>>>>> d7be75e (Drafts tests for panic errors support)
}

const CALL_EXCEPTION = 'CALL_EXCEPTION'
Expand Down
103 changes: 103 additions & 0 deletions test/solidity/errors/panicErrors.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,103 @@
const { expect, assert } = require('chai')
const { ethers } = require('hardhat')
const Constants = require('../../constants')

describe('Panic Errors', function () {
let contract

before(async function () {
const factory = await ethers.getContractFactory(Constants.Contract.Panic)
contract = await factory.deploy()
})

it('should verify panic error 0x01', async function () {
let error;
try {
await contract.testPanicError0x01();
} catch(e) {
error = e;
}
expect(error.errorName).to.eq('Panic');
expect(error.errorArgs).to.deep.eq([ethers.BigNumber.from(1)])
})

it('should verify panic error 0x11', async function () {
let error;
try {
await contract.testPanicError0x11();
} catch(e) {
error = e;
}
expect(error.errorName).to.eq('Panic');
expect(error.errorArgs).to.deep.eq([ethers.BigNumber.from(17)])
})

it('should verify panic error 0x12', async function () {
let error;
try {
await contract.testPanicError0x12();
} catch(e) {
error = e;
}
expect(error.errorName).to.eq('Panic');
expect(error.errorArgs).to.deep.eq([ethers.BigNumber.from(18)])
})

it('should verify panic error 0x21', async function () {
let error;
try {
await contract.testPanicError0x21();
} catch(e) {
error = e;
}
expect(error.errorName).to.eq('Panic');
expect(error.errorArgs).to.deep.eq([ethers.BigNumber.from(33)])
})

it('should verify panic error 0x31', async function () {
let error;
try {
const result = await contract.getSomeArray();
console.log(result);
await contract.testPanicError0x31();
} catch(e) {
error = e;
}
expect(error.errorName).to.eq('Panic');
expect(error.errorArgs).to.deep.eq([ethers.BigNumber.from(18)])
})

it('should verify panic error 0x32', async function () {
let error;
try {
await contract.testPanicError0x32();
} catch(e) {
error = e;
}
expect(error.errorName).to.eq('Panic');
expect(error.errorArgs).to.deep.eq([ethers.BigNumber.from(50)])
})

it('should verify panic error 0x41', async function () {
let error;
try {
await contract.testPanicError0x41();
} catch(e) {
console.log(e)
error = e;
}
expect(error.errorName).to.eq('Panic');
expect(error.errorArgs).to.deep.eq([ethers.BigNumber.from(65)])
})

it('should verify panic error 0x51', async function () {
let error;
try {
await contract.testPanicError0x51();
} catch(e) {
error = e;
}
expect(error.errorName).to.eq('Panic');
expect(error.errorArgs).to.deep.eq([ethers.BigNumber.from(81)])
})
})

0 comments on commit 2f45016

Please sign in to comment.