2015-02-23 10:36:57 +11:00
|
|
|
/* global describe, it */
|
|
|
|
|
2014-10-19 01:10:20 +11:00
|
|
|
var assert = require('assert')
|
2014-11-24 21:15:28 +11:00
|
|
|
var bigi = require('bigi')
|
2014-10-19 01:10:20 +11:00
|
|
|
var bitcoin = require('../../')
|
2016-04-22 17:08:45 +10:00
|
|
|
var blockchain = require('./_blockchain')
|
2014-10-19 01:10:20 +11:00
|
|
|
|
2015-02-23 10:36:57 +11:00
|
|
|
describe('bitcoinjs-lib (basic)', function () {
|
2015-03-19 11:15:51 +11:00
|
|
|
it('can generate a random bitcoin address', function () {
|
2014-11-24 21:02:19 +11:00
|
|
|
// for testing only
|
2015-03-19 11:15:51 +11:00
|
|
|
function rng () { return new Buffer('zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz') }
|
2014-11-24 21:02:19 +11:00
|
|
|
|
2015-03-02 16:48:36 +11:00
|
|
|
// generate random keyPair
|
|
|
|
var keyPair = bitcoin.ECPair.makeRandom({ rng: rng })
|
2015-07-08 15:56:21 +10:00
|
|
|
var address = keyPair.getAddress()
|
2014-11-24 21:02:19 +11:00
|
|
|
|
2015-05-07 11:29:20 +10:00
|
|
|
assert.strictEqual(address, '1F5VhMHukdnUES9kfXqzPzMeF1GPHKiF64')
|
2015-03-19 11:15:51 +11:00
|
|
|
})
|
2014-11-24 21:02:19 +11:00
|
|
|
|
2015-02-23 10:36:57 +11:00
|
|
|
it('can generate an address from a SHA256 hash', function () {
|
2014-11-24 21:15:28 +11:00
|
|
|
var hash = bitcoin.crypto.sha256('correct horse battery staple')
|
|
|
|
var d = bigi.fromBuffer(hash)
|
|
|
|
|
2015-03-02 16:48:36 +11:00
|
|
|
var keyPair = new bitcoin.ECPair(d)
|
2015-07-08 15:56:21 +10:00
|
|
|
var address = keyPair.getAddress()
|
2014-11-24 21:15:28 +11:00
|
|
|
|
2015-05-07 11:29:20 +10:00
|
|
|
assert.strictEqual(address, '1C7zdTfnkzmr13HfA2vNm5SJYRK6nEKyq8')
|
2014-11-24 21:15:28 +11:00
|
|
|
})
|
|
|
|
|
2015-04-15 18:19:49 -05:00
|
|
|
it('can generate a random keypair for alternative networks', function () {
|
|
|
|
// for testing only
|
|
|
|
function rng () { return new Buffer('zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz') }
|
|
|
|
|
|
|
|
var litecoin = bitcoin.networks.litecoin
|
|
|
|
|
|
|
|
var keyPair = bitcoin.ECPair.makeRandom({ network: litecoin, rng: rng })
|
|
|
|
var wif = keyPair.toWIF()
|
2015-07-08 15:56:21 +10:00
|
|
|
var address = keyPair.getAddress()
|
2015-04-15 18:19:49 -05:00
|
|
|
|
2015-05-07 11:29:20 +10:00
|
|
|
assert.strictEqual(address, 'LZJSxZbjqJ2XVEquqfqHg1RQTDdfST5PTn')
|
|
|
|
assert.strictEqual(wif, 'T7A4PUSgTDHecBxW1ZiYFrDNRih2o7M8Gf9xpoCgudPF9gDiNvuS')
|
2015-04-15 18:19:49 -05:00
|
|
|
})
|
|
|
|
|
2015-02-23 10:36:57 +11:00
|
|
|
it('can import an address via WIF', function () {
|
2015-03-02 16:48:36 +11:00
|
|
|
var keyPair = bitcoin.ECPair.fromWIF('Kxr9tQED9H44gCmp6HAdmemAzU3n84H3dGkuWTKvE23JgHMW8gct')
|
2015-07-08 15:56:21 +10:00
|
|
|
var address = keyPair.getAddress()
|
2014-10-19 01:10:20 +11:00
|
|
|
|
2015-05-07 11:29:20 +10:00
|
|
|
assert.strictEqual(address, '19AAjaTUbRjQCMuVczepkoPswiZRhjtg31')
|
2014-10-19 01:10:20 +11:00
|
|
|
})
|
|
|
|
|
2015-02-23 10:36:57 +11:00
|
|
|
it('can create a Transaction', function () {
|
2015-03-02 16:48:36 +11:00
|
|
|
var keyPair = bitcoin.ECPair.fromWIF('L1uyy5qTuGrVXrmrsvHWHgVzW9kKdrp27wBC7Vs6nZDTF2BRUVwy')
|
2014-10-19 01:10:20 +11:00
|
|
|
var tx = new bitcoin.TransactionBuilder()
|
|
|
|
|
2015-02-23 10:36:57 +11:00
|
|
|
tx.addInput('aa94ab02c182214f090e99a0d57021caffd0f195a81c24602b1028b130b63e31', 0)
|
|
|
|
tx.addOutput('1Gokm82v6DmtwKEB8AiVhm82hyFSsEvBDK', 15000)
|
2015-03-02 16:48:36 +11:00
|
|
|
tx.sign(0, keyPair)
|
2014-10-19 12:29:55 +11:00
|
|
|
|
2015-05-07 11:29:20 +10:00
|
|
|
assert.strictEqual(tx.build().toHex(), '0100000001313eb630b128102b60241ca895f1d0ffca2170d5a0990e094f2182c102ab94aa000000006b483045022100aefbcf847900b01dd3e3debe054d3b6d03d715d50aea8525f5ea3396f168a1fb022013d181d05b15b90111808b22ef4f9ebe701caf2ab48db269691fdf4e9048f4f60121029f50f51d63b345039a290c94bffd3180c99ed659ff6ea6b1242bca47eb93b59fffffffff01983a0000000000001976a914ad618cf4333b3b248f9744e8e81db2964d0ae39788ac00000000')
|
2014-10-19 12:29:55 +11:00
|
|
|
})
|
2016-04-22 17:08:45 +10:00
|
|
|
|
|
|
|
it('can create a [complex] Transaction', function (done) {
|
|
|
|
this.timeout(30000)
|
|
|
|
|
|
|
|
var network = bitcoin.networks.testnet
|
|
|
|
var alice = bitcoin.ECPair.makeRandom({ network: network })
|
|
|
|
var bob = bitcoin.ECPair.makeRandom({ network: network })
|
|
|
|
var alicesAddress = alice.getAddress()
|
|
|
|
var bobsAddress = bob.getAddress()
|
|
|
|
|
|
|
|
blockchain.t.faucet(alicesAddress, 2e4, function (err, unspentA) {
|
|
|
|
if (err) return done(err)
|
|
|
|
|
|
|
|
blockchain.t.faucet(bobsAddress, 2e4, function (err, unspentB) {
|
|
|
|
if (err) return done(err)
|
|
|
|
|
|
|
|
var tx = new bitcoin.TransactionBuilder(network)
|
|
|
|
tx.addInput(unspentA.txId, unspentA.vout)
|
|
|
|
tx.addInput(unspentB.txId, unspentB.vout)
|
|
|
|
tx.addOutput('mrCDrCybB6J1vRfbwM5hemdJz73FwDBC8r', 1e4)
|
|
|
|
tx.addOutput('2NByiBUaEXrhmqAsg7BbLpcQSAQs1EDwt5w', 1e4)
|
|
|
|
tx.sign(0, alice)
|
|
|
|
tx.sign(1, bob)
|
|
|
|
|
|
|
|
blockchain.t.transactions.propagate(tx.build().toHex(), done)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
2014-10-19 01:10:20 +11:00
|
|
|
})
|