Browse Source

Fixed bugs in IE11

patch-2
Braydon Fuller 10 years ago
parent
commit
ff4a6f549d
  1. 6
      lib/address.js
  2. 5
      lib/script/script.js
  3. 2
      test/hdkeycache.js
  4. 1
      test/mocha.opts
  5. 2
      test/paymentprotocol/index.js
  6. 1
      test/transaction/transaction.js
  7. 3
      test/util/preconditions.js

6
lib/address.js

@ -100,15 +100,17 @@ function Address(data, network, type) {
* @returns {Object} An "info" object with "type", "network", and "hashBuffer" * @returns {Object} An "info" object with "type", "network", and "hashBuffer"
*/ */
Address.prototype._classifyArguments = function(data, network, type) { Address.prototype._classifyArguments = function(data, network, type) {
var PublicKey = require('./publickey');
var Script = require('./script');
/* jshint maxcomplexity: 10 */ /* jshint maxcomplexity: 10 */
// transform and validate input data // transform and validate input data
if ((data instanceof Buffer || data instanceof Uint8Array) && data.length === 20) { if ((data instanceof Buffer || data instanceof Uint8Array) && data.length === 20) {
return Address._transformHash(data); return Address._transformHash(data);
} else if ((data instanceof Buffer || data instanceof Uint8Array) && data.length === 21) { } else if ((data instanceof Buffer || data instanceof Uint8Array) && data.length === 21) {
return Address._transformBuffer(data, network, type); return Address._transformBuffer(data, network, type);
} else if (data.constructor && (data.constructor.name && data.constructor.name === 'PublicKey')) { } else if (data instanceof PublicKey) {
return Address._transformPublicKey(data); return Address._transformPublicKey(data);
} else if (data.constructor && (data.constructor.name && data.constructor.name === 'Script')) { } else if (data instanceof Script) {
return Address._transformScript(data, network); return Address._transformScript(data, network);
} else if (typeof(data) === 'string') { } else if (typeof(data) === 'string') {
return Address._transformString(data, network, type); return Address._transformString(data, network, type);

5
lib/script/script.js

@ -177,7 +177,6 @@ Script.fromString = function(str) {
Script.prototype.toString = function() { Script.prototype.toString = function() {
var str = ''; var str = '';
for (var i = 0; i < this.chunks.length; i++) { for (var i = 0; i < this.chunks.length; i++) {
var chunk = this.chunks[i]; var chunk = this.chunks[i];
var opcodenum = chunk.opcodenum; var opcodenum = chunk.opcodenum;
@ -459,7 +458,7 @@ Script.prototype._addByType = function(obj, prepend) {
this._addOpcode(obj, prepend); this._addOpcode(obj, prepend);
} else if (typeof obj === 'number') { } else if (typeof obj === 'number') {
this._addOpcode(obj, prepend); this._addOpcode(obj, prepend);
} else if (obj.constructor && obj.constructor.name && obj.constructor.name === 'Opcode') { } else if (obj instanceof Opcode) {
this._addOpcode(obj, prepend); this._addOpcode(obj, prepend);
} else if (BufferUtil.isBuffer(obj)) { } else if (BufferUtil.isBuffer(obj)) {
this._addBuffer(obj, prepend); this._addBuffer(obj, prepend);
@ -484,7 +483,7 @@ Script.prototype._addOpcode = function(opcode, prepend) {
var op; var op;
if (typeof opcode === 'number') { if (typeof opcode === 'number') {
op = opcode; op = opcode;
} else if (opcode.constructor && opcode.constructor.name && opcode.constructor.name === 'Opcode') { } else if (opcode instanceof Opcode) {
op = opcode.toNumber(); op = opcode.toNumber();
} else { } else {
op = Opcode(opcode).toNumber(); op = Opcode(opcode).toNumber();

2
test/hdkeycache.js

@ -8,6 +8,8 @@ var HDPrivateKey = bitcore.HDPrivateKey;
var xprivkey = 'xprv9s21ZrQH143K3QTDL4LXw2F7HEK3wJUD2nW2nRk4stbPy6cq3jPPqjiChkVvvNKmPGJxWUtg6LnF5kejMRNNU3TGtRBeJgk33yuGBxrMPHi'; var xprivkey = 'xprv9s21ZrQH143K3QTDL4LXw2F7HEK3wJUD2nW2nRk4stbPy6cq3jPPqjiChkVvvNKmPGJxWUtg6LnF5kejMRNNU3TGtRBeJgk33yuGBxrMPHi';
describe('HDKey cache', function() { describe('HDKey cache', function() {
this.timeout(10000);
/* jshint unused: false */ /* jshint unused: false */
var cache = bitcore._HDKeyCache; var cache = bitcore._HDKeyCache;
var master = new HDPrivateKey(xprivkey); var master = new HDPrivateKey(xprivkey);

1
test/mocha.opts

@ -1 +1,2 @@
--recursive --recursive
--timeout 5000

2
test/paymentprotocol/index.js

@ -279,6 +279,8 @@ var bitpayRequest = new Buffer(''
describe('PaymentProtocol', function() { describe('PaymentProtocol', function() {
this.timeout(15000);
it('should be able to create class', function() { it('should be able to create class', function() {
should.exist(PaymentProtocol); should.exist(PaymentProtocol);
}); });

1
test/transaction/transaction.js

@ -84,6 +84,7 @@ describe('Transaction', function() {
}); });
describe('transaction creation test vector', function() { describe('transaction creation test vector', function() {
this.timeout(5000);
var index = 0; var index = 0;
transactionVector.forEach(function(vector) { transactionVector.forEach(function(vector) {
index++; index++;

3
test/util/preconditions.js

@ -52,7 +52,8 @@ describe('preconditions', function() {
$.checkArgumentType(1, PrivateKey); $.checkArgumentType(1, PrivateKey);
} catch (e) { } catch (e) {
error = e; error = e;
e.message.should.equal('Invalid Argument for (unknown name), expected PrivateKey but got number'); var fail = !(~e.message.indexOf('Invalid Argument for (unknown name)'));
fail.should.equal(false);
} }
should.exist(error); should.exist(error);
}); });

Loading…
Cancel
Save