var StealthAddress = require('../lib/expmt/stealthaddress'); var should = require('chai').should(); var Stealthkey = require('../lib/expmt/stealthkey'); var Keypair = require('../lib/keypair'); var Privkey = require('../lib/privkey'); var Pubkey = require('../lib/pubkey'); var BN = require('../lib/bn'); var Hash = require('../lib/hash'); var Base58check = require('../lib/base58check'); describe('StealthAddress', function() { var stealthkey = Stealthkey(); stealthkey.payloadKeypair = Keypair(); stealthkey.payloadKeypair.privkey = Privkey(); stealthkey.payloadKeypair.privkey.bn = BN().fromBuffer(Hash.sha256(new Buffer('test 1'))); stealthkey.payloadKeypair.privkey2pubkey(); stealthkey.scanKeypair = Keypair(); stealthkey.scanKeypair.privkey = Privkey(); stealthkey.scanKeypair.privkey.bn = BN().fromBuffer(Hash.sha256(new Buffer('test 2'))); stealthkey.scanKeypair.privkey2pubkey(); var senderKeypair = Keypair(); senderKeypair.privkey = Privkey(); senderKeypair.privkey.bn = BN().fromBuffer(Hash.sha256(new Buffer('test 3'))); senderKeypair.privkey2pubkey(); var addressString = '9dDbC9FzZ74r8njQkXD6W27gtrxLiWaeFPHxeo1fynQRXPicqxVt7u95ozbwoVVMXyrzaHKN9owsteg63FgwDfrxWx82SAW'; it('should make a new stealth address', function() { var sa = new StealthAddress(); should.exist(sa); sa = StealthAddress(); should.exist(sa); sa = StealthAddress(addressString); should.exist(sa); sa = StealthAddress(Base58check.decode(addressString)); should.exist(sa); }); describe('#fromJSON', function() { it('should give a stealthkey address with the right pubkeys', function() { var sa = new StealthAddress(); sa.fromJSON(addressString); sa.payloadPubkey.toString().should.equal(stealthkey.payloadKeypair.pubkey.toString()); sa.scanPubkey.toString().should.equal(stealthkey.scanKeypair.pubkey.toString()); }); }); describe('#toJSON', function() { it('should return this known address string', function() { StealthAddress().fromJSON(addressString).toJSON().should.equal(addressString); }); }); describe('#fromBuffer', function() { it('should give a stealthkey address with the right pubkeys', function() { var sa = new StealthAddress(); var buf = Base58check.decode(addressString); sa.fromBuffer(buf); sa.payloadPubkey.toString().should.equal(stealthkey.payloadKeypair.pubkey.toString()); sa.scanPubkey.toString().should.equal(stealthkey.scanKeypair.pubkey.toString()); }); }); describe('#fromString', function() { it('should give a stealthkey address with the right pubkeys', function() { var sa = new StealthAddress(); sa.fromString(addressString); sa.payloadPubkey.toString().should.equal(stealthkey.payloadKeypair.pubkey.toString()); sa.scanPubkey.toString().should.equal(stealthkey.scanKeypair.pubkey.toString()); }); }); describe('#getSharedKeypair', function() { it('should return a key', function() { var sa = new StealthAddress(); sa.payloadPubkey = stealthkey.payloadKeypair.pubkey; sa.scanPubkey = stealthkey.scanKeypair.pubkey; var key = sa.getSharedKeypair(senderKeypair); (key instanceof Keypair).should.equal(true); }); it('should return the same key as Stealthkey.prototype.getSharedKeypair', function() { var sa = new StealthAddress(); sa.payloadPubkey = stealthkey.payloadKeypair.pubkey; sa.scanPubkey = stealthkey.scanKeypair.pubkey; var key = sa.getSharedKeypair(senderKeypair); var key2 = stealthkey.getSharedKeypair(senderKeypair.pubkey); key.toString().should.equal(key2.toString()); }); }); describe('#getReceivePubkey', function() { it('should return a pubkey', function() { var pubkey = StealthAddress().fromStealthkey(stealthkey).getReceivePubkey(senderKeypair); (pubkey instanceof Pubkey).should.equal(true); }); it('should return the same pubkey as getReceivePubkey', function() { var pubkey = StealthAddress().fromStealthkey(stealthkey).getReceivePubkey(senderKeypair); var pubkey2 = stealthkey.getReceivePubkey(senderKeypair.pubkey); pubkey2.toString().should.equal(pubkey.toString()); }); }); describe('#toBuffer', function() { it('should return this known address buffer', function() { var buf = Base58check.decode(addressString); StealthAddress().fromBuffer(buf).toBuffer().toString('hex').should.equal(buf.toString('hex')); }); }); describe('#toString', function() { it('should return this known address string', function() { StealthAddress().fromString(addressString).toString().should.equal(addressString); }); }); });