Tests for the Ethereum tool suite Remix
npm -g install remix-tests
Example test file:
pragma solidity ^0.4.7;
import "remix_tests.sol"; // injected by remix-tests
import "./simple_storage.sol";
contract MyTest {
SimpleStorage foo;
uint i = 0;
function beforeAll() {
foo = new SimpleStorage();
}
function beforeEach() {
if (i == 1) {
foo.set(200);
}
i += 1;
}
function initialValueShouldBe100() public {
Assert.equal(foo.get(), 100, "initial value is not correct");
}
function initialValueShouldBe200() public constant returns {
return Assert.equal(foo.get(), 200, "initial value is not correct");
}
}
See also: example Su Squares contract and [https://travis-ci.org/su-squares/ethereum-contract/builds/446186067](Travis build) that uses remix-tests for continuous integration testing.
Available special functions:
beforeEach()
- runs before each testbeforeAll()
- runs before all tests
Available functions | Supported types |
---|---|
Assert.ok() |
bool |
Assert.equal() |
uint , int , bool , address , bytes32 , string |
Assert.notEqual() |
uint , int , bool , address , bytes32 , string |
Assert.greaterThan() |
uint , int |
Assert.lesserThan() |
uint , int |
It is quite common that a contract need to be tested in different situation.
Especially being able to set before hand the sender account (msg.sender
) used for a specific tests suite enable quite a lot a new test use cases.
please checkout https://github.com/ethereum/remix/blob/master/remix-tests/tests/various_sender/sender_test.sol for an example.
note that TestsAccounts
is filled with all the accounts available in web3.eth.accounts()
.
Remix-Tests will assume the tests will files whose name end with "_test.sol"
. e.g simple_storage_test.sol
Usage:
- A directory with tests files
remix-tests examples/
- A test file
remix-tests examples/simple_storage_test.sol
Importing the library:
const RemixTests = require('remix-tests');
Running a single test object:
remixTests.runTest(contractName, contractObj, testCallback, resultsCallback)
params:
testName
- string
name of the test
testObj
- web3.js 1.0 contract instance of the test
testCallback(object)
- called each time there is a test event. 3 possible type of objects:
{ type: 'contract', value: '<TestName>', filename: '<test_filename.sol>' }
{ type: 'testPass', value: '<name of testing function>', time: <time taken>, context: '<TestName>'}
{ type: 'testFailure', value: '<name of testing function>', time: <time taken>, context: '<TestName>', errMsg: '<message in the Assert>' }
resultsCallback(object)
passingNum
- number of passing testsfailureNum
- number of failing teststimePassed
- time it took for all the tests to run (in seconds)
Running a set of tests given the sourcecode:
remixTests.runTestSources(contractSources, testCallback, resultCallback, finalCallback, importFileCb);
params:
contractSources
- object
-> filename => { content: source }
testCallback(object)
- called each time there is a test event. 3 possible type of objects:
{ type: 'contract', value: '<TestName>', filename: '<test_filename.sol>' }
{ type: 'testPass', value: '<name of testing function>', time: <time taken>, context: '<TestName>'}
{ type: 'testFailure', value: '<name of testing function>', time: <time taken>, context: '<TestName>', errMsg: '<message in the Assert>' }
resultCallback(err, object)
passingNum
- number of passing testsfailureNum
- number of failing teststimePassed
- time it took for all the tests to run (in seconds)
finalCallback(err)
- called when all tests finish running.
importCb(url, cb)
Please feel free! Open an issue or a pull request. Please conform to standard
for code styles, and make sure that you add any relevant tests.
MIT © 2018 Remix Team