blob: efdd57e56dcb95acce6255368c6e7d86ee8253a0 [file] [log] [blame] [raw]
// Copyright (c) 2012-2017, Matt Godbolt
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// * Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in the
// documentation and/or other materials provided with the distribution.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ,
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
var fs = require('fs'), assert = require('assert');
var asm = require('../lib/asm');
var asmCl = require('../lib/asm-cl');
var should = require('chai').should();
function processAsm(filename, filters) {
var file = fs.readFileSync(filename, 'utf-8');
var parser;
if (file.indexOf('Microsoft') >= 0)
parser = new asmCl.AsmParser();
else
parser = new asm.AsmParser();
return parser.process(file, filters);
}
var cases = fs.readdirSync(__dirname + '/cases')
.filter(function (x) {
return x.match(/\.asm$/)
})
.map(function (x) {
return __dirname + '/cases/' + x;
});
function bless(filename, output, filters) {
var result = processAsm(__dirname + '/' + filename, filters);
fs.writeFileSync(__dirname + '/' + output, JSON.stringify(result, null, 2));
}
function dump(file) {
for (var i = 0; i < file.length; ++i) {
console.log((i + 1) + " : " + JSON.stringify(file[i]));
}
}
function testFilter(filename, suffix, filters) {
var result = processAsm(filename, filters);
var expected = filename + suffix;
var json = false;
var file;
try {
file = fs.readFileSync(expected + '.json', 'utf-8');
json = true;
} catch (e) {
}
if (!file) {
try {
file = fs.readFileSync(expected, 'utf-8');
} catch (e) {
return;
}
}
it(filename, function () {
if (json) {
file = JSON.parse(file);
} else {
file = file.split(/\r?\n/);
}
if (json) {
result.should.deep.equal(file);
} else {
result.length.should.equal(file.length);
var count = Math.min(file.length, result.length);
for (var i = 0; i < count; ++i) {
result[i].text.should.deep.equal(file[i]);
}
}
});
}
// bless("cases/mips5-square.asm", "cases/mips5-square.asm.directives.labels.comments.json", {directives: true, labels: true, commentOnly: true});
// bless("cases/gcc-sum.asm", "cases/gcc-sum.asm.directives.labels.comments.json", {directives: true, labels: true, commentOnly: true});
// bless("cases/gcc-arm-sum.asm", "cases/gcc-arm-sum.asm.directives.labels.comments.json", {directives: true, labels: true, commentOnly: true});
// bless("cases/gcc-avr-sum.asm", "cases/gcc-avr-sum.asm.directives.labels.comments.json", {directives: true, labels: true, commentOnly: true});
// bless("cases/cl-regex.asm", "cases/cl-regex.asm.directives.labels.comments.json", {directives: true, labels: true, commentOnly: true});
// bless("cases/cl-regex.asm", "cases/cl-regex.asm.dlcb.json", {directives: true, labels: true, commentOnly: true, binary:true});
// bless("cases/cl-maxarray.asm", "cases/cl-maxarray.asm.dlcb.json", {directives: true, labels: true, commentOnly: true, binary:true});
// bless("cases/cl64-sum.asm", "cases/cl64-sum.asm.dlcb.json", {directives: true, labels: true, commentOnly: true, binary:true});
// bless("cases/avr-loop.asm", "cases/avr-loop.asm.directives.labels.comments.json", {directives: true, labels: true, commentOnly: true});
// bless("cases/bug-192.asm", "cases/bug-192.asm.directives.labels.comments.json", {directives: true, labels: true, commentOnly: true});
// bless("cases/arm-moose.asm", "cases/arm-moose.asm.directives.labels.comments.json", {directives: true, labels: true, commentOnly: true});
// bless("cases/arm-moose.asm", "cases/arm-moose.asm.dlcb.json", {directives: true, labels: true, commentOnly: true, binary: true});
// describe('A test', function() {
// it('should work', function(){
// console.log(processAsm(__dirname + '/cases/mips5-square.asm', {directives: true, labels: true, commentOnly: true}));
// });
// });
describe('Filter test cases', function () {
describe('Directive filters', function () {
cases.forEach(function (x) {
testFilter(x, ".directives", {directives: true})
});
});
describe('Directives and labels together', function () {
cases.forEach(function (x) {
testFilter(x, ".directives.labels",
{directives: true, labels: true})
});
});
describe('Directives, labels and comments', function () {
cases.forEach(function (x) {
testFilter(x, ".directives.labels.comments",
{directives: true, labels: true, commentOnly: true})
});
});
describe('Directives, labels, comments and binary mode', function () {
cases.forEach(function (x) {
testFilter(x, ".dlcb",
{directives: true, labels: true, commentOnly: true, binary: true})
});
});
});