asdf-games/node_modules/watchify/test/errors.js

57 lines
1.5 KiB
JavaScript

var test = require('tape');
var watchify = require('../');
var browserify = require('browserify');
var vm = require('vm');
var fs = require('fs');
var path = require('path');
var mkdirp = require('mkdirp');
var os = require('os');
var tmpdir = path.join((os.tmpdir || os.tmpDir)(), 'watchify-' + Math.random());
var file = path.join(tmpdir, 'main.js');
mkdirp.sync(tmpdir);
fs.writeFileSync(file, 'console.log(555)');
test('errors', function (t) {
t.plan(5);
var w = watchify(browserify(file, watchify.args));
w.bundle(function (err, src) {
t.ifError(err);
t.equal(run(src), '555\n');
breakTheBuild();
});
function breakTheBuild() {
setTimeout(function() {
fs.writeFileSync(file, 'console.log(');
}, 1000);
w.once('update', function () {
w.bundle(function (err, src) {
t.ok(err instanceof Error, 'should be error');
fixTheBuild();
});
});
}
function fixTheBuild() {
setTimeout(function() {
fs.writeFileSync(file, 'console.log(333)');
}, 1000);
w.once('update', function () {
w.bundle(function (err, src) {
t.ifError(err);
t.equal(run(src), '333\n');
w.close();
});
});
}
});
function run (src) {
var output = '';
function log (msg) { output += msg + '\n' }
vm.runInNewContext(src, { console: { log: log } });
return output;
}