mirror of
https://github.com/XRPLF/rippled.git
synced 2025-11-20 11:05:54 +00:00
266 lines
6.7 KiB
JavaScript
266 lines
6.7 KiB
JavaScript
|
|
var async = require("async");
|
|
var buster = require("buster");
|
|
var fs = require("fs");
|
|
|
|
var server = require("./server.js");
|
|
var remote = require("../js/remote.js");
|
|
var config = require("./config.js");
|
|
|
|
var Amount = require("../js/amount.js").Amount;
|
|
|
|
require("../js/amount.js").setAccounts(config.accounts);
|
|
|
|
buster.testRunner.timeout = 5000;
|
|
|
|
var alpha;
|
|
|
|
buster.testCase("Work in progress", {
|
|
'setUp' :
|
|
function (done) {
|
|
server.start("alpha",
|
|
function (e) {
|
|
buster.refute(e);
|
|
|
|
alpha = remote.remoteConfig(config, "alpha", 'TRACE');
|
|
|
|
alpha
|
|
.once('ledger_closed', done)
|
|
.connect();
|
|
}
|
|
// , 'MOCK'
|
|
);
|
|
},
|
|
|
|
'tearDown' :
|
|
function (done) {
|
|
alpha
|
|
.on('disconnected', function () {
|
|
server.stop("alpha", function (e) {
|
|
buster.refute(e);
|
|
done();
|
|
});
|
|
})
|
|
.connect(false);
|
|
},
|
|
|
|
"offer create then cancel in one ledger" :
|
|
function (done) {
|
|
var final_create;
|
|
|
|
async.waterfall([
|
|
function (callback) {
|
|
alpha.transaction()
|
|
.offer_create("root", "500", "100/USD/root")
|
|
.on("proposed", function (m) {
|
|
console.log("PROPOSED: offer_create: %s", JSON.stringify(m));
|
|
callback(m.result != 'tesSUCCESS', m);
|
|
})
|
|
.on("final", function (m) {
|
|
console.log("FINAL: offer_create: %s", JSON.stringify(m));
|
|
|
|
buster.assert.equals('tesSUCCESS', m.metadata.TransactionResult);
|
|
|
|
final_create = m;
|
|
})
|
|
.submit();
|
|
},
|
|
function (m, callback) {
|
|
alpha.transaction()
|
|
.offer_cancel("root", m.transaction.Sequence)
|
|
.on("proposed", function (m) {
|
|
console.log("PROPOSED: offer_cancel: %s", JSON.stringify(m));
|
|
callback(m.result != 'tesSUCCESS', m);
|
|
})
|
|
.on("final", function (m) {
|
|
console.log("FINAL: offer_cancel: %s", JSON.stringify(m));
|
|
|
|
buster.assert.equals('tesSUCCESS', m.metadata.TransactionResult);
|
|
buster.assert(final_create);
|
|
done();
|
|
})
|
|
.submit();
|
|
},
|
|
function (m, callback) {
|
|
alpha
|
|
.once("ledger_closed", function (ledger_closed, ledger_closed_index) {
|
|
console.log("LEDGER_CLOSED: %d: %s", ledger_closed_index, ledger_closed);
|
|
})
|
|
.ledger_accept();
|
|
}
|
|
], function (error) {
|
|
console.log("result: error=%s", error);
|
|
buster.refute(error);
|
|
|
|
if (error) done();
|
|
});
|
|
},
|
|
|
|
"offer_create then ledger_accept then offer_cancel then ledger_accept." :
|
|
function (done) {
|
|
var final_create;
|
|
var offer_seq;
|
|
|
|
async.waterfall([
|
|
function (callback) {
|
|
alpha.transaction()
|
|
.offer_create("root", "500", "100/USD/root")
|
|
.on("proposed", function (m) {
|
|
console.log("PROPOSED: offer_create: %s", JSON.stringify(m));
|
|
|
|
offer_seq = m.transaction.Sequence;
|
|
|
|
callback(m.result != 'tesSUCCESS');
|
|
})
|
|
.on("final", function (m) {
|
|
console.log("FINAL: offer_create: %s", JSON.stringify(m));
|
|
|
|
buster.assert.equals('tesSUCCESS', m.metadata.TransactionResult);
|
|
|
|
final_create = m;
|
|
|
|
callback();
|
|
})
|
|
.submit();
|
|
},
|
|
function (callback) {
|
|
if (!final_create) {
|
|
alpha
|
|
.once("ledger_closed", function (ledger_closed, ledger_closed_index) {
|
|
console.log("LEDGER_CLOSED: %d: %s", ledger_closed_index, ledger_closed);
|
|
|
|
})
|
|
.ledger_accept();
|
|
}
|
|
else {
|
|
callback();
|
|
}
|
|
},
|
|
function (callback) {
|
|
console.log("CANCEL: offer_cancel: %d", offer_seq);
|
|
|
|
alpha.transaction()
|
|
.offer_cancel("root", offer_seq)
|
|
.on("proposed", function (m) {
|
|
console.log("PROPOSED: offer_cancel: %s", JSON.stringify(m));
|
|
callback(m.result != 'tesSUCCESS');
|
|
})
|
|
.on("final", function (m) {
|
|
console.log("FINAL: offer_cancel: %s", JSON.stringify(m));
|
|
|
|
buster.assert.equals('tesSUCCESS', m.metadata.TransactionResult);
|
|
buster.assert(final_create);
|
|
|
|
done();
|
|
})
|
|
.submit();
|
|
},
|
|
// See if ledger_accept will crash.
|
|
function (callback) {
|
|
alpha
|
|
.once("ledger_closed", function (ledger_closed, ledger_closed_index) {
|
|
console.log("LEDGER_CLOSED: A: %d: %s", ledger_closed_index, ledger_closed);
|
|
callback();
|
|
})
|
|
.ledger_accept();
|
|
},
|
|
function (callback) {
|
|
alpha
|
|
.once("ledger_closed", function (ledger_closed, ledger_closed_index) {
|
|
console.log("LEDGER_CLOSED: B: %d: %s", ledger_closed_index, ledger_closed);
|
|
callback();
|
|
})
|
|
.ledger_accept();
|
|
},
|
|
], function (error) {
|
|
console.log("result: error=%s", error);
|
|
buster.refute(error);
|
|
|
|
if (error) done();
|
|
});
|
|
},
|
|
|
|
"offer cancel past and future sequence" :
|
|
function (done) {
|
|
var final_create;
|
|
|
|
async.waterfall([
|
|
function (callback) {
|
|
alpha.transaction()
|
|
.payment('root', 'alice', Amount.from_json("10000"))
|
|
.flags('CreateAccount')
|
|
.on("proposed", function (m) {
|
|
console.log("PROPOSED: CreateAccount: %s", JSON.stringify(m));
|
|
callback(m.result != 'tesSUCCESS', m);
|
|
})
|
|
.on('error', function(m) {
|
|
console.log("error: %s", m);
|
|
|
|
buster.assert(false);
|
|
callback(m);
|
|
})
|
|
.submit();
|
|
},
|
|
// Past sequence but wrong
|
|
function (m, callback) {
|
|
alpha.transaction()
|
|
.offer_cancel("root", m.transaction.Sequence)
|
|
.on("proposed", function (m) {
|
|
console.log("PROPOSED: offer_cancel past: %s", JSON.stringify(m));
|
|
callback(m.result != 'tesSUCCESS', m);
|
|
})
|
|
.submit();
|
|
},
|
|
// Same sequence
|
|
function (m, callback) {
|
|
alpha.transaction()
|
|
.offer_cancel("root", m.transaction.Sequence+1)
|
|
.on("proposed", function (m) {
|
|
console.log("PROPOSED: offer_cancel same: %s", JSON.stringify(m));
|
|
callback(m.result != 'temBAD_SEQUENCE', m);
|
|
})
|
|
.submit();
|
|
},
|
|
// Future sequence
|
|
function (m, callback) {
|
|
// After a malformed transaction, need to recover correct sequence.
|
|
alpha.set_account_seq("root", alpha.account_seq("root")-1);
|
|
|
|
alpha.transaction()
|
|
.offer_cancel("root", m.transaction.Sequence+2)
|
|
.on("proposed", function (m) {
|
|
console.log("ERROR: offer_cancel future: %s", JSON.stringify(m));
|
|
callback(m.result != 'temBAD_SEQUENCE');
|
|
})
|
|
.submit();
|
|
},
|
|
// See if ledger_accept will crash.
|
|
function (callback) {
|
|
alpha
|
|
.once("ledger_closed", function (ledger_closed, ledger_closed_index) {
|
|
console.log("LEDGER_CLOSED: A: %d: %s", ledger_closed_index, ledger_closed);
|
|
callback();
|
|
})
|
|
.ledger_accept();
|
|
},
|
|
function (callback) {
|
|
alpha
|
|
.once("ledger_closed", function (ledger_closed, ledger_closed_index) {
|
|
console.log("LEDGER_CLOSED: B: %d: %s", ledger_closed_index, ledger_closed);
|
|
callback();
|
|
})
|
|
.ledger_accept();
|
|
},
|
|
function (callback) {
|
|
callback();
|
|
}
|
|
], function (error) {
|
|
console.log("result: error=%s", error);
|
|
buster.refute(error);
|
|
|
|
done();
|
|
});
|
|
},
|
|
});
|
|
// vim:sw=2:sts=2:ts=8
|