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:
network: livenet
host: localhost
port: 8333
BitcoreNode:
NetworkMonitor:
network: livenet
host: localhost
port: 8333

View File

@ -1,26 +1,19 @@
'use strict';
var config = require('config');
var bitcore = require('bitcore');
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();
var BitcoreNode = require('./lib/node.js');
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 $ = bitcore.util.preconditions;
var _ = bitcore.deps._;
var EventEmitter = require('events').EventEmitter;
var EventEmitter = require('eventemitter2').EventEmitter2;
var util = require('util');
function EventBus() {

View File

@ -1,7 +1,7 @@
'use strict';
var util = require('util');
var EventEmitter = require('events').EventEmitter;
var EventEmitter = require('eventemitter2').EventEmitter2;
var bitcore = require('bitcore');
var Networks = bitcore.Networks;
@ -44,6 +44,10 @@ NetworkMonitor.prototype.setupPeer = function(peer) {
peer.on('block', function(m) {
self.bus.process(m.block);
});
peer.on('error', function(err) {
self.emit('error', err);
});
};
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",
"cors": "^2.5.3",
"cron": "^1.0.4",
"eventemitter2": "^0.4.14",
"express": "4.11.1",
"glob": "*",
"js-yaml": "^3.2.7",

View File

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

View File

@ -8,7 +8,7 @@ var sinon = require('sinon');
var util = require('util');
var Transaction = bitcore.Transaction;
var Block = bitcore.Block;
var EventEmitter = require('events').EventEmitter;
var EventEmitter = require('eventemitter2').EventEmitter2;
var NetworkMonitor = require('../lib/networkmonitor');
var EventBus = require('../lib/eventbus');
@ -65,9 +65,16 @@ describe('NetworkMonitor', function() {
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) {
var nm = new NetworkMonitor(busMock, peerMock);
nm.on('ready', cb)
nm.on('ready', cb);
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');
});
});