2011-01-25 06:23:18 +08:00
|
|
|
var path = require('path'),
|
|
|
|
assert = require('assert'),
|
2011-01-27 06:56:16 +08:00
|
|
|
fs = require('fs');
|
2011-01-25 06:23:18 +08:00
|
|
|
|
2011-07-23 01:48:52 +08:00
|
|
|
var carto = require('../lib/carto');
|
|
|
|
var tree = require('../lib/carto/tree');
|
2011-01-25 06:23:18 +08:00
|
|
|
var helper = require('./support/helper');
|
|
|
|
|
2012-05-03 00:56:38 +08:00
|
|
|
describe('Rendering', function() {
|
2011-01-25 06:23:18 +08:00
|
|
|
helper.files('rendering', 'mml', function(file) {
|
2012-05-03 00:56:38 +08:00
|
|
|
it('should render ' + path.basename(file) + ' correctly', function(done) {
|
2011-01-25 07:50:27 +08:00
|
|
|
var completed = false;
|
2011-01-26 06:12:45 +08:00
|
|
|
var renderResult;
|
2011-07-23 01:48:52 +08:00
|
|
|
var mml = helper.mml(file);
|
2014-06-11 23:52:06 +08:00
|
|
|
try {
|
|
|
|
var output = new carto.Renderer({
|
|
|
|
paths: [ path.dirname(file) ],
|
|
|
|
data_dir: path.join(__dirname, '../data'),
|
|
|
|
local_data_dir: path.join(__dirname, 'rendering'),
|
|
|
|
filename: file
|
|
|
|
}).render(mml);
|
|
|
|
} catch(err) {
|
|
|
|
if (Array.isArray(err)){
|
|
|
|
err.forEach(carto.writeError);
|
|
|
|
return done();
|
|
|
|
} else {
|
|
|
|
return done(err);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
var result = helper.resultFile(file);
|
|
|
|
renderResult = output;
|
|
|
|
helper.compareToXMLFile(result, output, function(err,expected_json,actual_json) {
|
|
|
|
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) {
|
2014-06-11 23:52:06 +08:00
|
|
|
// disabled since it can break on large diffs
|
|
|
|
/*
|
|
|
|
console.warn(
|
|
|
|
helper.stylize("Failure", 'red') + ': ' +
|
|
|
|
helper.stylize(file, 'underline') +
|
|
|
|
' differs from expected result.');
|
|
|
|
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)');
|
2011-07-23 01:48:52 +08:00
|
|
|
} else {
|
2014-06-11 23:52:06 +08:00
|
|
|
// cleanup any actual renders that no longer fail
|
|
|
|
try {
|
|
|
|
fs.unlinkSync(actual);
|
|
|
|
fs.unlinkSync(expected);
|
|
|
|
} catch (err) {}
|
2011-07-23 01:48:52 +08:00
|
|
|
}
|
2012-05-03 00:56:38 +08:00
|
|
|
done();
|
2014-06-11 23:52:06 +08:00
|
|
|
}, [
|
|
|
|
helper.removeAbsoluteImages,
|
|
|
|
helper.removeAbsoluteDatasources
|
|
|
|
]);
|
2011-01-25 06:23:18 +08:00
|
|
|
|
2012-05-03 00:56:38 +08:00
|
|
|
// beforeExit(function() {
|
|
|
|
// if (!completed && renderResult) {
|
|
|
|
// console.warn(helper.stylize('renderer produced:', 'bold'));
|
|
|
|
// console.warn(renderResult);
|
|
|
|
// }
|
|
|
|
// assert.ok(completed, 'Rendering finished.');
|
|
|
|
// });
|
|
|
|
});
|
|
|
|
});
|
2011-01-25 06:23:18 +08:00
|
|
|
});
|