|
|
|
@ -8,86 +8,8 @@ function append (container, txt) { |
|
|
|
|
container.appendChild(child) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
function render (api) { |
|
|
|
|
var container = yo`<div class="tests" id="tests"></div>` |
|
|
|
|
|
|
|
|
|
let testCallback = function (result) { |
|
|
|
|
if (result.type === 'contract') { |
|
|
|
|
append(container, '\n ' + result.value) |
|
|
|
|
} else if (result.type === 'testPass') { |
|
|
|
|
append(container, '\t✓ ' + result.value) |
|
|
|
|
} else if (result.type === 'testFailure') { |
|
|
|
|
append(container, '\t✘ ' + result.value) |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
let resultsCallback = function (_err, result, cb) { |
|
|
|
|
// total stats for the test
|
|
|
|
|
// result.passingNum
|
|
|
|
|
// result.failureNum
|
|
|
|
|
// result.timePassed
|
|
|
|
|
cb() |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
let updateFinalResult = function (_err, result) { |
|
|
|
|
if (result.totalPassing > 0) { |
|
|
|
|
append(container, (' ' + result.totalPassing + ' passing ') + ('(' + result.totalTime + 's)')) |
|
|
|
|
} |
|
|
|
|
if (result.totalFailing > 0) { |
|
|
|
|
append(container, (' ' + result.totalFailing + ' failing')) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
result.errors.forEach((error, index) => { |
|
|
|
|
append(container, ' ' + (index + 1) + ') ' + error.context + ' ' + error.value) |
|
|
|
|
append(container, '') |
|
|
|
|
append(container, ('\t error: ' + error.message)) |
|
|
|
|
}) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
function runTest (testFilePath, callback) { |
|
|
|
|
var provider = api.fileProviderOf(testFilePath) |
|
|
|
|
provider.get(testFilePath, (error, content) => { |
|
|
|
|
if (!error) { |
|
|
|
|
var runningTest = {} |
|
|
|
|
runningTest[testFilePath] = { content } |
|
|
|
|
remixTests.runTestSources(runningTest, testCallback, resultsCallback, (error, result) => { |
|
|
|
|
updateFinalResult(error, result) |
|
|
|
|
callback(error) |
|
|
|
|
}, api.importFileCb) |
|
|
|
|
} |
|
|
|
|
}) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
let runTests = function () { |
|
|
|
|
container.innerHTML = '' |
|
|
|
|
var path = api.currentPath() |
|
|
|
|
var tests = [] |
|
|
|
|
api.filesFromPath(path, (error, files) => { |
|
|
|
|
if (!error) { |
|
|
|
|
for (var file in files) { |
|
|
|
|
if (/.(_test.sol)$/.exec(file)) tests.push(path + file) |
|
|
|
|
} |
|
|
|
|
async.eachOfSeries(tests, (value, key, callback) => { runTest(value, callback) }) |
|
|
|
|
} |
|
|
|
|
}) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
return yo` |
|
|
|
|
<div class="${css.testTabView} "id="testView"> |
|
|
|
|
<div> |
|
|
|
|
<div class="${css.infoBox}"> |
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
<div class="${css.testList}"> |
|
|
|
|
<p><button onclick=${runTests}>Run Tests</button></p> |
|
|
|
|
${container} |
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
` |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
function testTab (api = {}, events = {}, opts = {}) { |
|
|
|
|
let el = render(api) |
|
|
|
|
let el = prototype.render(api) |
|
|
|
|
let gitterIsLoaded = false |
|
|
|
|
|
|
|
|
|
events.app.register('tabChanged', (tabName) => { |
|
|
|
@ -95,7 +17,7 @@ function testTab (api = {}, events = {}, opts = {}) { |
|
|
|
|
return |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
yo.update(el, render(api)) |
|
|
|
|
yo.update(el, prototype.render(api)) |
|
|
|
|
el.style.display = 'block' |
|
|
|
|
gitterIsLoaded = true |
|
|
|
|
}) |
|
|
|
@ -105,7 +27,83 @@ function testTab (api = {}, events = {}, opts = {}) { |
|
|
|
|
|
|
|
|
|
const prototype = { |
|
|
|
|
constructor: testTab, |
|
|
|
|
render: render |
|
|
|
|
render: function render (api) { |
|
|
|
|
var container = yo`<div class="tests" id="tests"></div>` |
|
|
|
|
|
|
|
|
|
let testCallback = function (result) { |
|
|
|
|
if (result.type === 'contract') { |
|
|
|
|
append(container, '\n ' + result.value) |
|
|
|
|
} else if (result.type === 'testPass') { |
|
|
|
|
append(container, '\t✓ ' + result.value) |
|
|
|
|
} else if (result.type === 'testFailure') { |
|
|
|
|
append(container, '\t✘ ' + result.value) |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
let resultsCallback = function (_err, result, cb) { |
|
|
|
|
// total stats for the test
|
|
|
|
|
// result.passingNum
|
|
|
|
|
// result.failureNum
|
|
|
|
|
// result.timePassed
|
|
|
|
|
cb() |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
let updateFinalResult = function (_err, result) { |
|
|
|
|
if (result.totalPassing > 0) { |
|
|
|
|
append(container, (' ' + result.totalPassing + ' passing ') + ('(' + result.totalTime + 's)')) |
|
|
|
|
} |
|
|
|
|
if (result.totalFailing > 0) { |
|
|
|
|
append(container, (' ' + result.totalFailing + ' failing')) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
result.errors.forEach((error, index) => { |
|
|
|
|
append(container, ' ' + (index + 1) + ') ' + error.context + ' ' + error.value) |
|
|
|
|
append(container, '') |
|
|
|
|
append(container, ('\t error: ' + error.message)) |
|
|
|
|
}) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
function runTest (testFilePath, callback) { |
|
|
|
|
var provider = api.fileProviderOf(testFilePath) |
|
|
|
|
provider.get(testFilePath, (error, content) => { |
|
|
|
|
if (!error) { |
|
|
|
|
var runningTest = {} |
|
|
|
|
runningTest[testFilePath] = { content } |
|
|
|
|
remixTests.runTestSources(runningTest, testCallback, resultsCallback, (error, result) => { |
|
|
|
|
updateFinalResult(error, result) |
|
|
|
|
callback(error) |
|
|
|
|
}, api.importFileCb) |
|
|
|
|
} |
|
|
|
|
}) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
let runTests = function () { |
|
|
|
|
container.innerHTML = '' |
|
|
|
|
var path = api.currentPath() |
|
|
|
|
var tests = [] |
|
|
|
|
api.filesFromPath(path, (error, files) => { |
|
|
|
|
if (!error) { |
|
|
|
|
for (var file in files) { |
|
|
|
|
if (/.(_test.sol)$/.exec(file)) tests.push(path + file) |
|
|
|
|
} |
|
|
|
|
async.eachOfSeries(tests, (value, key, callback) => { runTest(value, callback) }) |
|
|
|
|
} |
|
|
|
|
}) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
return yo` |
|
|
|
|
<div class="${css.testTabView} "id="testView"> |
|
|
|
|
<div> |
|
|
|
|
<div class="${css.infoBox}"> |
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
<div class="${css.testList}"> |
|
|
|
|
<p><button onclick=${runTests}>Run Tests</button></p> |
|
|
|
|
${container} |
|
|
|
|
</div> |
|
|
|
|
</div> |
|
|
|
|
` |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
prototype.constructor.prototype = prototype |
|
|
|
|
module.exports = prototype.constructor |
|
|
|
|