carto/test/rendering.test.js

72 lines
2.9 KiB
JavaScript
Raw Normal View History

var path = require('path'),
assert = require('assert'),
2011-01-27 06:56:16 +08:00
fs = require('fs');
2011-07-23 01:48:52 +08:00
var carto = require('../lib/carto');
var tree = require('../lib/carto/tree');
var helper = require('./support/helper');
describe('Rendering', function() {
helper.files('rendering', 'mml', function(file) {
it('should render ' + path.basename(file) + ' correctly', function(done) {
2011-01-25 07:50:27 +08:00
var completed = false;
var renderResult;
2011-07-23 01:48:52 +08:00
var mml = helper.mml(file);
new carto.Renderer({
paths: [ path.dirname(file) ],
data_dir: path.join(__dirname, '../data'),
local_data_dir: path.join(__dirname, 'rendering'),
filename: file
}).render(mml, function (err, output) {
if (err) {
if (Array.isArray(err)){
err.forEach(carto.writeError);
} else {
2011-07-23 01:48:52 +08:00
throw err;
}
2011-07-23 01:48:52 +08:00
} else {
var result = helper.resultFile(file);
renderResult = output;
helper.compareToXMLFile(result, output, function(err,expected_json,actual_json) {
2011-07-23 01:48:52 +08:00
completed = true;
var actual = file.replace(path.extname(file),'') + '-actual.json';
var expected = file.replace(path.extname(file),'') + '-expected.json';
2011-07-23 01:48:52 +08:00
if (err) {
// disabled since it can break on large diffs
/*
2011-07-23 01:48:52 +08:00
console.warn(
helper.stylize("Failure", 'red') + ': ' +
helper.stylize(file, 'underline') +
' differs from expected result.');
2011-07-23 01:48:52 +08:00
helper.showDifferences(err);
throw '';
*/
fs.writeFileSync(actual,JSON.stringify(actual_json,null,4));
fs.writeFileSync(expected,JSON.stringify(expected_json,null,4));
throw new Error('failed: xml ' + result + ' in json form does not match expected result:\n' + actual + ' (actual)\n' + expected + ' (expected)');
2012-12-22 07:14:36 +08:00
} else {
// cleanup any actual renders that no longer fail
try {
fs.unlinkSync(actual);
fs.unlinkSync(expected);
2012-12-22 07:14:36 +08:00
} catch (err) {}
2011-07-23 01:48:52 +08:00
}
done();
2011-07-23 01:48:52 +08:00
}, [
helper.removeAbsoluteImages,
helper.removeAbsoluteDatasources
]);
}
});
// beforeExit(function() {
// if (!completed && renderResult) {
// console.warn(helper.stylize('renderer produced:', 'bold'));
// console.warn(renderResult);
// }
// assert.ok(completed, 'Rendering finished.');
// });
});
});
});