Update function & expression tests

next
cgewecke 5 years ago
parent a63806e181
commit b1bea305eb
  1. 24
      test/units/expressions.js
  2. 269
      test/units/function.js

@ -1,24 +1,14 @@
/* eslint-env node, mocha */ const assert = require('assert');
const util = require('./../util/util.js');
/*const solc = require('solc');
const getInstrumentedVersion = require('./../lib/instrumentSolidity.js');
const util = require('./util/util.js');
const path = require('path');
describe('generic expressions', () => { describe('generic expressions', () => {
const filePath = path.resolve('./test.sol');
it('should compile after instrumenting a single binary expression', () => { it('should compile after instrumenting a single binary expression', () => {
const contract = util.getCode('expressions/single-binary-expression.sol'); const info = util.instrumentAndCompile('expressions/single-binary-expression');
const info = getInstrumentedVersion(contract, filePath); util.report(info.solcOutput.errors);
const output = JSON.parse(solc.compile(util.codeToCompilerInput(info.contract)));
util.report(output.errors);
}); });
it('should compile after instrumenting a new expression', () => { it('should compile after instrumenting a new expression', () => {
const contract = util.getCode('expressions/new-expression.sol'); const info = util.instrumentAndCompile('expressions/new-expression');
const info = getInstrumentedVersion(contract, filePath); util.report(info.solcOutput.errors);
const output = JSON.parse(solc.compile(util.codeToCompilerInput(info.contract)));
util.report(output.errors);
}); });
});*/ });

