|
|
@ -217,7 +217,7 @@ export function runTest (testName: string, testObject: any, contractDetails: Com |
|
|
|
const isJSONInterfaceAvailable = testObject && testObject.options && testObject.options.jsonInterface |
|
|
|
const isJSONInterfaceAvailable = testObject && testObject.options && testObject.options.jsonInterface |
|
|
|
if (!isJSONInterfaceAvailable) { return resultsCallback(new Error('Contract interface not available'), { passingNum, failureNum, timePassed }) } |
|
|
|
if (!isJSONInterfaceAvailable) { return resultsCallback(new Error('Contract interface not available'), { passingNum, failureNum, timePassed }) } |
|
|
|
const runList: RunListInterface[] = createRunList(testObject.options.jsonInterface, fileAST, testName) |
|
|
|
const runList: RunListInterface[] = createRunList(testObject.options.jsonInterface, fileAST, testName) |
|
|
|
const web3 = new Web3() |
|
|
|
const web3 = opts.web3 || new Web3() |
|
|
|
const accts: TestResultInterface = { |
|
|
|
const accts: TestResultInterface = { |
|
|
|
type: 'accountList', |
|
|
|
type: 'accountList', |
|
|
|
value: opts.accounts |
|
|
|
value: opts.accounts |
|
|
@ -284,59 +284,63 @@ export function runTest (testName: string, testObject: any, contractDetails: Com |
|
|
|
sendParams.gas = 10000000 * 8 |
|
|
|
sendParams.gas = 10000000 * 8 |
|
|
|
method.send(sendParams).on('receipt', (receipt) => { |
|
|
|
method.send(sendParams).on('receipt', (receipt) => { |
|
|
|
try { |
|
|
|
try { |
|
|
|
const time: number = (Date.now() - startTime) / 1000.0 |
|
|
|
web3.eth.getHHLogsForTx(receipt.transactionHash).then((hhLogs) => { |
|
|
|
const assertionEventHashes = assertionEvents.map(e => Web3.utils.sha3(e.name + '(' + e.params.join() + ')')) |
|
|
|
const time: number = (Date.now() - startTime) / 1000.0 |
|
|
|
let testPassed = false |
|
|
|
const assertionEventHashes = assertionEvents.map(e => Web3.utils.sha3(e.name + '(' + e.params.join() + ')')) |
|
|
|
for (const i in receipt.events) { |
|
|
|
let testPassed = false |
|
|
|
let events = receipt.events[i] |
|
|
|
for (const i in receipt.events) { |
|
|
|
if (!Array.isArray(events)) events = [events] |
|
|
|
let events = receipt.events[i] |
|
|
|
for (const event of events) { |
|
|
|
if (!Array.isArray(events)) events = [events] |
|
|
|
const eIndex = assertionEventHashes.indexOf(event.raw.topics[0]) // event name topic will always be at index 0
|
|
|
|
for (const event of events) { |
|
|
|
if (eIndex >= 0) { |
|
|
|
const eIndex = assertionEventHashes.indexOf(event.raw.topics[0]) // event name topic will always be at index 0
|
|
|
|
const testEvent = web3.eth.abi.decodeParameters(assertionEvents[eIndex].params, event.raw.data) |
|
|
|
if (eIndex >= 0) { |
|
|
|
if (!testEvent[0]) { |
|
|
|
const testEvent = web3.eth.abi.decodeParameters(assertionEvents[eIndex].params, event.raw.data) |
|
|
|
const assertMethod = testEvent[2] |
|
|
|
if (!testEvent[0]) { |
|
|
|
if (assertMethod === 'ok') { // for 'Assert.ok' method
|
|
|
|
const assertMethod = testEvent[2] |
|
|
|
testEvent[3] = 'false' |
|
|
|
if (assertMethod === 'ok') { // for 'Assert.ok' method
|
|
|
|
testEvent[4] = 'true' |
|
|
|
testEvent[3] = 'false' |
|
|
|
|
|
|
|
testEvent[4] = 'true' |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
const location = getAssertMethodLocation(fileAST, testName, func.name, assertMethod) |
|
|
|
|
|
|
|
const resp: TestResultInterface = { |
|
|
|
|
|
|
|
type: 'testFailure', |
|
|
|
|
|
|
|
value: changeCase.sentenceCase(func.name), |
|
|
|
|
|
|
|
filename: testObject.filename, |
|
|
|
|
|
|
|
time: time, |
|
|
|
|
|
|
|
errMsg: testEvent[1], |
|
|
|
|
|
|
|
context: testName, |
|
|
|
|
|
|
|
assertMethod, |
|
|
|
|
|
|
|
returned: testEvent[3], |
|
|
|
|
|
|
|
expected: testEvent[4], |
|
|
|
|
|
|
|
location, |
|
|
|
|
|
|
|
hhLogs |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
testCallback(undefined, resp) |
|
|
|
|
|
|
|
failureNum += 1 |
|
|
|
|
|
|
|
timePassed += time |
|
|
|
|
|
|
|
return next() |
|
|
|
} |
|
|
|
} |
|
|
|
const location = getAssertMethodLocation(fileAST, testName, func.name, assertMethod) |
|
|
|
testPassed = true |
|
|
|
const resp: TestResultInterface = { |
|
|
|
|
|
|
|
type: 'testFailure', |
|
|
|
|
|
|
|
value: changeCase.sentenceCase(func.name), |
|
|
|
|
|
|
|
filename: testObject.filename, |
|
|
|
|
|
|
|
time: time, |
|
|
|
|
|
|
|
errMsg: testEvent[1], |
|
|
|
|
|
|
|
context: testName, |
|
|
|
|
|
|
|
assertMethod, |
|
|
|
|
|
|
|
returned: testEvent[3], |
|
|
|
|
|
|
|
expected: testEvent[4], |
|
|
|
|
|
|
|
location |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
testCallback(undefined, resp) |
|
|
|
|
|
|
|
failureNum += 1 |
|
|
|
|
|
|
|
timePassed += time |
|
|
|
|
|
|
|
return next() |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
testPassed = true |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (testPassed) { |
|
|
|
if (testPassed) { |
|
|
|
const resp: TestResultInterface = { |
|
|
|
const resp: TestResultInterface = { |
|
|
|
type: 'testPass', |
|
|
|
type: 'testPass', |
|
|
|
value: changeCase.sentenceCase(func.name), |
|
|
|
value: changeCase.sentenceCase(func.name), |
|
|
|
filename: testObject.filename, |
|
|
|
filename: testObject.filename, |
|
|
|
time: time, |
|
|
|
time: time, |
|
|
|
context: testName |
|
|
|
context: testName, |
|
|
|
|
|
|
|
hhLogs |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
testCallback(undefined, resp) |
|
|
|
|
|
|
|
passingNum += 1 |
|
|
|
|
|
|
|
timePassed += time |
|
|
|
} |
|
|
|
} |
|
|
|
testCallback(undefined, resp) |
|
|
|
|
|
|
|
passingNum += 1 |
|
|
|
|
|
|
|
timePassed += time |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return next() |
|
|
|
return next() |
|
|
|
|
|
|
|
}) |
|
|
|
} catch (err) { |
|
|
|
} catch (err) { |
|
|
|
console.error(err) |
|
|
|
console.error(err) |
|
|
|
return next(err) |
|
|
|
return next(err) |
|
|
|