2018-11-06 07:14:33 +03:00
|
|
|
'use strict';
|
|
|
|
|
2018-12-04 11:12:05 +03:00
|
|
|
var fs = require('fs')
|
2018-11-06 07:14:33 +03:00
|
|
|
var runner = require('urbit-runner')
|
|
|
|
var Urbit = runner.Urbit;
|
|
|
|
var ERROR = runner.ERROR;
|
|
|
|
var actions = runner.actions
|
|
|
|
|
2019-02-07 19:40:29 +03:00
|
|
|
var args = ['-cgPSF', 'zod', '-B', 'brass.pill', 'zod'];
|
2018-11-06 07:14:33 +03:00
|
|
|
var urbit = new Urbit(args);
|
|
|
|
|
2018-11-06 10:27:56 +03:00
|
|
|
// vere hangs (always?) with run in travis-ci with -P
|
|
|
|
// so we send ^Z if we hang for ~s30
|
|
|
|
function exit() {
|
|
|
|
setTimeout(function(){
|
|
|
|
urbit.pty.write('\x1a');
|
|
|
|
urbit.pty.on('exit', function(code, signal){
|
|
|
|
process.exit(0);
|
|
|
|
})
|
|
|
|
}, 30 * 1000);
|
|
|
|
|
|
|
|
return urbit.exit(0);
|
|
|
|
}
|
|
|
|
|
2018-11-06 07:14:33 +03:00
|
|
|
Promise.resolve(urbit)
|
2019-01-08 09:13:13 +03:00
|
|
|
// XX temporary
|
|
|
|
// send ctrl-x to select dojo
|
|
|
|
//
|
|
|
|
.then(function(){
|
|
|
|
return urbit.expect(/talk\[\] /)
|
|
|
|
.then(function() {
|
|
|
|
return urbit.pty.write("\x18")
|
|
|
|
})
|
|
|
|
.then(function() { return urbit })
|
|
|
|
})
|
2018-11-06 07:14:33 +03:00
|
|
|
.then(actions.safeBoot)
|
|
|
|
.then(actions.test)
|
2019-01-30 01:33:53 +03:00
|
|
|
.then(function(){
|
|
|
|
return urbit.line("|mass")
|
|
|
|
.then(function(){
|
|
|
|
return urbit.expectEcho("%ran-mass")
|
|
|
|
.then(function(){ return urbit.resetListeners(); })
|
|
|
|
})
|
|
|
|
})
|
2018-11-06 10:27:56 +03:00
|
|
|
.then(exit)
|
2018-11-06 07:14:33 +03:00
|
|
|
.catch(function(err){
|
2018-11-06 10:27:56 +03:00
|
|
|
// we still exit 0, Arvo errors are not our fault ...
|
2018-11-06 07:14:33 +03:00
|
|
|
return urbit.waitSilent()
|
|
|
|
.then(function(){
|
2018-11-06 10:27:56 +03:00
|
|
|
return urbit.warn("Arvo test aborted:", err);
|
|
|
|
})
|
|
|
|
.then(exit);
|
2018-11-06 07:14:33 +03:00
|
|
|
});
|