@ -1,186 +1,159 @@
/*const solc = require('solc');
const getInstrumentedVersion = require('./../lib/instrumentSolidity.js');
const util = require('./util/util.js');
const path = require('path');
const CoverageMap = require('./../lib/coverageMap');
const vm = require('./util/vm');
const assert = require('assert'); const assert = require('assert');
const util = require('./../util/util.js');
const ganache = require('ganache-core');
const Coverage = require('./../../lib/coverage');
describe('function declarations', () => { describe('function declarations', () => {
const filePath = path.resolve('./test.sol'); let coverage;
const pathPrefix = './'; let provider;
let collector;
before(async () => ({ provider, collector } = await util.initializeProvider(ganache)));
beforeEach(() => coverage = new Coverage());
after((done) => provider.close(done));
it('should compile after instrumenting an ordinary function declaration', () => { it('should compile after instrumenting an ordinary function declaration', () => {
const contract = util.getCode('function/function.sol'); const info = util.instrumentAndCompile('function/function');
const info = getInstrumentedVersion(contract, 'test.sol'); util.report(info.solcOutput.errors);
const output = JSON.parse(solc.compile(util.codeToCompilerInput(info.contract)));
util.report(output.errors);
}); });
it('should compile after instrumenting an abstract function declaration', () => { it('should compile after instrumenting an abstract function declaration', () => {
const contract = util.getCode('function/abstract.sol'); const info = util.instrumentAndCompile('function/abstract');
const info = getInstrumentedVersion(contract, 'test.sol'); util.report(info.solcOutput.errors);
const output = JSON.parse(solc.compile(util.codeToCompilerInput(info.contract)));
util.report(output.errors);
}); });
it('should compile after instrumenting a function declaration with an empty body', () => { it('should compile after instrumenting a function declaration with an empty body', () => {
const contract = util.getCode('function/empty-body.sol'); const info = util.instrumentAndCompile('function/empty-body');
const info = getInstrumentedVersion(contract, 'test.sol'); util.report(info.solcOutput.errors);
const output = JSON.parse(solc.compile(util.codeToCompilerInput(info.contract)));
util.report(output.errors);
}); });
it('should compile after instrumenting lots of declarations in row', () => { it('should compile after instrumenting lots of declarations in row', () => {
const contract = util.getCode('function/multiple.sol'); const info = util.instrumentAndCompile('function/multiple');
const info = getInstrumentedVersion(contract, 'test.sol'); util.report(info.solcOutput.errors);
const output = JSON.parse(solc.compile(util.codeToCompilerInput(info.contract)));
util.report(output.errors);
}); });
it('should compile after instrumenting a new->constructor-->method chain', () => { it('should compile after instrumenting a new->constructor-->method chain', () => {
const contract = util.getCode('function/chainable-new.sol'); const info = util.instrumentAndCompile('function/chainable-new');
const info = getInstrumentedVersion(contract, 'test.sol'); util.report(info.solcOutput.errors);
const output = JSON.parse(solc.compile(util.codeToCompilerInput(info.contract)));
util.report(output.errors);
}); });
it('should compile after instrumenting a constructor call that chains to a method call', () => { it('should compile after instrumenting a constructor call that chains to a method call', () => {
const contract = util.getCode('function/chainable.sol'); const info = util.instrumentAndCompile('function/chainable');
const info = getInstrumentedVersion(contract, 'test.sol'); util.report(info.solcOutput.errors);
const output = JSON.parse(solc.compile(util.codeToCompilerInput(info.contract)));
util.report(output.errors);
}); });
it('should compile after instrumenting a function with calldata keyword', () => { it('should compile after instrumenting a function with calldata keyword', () => {
const contract = util.getCode('function/calldata.sol'); const info = util.instrumentAndCompile('function/calldata');
const info = getInstrumentedVersion(contract, 'test.sol'); util.report(info.solcOutput.errors);
const output = JSON.parse(solc.compile(util.codeToCompilerInput(info.contract)));
util.report(output.errors);
}); });
it('should compile after instrumenting a constructor-->method-->value chain', () => { it('should compile after instrumenting a constructor-->method-->value chain', () => {
const contract = util.getCode('function/chainable-value.sol'); const info = util.instrumentAndCompile('function/chainable-value');
const info = getInstrumentedVersion(contract, 'test.sol'); util.report(info.solcOutput.errors);
const output = JSON.parse(solc.compile(util.codeToCompilerInput(info.contract)));
util.report(output.errors);
}); });
it('should cover a simple invoked function call', done => { it('should cover a simple invoked function call', async function() {
const contract = util.getCode('function/function-call.sol'); const contract = await util.bootstrapCoverage('function/function-call', provider, collector);
const info = getInstrumentedVersion(contract, filePath); coverage.addContract(contract.instrumented, util.filePath);
const coverage = new CoverageMap(); await contract.instance.a();
coverage.addContract(info, filePath); const mapping = coverage.generate(contract.data, util.pathPrefix);
vm.execute(info.contract, 'a', []).then(events => { assert.deepEqual(mapping[util.filePath].l, {
const mapping = coverage.generate(events, pathPrefix); 7: 1,
assert.deepEqual(mapping[filePath].l, { });
7: 1, assert.deepEqual(mapping[util.filePath].b, {});
}); assert.deepEqual(mapping[util.filePath].s, {
assert.deepEqual(mapping[filePath].b, {}); 1: 1,
assert.deepEqual(mapping[filePath].s, { });
1: 1, assert.deepEqual(mapping[util.filePath].f, {
}); 1: 1,
assert.deepEqual(mapping[filePath].f, { 2: 1,
1: 1, });
2: 1,
});
done();
}).catch(done);
}); });
it('should cover a modifier used on a function', done => { it('should cover a modifier used on a function', async function() {
const contract = util.getCode('function/modifier.sol'); const contract = await util.bootstrapCoverage('function/modifier', provider, collector);
const info = getInstrumentedVersion(contract, filePath); coverage.addContract(contract.instrumented, util.filePath);
const coverage = new CoverageMap(); await contract.instance.a(0);
coverage.addContract(info, filePath); const mapping = coverage.generate(contract.data, util.pathPrefix);
vm.execute(info.contract, 'a', [0]).then(events => { assert.deepEqual(mapping[util.filePath].l, {
const mapping = coverage.generate(events, pathPrefix); 5: 1, 6: 1, 9: 1,
assert.deepEqual(mapping[filePath].l, { });
5: 1, 6: 1, 9: 1, assert.deepEqual(mapping[util.filePath].b, {});
}); assert.deepEqual(mapping[util.filePath].s, {
assert.deepEqual(mapping[filePath].b, {}); 1: 1
assert.deepEqual(mapping[filePath].s, { });
1: 1 assert.deepEqual(mapping[util.filePath].f, {
}); 1: 1,
assert.deepEqual(mapping[filePath].f, { 2: 1,
1: 1, });
2: 1,
});
done();
}).catch(done);
}); });
it('should cover a constructor that uses the `constructor` keyword', done => { it('should cover a constructor that uses the `constructor` keyword', async function() {
const contract = util.getCode('function/constructor-keyword.sol'); const contract = await util.bootstrapCoverage('function/constructor-keyword', provider, collector);
const info = getInstrumentedVersion(contract, filePath); coverage.addContract(contract.instrumented, util.filePath);
const coverage = new CoverageMap(); await contract.instance.a();
coverage.addContract(info, filePath); const mapping = coverage.generate(contract.data, util.pathPrefix);
vm.execute(info.contract, 'a', []).then(events => { assert.deepEqual(mapping[util.filePath].l, {
const mapping = coverage.generate(events, pathPrefix); 6: 1, 11: 1
assert.deepEqual(mapping[filePath].l, { });
6: 1, 11: 1 assert.deepEqual(mapping[util.filePath].b, {});
}); assert.deepEqual(mapping[util.filePath].s, {
assert.deepEqual(mapping[filePath].b, {}); 1: 1, 2: 1
assert.deepEqual(mapping[filePath].s, { });
1: 1, 2: 1 assert.deepEqual(mapping[util.filePath].f, {
}); 1: 1,
assert.deepEqual(mapping[filePath].f, { 2: 1,
1: 1, });
2: 1,
});
done();
}).catch(done);
}); });
it('should cover a constructor call that chains to a method call', done => { // We try and call a contract at an address where it doesn't exist and the VM
const contract = util.getCode('function/chainable.sol'); // throws, but we can verify line / statement / fn coverage is getting mapped.
const info = getInstrumentedVersion(contract, filePath); it('should cover a constructor call that chains to a method call', async function() {
const coverage = new CoverageMap(); const contract = await util.bootstrapCoverage('function/chainable', provider, collector);
coverage.addContract(info, filePath); coverage.addContract(contract.instrumented, util.filePath);
// We try and call a contract at an address where it doesn't exist and the VM
// throws, but we can verify line / statement / fn coverage is getting mapped. try { await contract.instance.a() } catch(err){}
vm.execute(info.contract, 'a', []).then(events => {
const mapping = coverage.generate(events, pathPrefix); const mapping = coverage.generate(contract.data, util.pathPrefix);
assert.deepEqual(mapping[filePath].l, {
9: 1, assert.deepEqual(mapping[util.filePath].l, {
}); 9: 1,
assert.deepEqual(mapping[filePath].b, {}); });
assert.deepEqual(mapping[filePath].s, { assert.deepEqual(mapping[util.filePath].b, {});
1: 1, assert.deepEqual(mapping[util.filePath].s, {
}); 1: 1,
assert.deepEqual(mapping[filePath].f, { });
1: 0, assert.deepEqual(mapping[util.filePath].f, {
2: 1, 1: 0,
}); 2: 1,
done(); });
}).catch(done);
}); });
it('should cover a constructor call that chains to a method call', done => { // The vm runs out of gas here - but we can verify line / statement / fn
const contract = util.getCode('function/chainable-value.sol'); // coverage is getting mapped.
const info = getInstrumentedVersion(contract, filePath); it('should cover a constructor call that chains to a method call', async function() {
const coverage = new CoverageMap(); const contract = await util.bootstrapCoverage('function/chainable-value', provider, collector);
coverage.addContract(info, filePath); coverage.addContract(contract.instrumented, util.filePath);
// The vm runs out of gas here - but we can verify line / statement / fn
// coverage is getting mapped. try { await contract.instance.a() } catch(err){}
vm.execute(info.contract, 'a', []).then(events => {
const mapping = coverage.generate(events, pathPrefix); const mapping = coverage.generate(contract.data, util.pathPrefix);
assert.deepEqual(mapping[filePath].l, {
10: 1, assert.deepEqual(mapping[util.filePath].l, {
}); 10: 1,
assert.deepEqual(mapping[filePath].b, {}); });
assert.deepEqual(mapping[filePath].s, { assert.deepEqual(mapping[util.filePath].b, {});
1: 1, assert.deepEqual(mapping[util.filePath].s, {
}); 1: 1,
assert.deepEqual(mapping[filePath].f, { });
1: 0, assert.deepEqual(mapping[util.filePath].f, {
2: 1, 1: 0,
}); 2: 1,
done(); });
}).catch(done);
}); });
}); });
*/

Loading…
Cancel
Save