Merge pull request #22 from maraoz/add/BitcoreNode

add BitcoreNode model
This commit is contained in:
Esteban Ordano 2015-03-02 16:11:17 -03:00
commit 9ff13d913f
9 changed files with 141 additions and 34 deletions

View File

@ -1,4 +1,5 @@
NetworkMonitor: BitcoreNode:
network: livenet NetworkMonitor:
host: localhost network: livenet
port: 8333 host: localhost
port: 8333

View File

@ -1,26 +1,19 @@
'use strict'; 'use strict';
var config = require('config'); var config = require('config');
var bitcore = require('bitcore'); var BitcoreNode = require('./lib/node.js');
var NetworkMonitor = require('./lib/networkmonitor');
var EventBus = require('./lib/eventbus');
var bus = new EventBus();
var nm = NetworkMonitor.create(bus, config.get('NetworkMonitor'));
bus.register(bitcore.Transaction, function(tx) {
console.log('Transaction:', tx.id);
});
bus.register(bitcore.Block, function(block) {
console.log('Block:', block.id);
});
nm.start();
if (require.main === module) {
var node = BitcoreNode.create(config.get('BitcoreNode'));
node.start();
node.on('error', function(err) {
if (err.code === 'ECONNREFUSED') {
console.log('Connection to bitcoind failed');
} else {
console.log('Unrecognized error: ', err);
}
});
}
module.exports = BitcoreNode;

View File

