Browse Source

.

activeAddress
Ivan Socolsky 10 years ago
parent
commit
790fe56122
  1. 3
      lib/server.js
  2. 20
      test/integration.js

3
lib/server.js

@ -322,8 +322,9 @@ CopayServer.prototype.getBalance = function(opts, cb) {
CopayServer.prototype._createRawTx = function(txp) { CopayServer.prototype._createRawTx = function(txp) {
console.log(txp);
var rawTx = new Bitcore.Transaction() var rawTx = new Bitcore.Transaction()
.from(tx.inputs) .from(txp.inputs)
.to(txp.toAddress, txp.amount) .to(txp.toAddress, txp.amount)
.change(txp.changeAddress); .change(txp.changeAddress);

20
test/integration.js

@ -8,7 +8,9 @@ var sinon = require('sinon');
var should = chai.should(); var should = chai.should();
var levelup = require('levelup'); var levelup = require('levelup');
var memdown = require('memdown'); var memdown = require('memdown');
var Bitcore = require('bitcore');
var SignUtils = require('../lib/signutils');
var Storage = require('../lib/storage'); var Storage = require('../lib/storage');
var Wallet = require('../lib/model/wallet'); var Wallet = require('../lib/model/wallet');
@ -93,14 +95,15 @@ helpers.createAndJoinWallet = function(id, m, n, cb) {
}); });
}); });
}; };
helpers.createUtxos = function(amounts) { helpers.createUtxos = function(wallet, amounts) {
amounts = [].concat(amounts); amounts = [].concat(amounts);
return _.map(amounts, function(amount) { return _.map(amounts, function(amount) {
return { return {
txid: 'dummy' + Math.random(), txid: SignUtils.hash(Math.random().toString()).toString('hex'),
vout: Math.floor((Math.random() * 10) + 1), vout: Math.floor((Math.random() * 10) + 1),
amount: amount, amount: amount,
scriptPubKey: new Bitcore.Script.buildMultisigOut(wallet.publicKeyRing, wallet.n),
}; };
}); });
}; };
@ -607,11 +610,13 @@ describe('Copay server', function() {
}); });
describe('#createTx', function() { describe('#createTx', function() {
var wallet;
beforeEach(function(done) { beforeEach(function(done) {
server = new CopayServer({ server = new CopayServer({
storage: storage, storage: storage,
}); });
helpers.createAndJoinWallet('123', 2, 2, function(err, wallet) { helpers.createAndJoinWallet('123', 2, 2, function(err, w) {
wallet = w;
server.createAddress({ server.createAddress({
walletId: '123', walletId: '123',
isChange: false, isChange: false,
@ -621,12 +626,12 @@ describe('Copay server', function() {
}); });
}); });
it('should create tx', function(done) { it.only('should create tx', function(done) {
var bc = sinon.stub(); var bc = sinon.stub();
bc.getUnspentUtxos = sinon.stub().callsArgWith(1, null, helpers.createUtxos([100, 200])); bc.getUnspentUtxos = sinon.stub().callsArgWith(1, null, helpers.createUtxos(wallet, [100, 200]));
server._getBlockExplorer = sinon.stub().returns(bc); server._getBlockExplorer = sinon.stub().returns(bc);
server._createRawTx = sinon.stub().returns('raw'); //server._createRawTx = sinon.stub().returns('raw');
var txOpts = { var txOpts = {
copayerId: '1', copayerId: '1',
@ -640,7 +645,8 @@ describe('Copay server', function() {
server.createTx(txOpts, function(err, tx) { server.createTx(txOpts, function(err, tx) {
should.not.exist(err); should.not.exist(err);
tx.should.exist; tx.should.exist;
tx.rawTx.should.equal('raw'); console.log(tx);
//tx.rawTx.should.equal('raw');
tx.isAccepted().should.equal.false; tx.isAccepted().should.equal.false;
tx.isRejected().should.equal.false; tx.isRejected().should.equal.false;
server.getPendingTxs({ server.getPendingTxs({

Loading…
Cancel
Save