Browse Source

adjust confirmations for cached txs only

activeAddress
Ivan Socolsky 9 years ago
parent
commit
ddd9107600
No known key found for this signature in database GPG Key ID: FAECE6A05FAA4F56
  1. 3
      lib/server.js
  2. 69
      test/integration/server.js

3
lib/server.js

@ -2686,9 +2686,10 @@ WalletService.prototype.getTxHistory = function(opts, cb) {
self.storage.storeTxHistoryCache(self.walletId, totalItems, fwdIndex, txsToCache, next); self.storage.storeTxHistoryCache(self.walletId, totalItems, fwdIndex, txsToCache, next);
}, },
function(next) { function(next) {
if (!useCache || !fromCache) return next();
if (!txs) return next(); if (!txs) return next();
// Fix tx confirmations // Fix tx confirmations for cached txs
self._getBlockchainHeight(network, function(err, height) { self._getBlockchainHeight(network, function(err, height) {
if (err || !height) return next(err); if (err || !height) return next(err);
_.each(txs, function(tx) { _.each(txs, function(tx) {

69
test/integration/server.js

@ -5839,11 +5839,10 @@ describe('Wallet service', function() {
var skip = 31; var skip = 31;
var limit = 10; var limit = 10;
var totalItems = 200; var totalItems = 200;
var currentHeight = 1000;
var h = helpers.historyCacheTest(totalItems); var h = helpers.historyCacheTest(totalItems);
helpers.stubHistory(h); helpers.stubHistory(h);
blockchainExplorer.getBlockchainHeight = sinon.stub().callsArgWith(0, null, currentHeight); blockchainExplorer.getBlockchainHeight = sinon.stub().callsArgWith(0, null, 200);
var storeTxHistoryCacheSpy = sinon.spy(server.storage, 'storeTxHistoryCache'); var storeTxHistoryCacheSpy = sinon.spy(server.storage, 'storeTxHistoryCache');
@ -5863,10 +5862,10 @@ describe('Wallet service', function() {
calls[0].args[1].should.equal(totalItems); // total calls[0].args[1].should.equal(totalItems); // total
calls[0].args[2].should.equal(totalItems - skip - limit); // position calls[0].args[2].should.equal(totalItems - skip - limit); // position
calls[0].args[3].length.should.equal(5); // 5 txs have confirmations>= 100 calls[0].args[3].length.should.equal(5); // 5 txs have confirmations>= 36
// should be reversed! // should be reversed!
calls[0].args[3][0].confirmations.should.equal(currentHeight - (totalItems - (skip + limit)) + 1); calls[0].args[3][0].confirmations.should.equal(skip + limit - 1);
calls[0].args[3][0].txid.should.equal(h[skip + limit - 1].txid); calls[0].args[3][0].txid.should.equal(h[skip + limit - 1].txid);
server.storage.storeTxHistoryCache.restore(); server.storage.storeTxHistoryCache.restore();
done(); done();
@ -5897,11 +5896,10 @@ describe('Wallet service', function() {
var skip = 195; var skip = 195;
var limit = 5; var limit = 5;
var totalItems = 200; var totalItems = 200;
var currentHeight = 1000;
var h = helpers.historyCacheTest(totalItems); var h = helpers.historyCacheTest(totalItems);
helpers.stubHistory(h); helpers.stubHistory(h);
blockchainExplorer.getBlockchainHeight = sinon.stub().callsArgWith(0, null, currentHeight); blockchainExplorer.getBlockchainHeight = sinon.stub().callsArgWith(0, null, 200);
var storeTxHistoryCacheSpy = sinon.spy(server.storage, 'storeTxHistoryCache'); var storeTxHistoryCacheSpy = sinon.spy(server.storage, 'storeTxHistoryCache');
server.getTxHistory({ server.getTxHistory({
@ -5920,7 +5918,7 @@ describe('Wallet service', function() {
calls[0].args[3].length.should.equal(5); calls[0].args[3].length.should.equal(5);
// should be reversed! // should be reversed!
calls[0].args[3][0].confirmations.should.equal(currentHeight + 1); calls[0].args[3][0].confirmations.should.equal(totalItems - 1);
calls[0].args[3][0].txid.should.equal(h[totalItems - 1].txid); calls[0].args[3][0].txid.should.equal(h[totalItems - 1].txid);
server.storage.storeTxHistoryCache.restore(); server.storage.storeTxHistoryCache.restore();
done(); done();
@ -5934,12 +5932,13 @@ describe('Wallet service', function() {
var h = helpers.historyCacheTest(20); var h = helpers.historyCacheTest(20);
_.each(h, function(x, i) { _.each(h, function(x, i) {
x.blockheight = 100 - i; x.confirmations = 500 + i;
x.blockheight = 1000 - i;
}); });
helpers.stubHistory(h); helpers.stubHistory(h);
var storeTxHistoryCacheSpy = sinon.spy(server.storage, 'storeTxHistoryCache'); var storeTxHistoryCacheSpy = sinon.spy(server.storage, 'storeTxHistoryCache');
blockchainExplorer.getBlockchainHeight = sinon.stub().callsArgWith(0, null, 100); blockchainExplorer.getBlockchainHeight = sinon.stub().callsArgWith(0, null, 1500);
// Cache txs // Cache txs
server.getTxHistory({ server.getTxHistory({
@ -5957,10 +5956,10 @@ describe('Wallet service', function() {
}, function(err, txs) { }, function(err, txs) {
should.not.exist(err); should.not.exist(err);
txs.length.should.equal(20); txs.length.should.equal(20);
_.first(txs).confirmations.should.equal(1); _.first(txs).confirmations.should.equal(501);
_.last(txs).confirmations.should.equal(20); _.last(txs).confirmations.should.equal(520);
blockchainExplorer.getBlockchainHeight = sinon.stub().callsArgWith(0, null, 200); blockchainExplorer.getBlockchainHeight = sinon.stub().callsArgWith(0, null, 2000);
server._notify('NewBlock', { server._notify('NewBlock', {
network: 'livenet', network: 'livenet',
hash: 'dummy hash', hash: 'dummy hash',
@ -5974,8 +5973,8 @@ describe('Wallet service', function() {
limit: 30, limit: 30,
}, function(err, txs) { }, function(err, txs) {
should.not.exist(err); should.not.exist(err);
_.first(txs).confirmations.should.equal(101); _.first(txs).confirmations.should.equal(1001);
_.last(txs).confirmations.should.equal(120); _.last(txs).confirmations.should.equal(1020);
server.storage.storeTxHistoryCache.restore(); server.storage.storeTxHistoryCache.restore();
Defaults.CONFIRMATIONS_TO_START_CACHING = _confirmations; Defaults.CONFIRMATIONS_TO_START_CACHING = _confirmations;
@ -5993,11 +5992,53 @@ describe('Wallet service', function() {
WalletService._cachedBlockheight = null; WalletService._cachedBlockheight = null;
var h = helpers.historyCacheTest(20); var h = helpers.historyCacheTest(20);
_.each(h, function(x, i) {
x.confirmations = 500 + i;
x.blockheight = 1000 - i;
});
helpers.stubHistory(h); helpers.stubHistory(h);
var storeTxHistoryCacheSpy = sinon.spy(server.storage, 'storeTxHistoryCache'); var storeTxHistoryCacheSpy = sinon.spy(server.storage, 'storeTxHistoryCache');
blockchainExplorer.getBlockchainHeight = sinon.stub().callsArgWith(0, null, null); blockchainExplorer.getBlockchainHeight = sinon.stub().callsArgWith(0, null, null);
// Cache txs
server.getTxHistory({
skip: 0,
limit: 30,
}, function(err, txs) {
should.not.exist(err);
should.exist(txs);
txs.length.should.equal(20);
var calls = storeTxHistoryCacheSpy.getCalls();
calls.length.should.equal(1);
server.getTxHistory({
skip: 0,
limit: 30,
}, function(err, txs) {
should.not.exist(err);
txs.length.should.equal(20);
_.first(txs).confirmations.should.equal(500);
_.last(txs).confirmations.should.equal(519);
server.storage.storeTxHistoryCache.restore();
Defaults.CONFIRMATIONS_TO_START_CACHING = _confirmations;
done();
});
});
});
it('should get returned # of confirmations for non cached txs', function(done) {
var _confirmations = Defaults.CONFIRMATIONS_TO_START_CACHING;
Defaults.CONFIRMATIONS_TO_START_CACHING = 6;
WalletService._cachedBlockheight = null;
var h = helpers.historyCacheTest(20);
helpers.stubHistory(h);
var storeTxHistoryCacheSpy = sinon.spy(server.storage, 'storeTxHistoryCache');
blockchainExplorer.getBlockchainHeight = sinon.stub().callsArgWith(0, null, 500);
// Cache txs // Cache txs
server.getTxHistory({ server.getTxHistory({
skip: 0, skip: 0,

Loading…
Cancel
Save