@ -5,7 +5,7 @@ var bitcore = require('bitcore');
var Promise = require('bluebird'); var Promise = require('bluebird');
var $ = bitcore.util.preconditions; var $ = bitcore.util.preconditions;
var _ = bitcore.deps._; var _ = bitcore.deps._;
var EventEmitter = require('events').EventEmitter; var EventEmitter = require('eventemitter2').EventEmitter2;
var util = require('util'); var util = require('util');
function EventBus() { function EventBus() {

View File

@ -1,7 +1,7 @@
'use strict'; 'use strict';
var util = require('util'); var util = require('util');
var EventEmitter = require('events').EventEmitter; var EventEmitter = require('eventemitter2').EventEmitter2;
var bitcore = require('bitcore'); var bitcore = require('bitcore');
var Networks = bitcore.Networks; var Networks = bitcore.Networks;
@ -44,6 +44,10 @@ NetworkMonitor.prototype.setupPeer = function(peer) {
peer.on('block', function(m) { peer.on('block', function(m) {
self.bus.process(m.block); self.bus.process(m.block);
}); });
peer.on('error', function(err) {
self.emit('error', err);
});
}; };
NetworkMonitor.prototype.start = function() { NetworkMonitor.prototype.start = function() {

50
lib/node.js Normal file
View File

@ -0,0 +1,50 @@
'use strict';
var util = require('util');
var EventEmitter = require('eventemitter2').EventEmitter2;
var bitcore = require('bitcore');
var Unit = bitcore.Unit;
var $ = bitcore.util.preconditions;
var NetworkMonitor = require('./networkmonitor');
var EventBus = require('./eventbus');
var BitcoreNode = function(bus, nm) {
$.checkArgument(bus);
$.checkArgument(nm);
var self = this;
this.bus = bus;
this.nm = nm;
this.bus.register(bitcore.Transaction, function(tx) {
var tout = Unit.fromSatoshis(tx.outputAmount).toBTC();
console.log('Transaction:', tx.id);
console.log('\ttotal_out:', tout, 'BTC');
});
this.bus.register(bitcore.Block, function(block) {
console.log('Block:', block.id);
});
this.bus.onAny(function(value) {
self.emit(this.event, value);
});
this.nm.on('error', function(err) {
self.emit('error', err);
});
};
util.inherits(BitcoreNode, EventEmitter);
BitcoreNode.create = function(opts) {
opts = opts || {};
var bus = new EventBus();
var nm = NetworkMonitor.create(bus, opts.NetworkMonitor);
return new BitcoreNode(bus, nm);
};
BitcoreNode.prototype.start = function() {
this.nm.start();
};
module.exports = BitcoreNode;

View File

@ -55,6 +55,7 @@
"compression": "^1.4.1", "compression": "^1.4.1",
"cors": "^2.5.3", "cors": "^2.5.3",
"cron": "^1.0.4", "cron": "^1.0.4",
"eventemitter2": "^0.4.14",
"express": "4.11.1", "express": "4.11.1",
"glob": "*", "glob": "*",
"js-yaml": "^3.2.7", "js-yaml": "^3.2.7",

View File

@ -57,18 +57,20 @@ describe('EventBus', function() {
bus.process(foo); bus.process(foo);
}); });
var b1 = new BarEvent(); var b1 = new BarEvent();
b1.x = 42; b1.y = 42;
var b2 = new BarEvent(); var b2 = new BarEvent();
b2.x = 69; b2.y = 69;
it('foo returns two bars', function() { it('foo returns two bars', function(cb) {
var bus = new EventBus(); var bus = new EventBus();
var spy = sinon.spy(); var spy = sinon.spy();
bus.register(FooEvent, function() { bus.register(FooEvent, function() {
return [b1, b2]; return [b1, b2];
}); });
bus.register(BarEvent, spy); bus.register(BarEvent, spy);
bus.process(foo); bus.process(foo).then(function() {
spy.callCount.should.equal(2); spy.callCount.should.equal(2);
cb();
});
}); });
it('foo returns two bars and emits external events', function(cb) { it('foo returns two bars and emits external events', function(cb) {
var bus = new EventBus(); var bus = new EventBus();
@ -104,7 +106,7 @@ describe('EventBus', function() {
return Promise.resolve([b1, b2]).delay(1); return Promise.resolve([b1, b2]).delay(1);
}); });
bus.register(BarEvent, function(e) { bus.register(BarEvent, function(e) {
if (e.x === b1.x) { if (e.y === b1.y) {
throw err; throw err;
} }
}); });

View File

@ -8,7 +8,7 @@ var sinon = require('sinon');
var util = require('util'); var util = require('util');
var Transaction = bitcore.Transaction; var Transaction = bitcore.Transaction;
var Block = bitcore.Block; var Block = bitcore.Block;
var EventEmitter = require('events').EventEmitter; var EventEmitter = require('eventemitter2').EventEmitter2;
var NetworkMonitor = require('../lib/networkmonitor'); var NetworkMonitor = require('../lib/networkmonitor');
var EventBus = require('../lib/eventbus'); var EventBus = require('../lib/eventbus');
@ -65,9 +65,16 @@ describe('NetworkMonitor', function() {
nm.start.bind(nm).should.not.throw(); nm.start.bind(nm).should.not.throw();
}); });
it('broadcasts errors in underlying peer', function(cb) {
var nm = new NetworkMonitor(busMock, peerMock);
nm.on('error', cb);
nm.start();
peerMock.emit('error');
});
it('broadcasts ready after start', function(cb) { it('broadcasts ready after start', function(cb) {
var nm = new NetworkMonitor(busMock, peerMock); var nm = new NetworkMonitor(busMock, peerMock);
nm.on('ready', cb) nm.on('ready', cb);
nm.start(); nm.start();
}); });

49
test/node.js Normal file
View File

@ -0,0 +1,49 @@
'use strict';
var chai = require('chai');
var should = chai.should();
var sinon = require('sinon');
var Promise = require('bluebird');
var EventEmitter = require('eventemitter2').EventEmitter2;
var BitcoreNode = require('../lib/node');
var EventBus = require('../lib/eventbus');
Promise.longStackTraces();
describe('BitcoreNode', function() {
// mocks
var busMock, nmMock;
beforeEach(function() {
busMock = new EventBus();
nmMock = new EventEmitter();
nmMock.start = function() {};
});
describe('instantiates', function() {
it('from constructor', function() {
var node = new BitcoreNode(busMock, nmMock);
should.exist(node);
});
it('from create', function() {
var node = BitcoreNode.create();
should.exist(node);
});
});
it('starts', function() {
var node = new BitcoreNode(busMock, nmMock);
node.start.bind(node).should.not.throw();
});
it('broadcasts errors from network monitor', function(cb) {
var node = new BitcoreNode(busMock, nmMock);
node.on('error', cb);
nmMock.emit('error');
});
it('exposes all events from the event bus', function(cb) {
var node = new BitcoreNode(busMock, nmMock);
node.on('foo', cb);
busMock.emit('foo');
});
});