Merge pull request #51 from maraoz/feature/browserify-Address

browserify Address and dependencies
This commit is contained in:
Ryan X. Charles 2014-02-07 19:40:58 -05:00
commit f066d3e0ce
13 changed files with 140 additions and 14 deletions

1
.gitignore vendored
View File

@ -1,5 +1,6 @@
build/ build/
browser/bundle.js browser/bundle.js
browser/vendor.js
node_modules/ node_modules/
*.swp *.swp
*~ *~

View File

@ -5,7 +5,7 @@ function ClassSpec(b) {
function Address() { function Address() {
Address.super(this, arguments); Address.super(this, arguments);
}; }
Address.superclass = superclass; Address.superclass = superclass;
superclass.applyEncodingsTo(Address); superclass.applyEncodingsTo(Address);
@ -13,10 +13,10 @@ function ClassSpec(b) {
Address.prototype.validate = function() { Address.prototype.validate = function() {
this.doAsBinary(function() { this.doAsBinary(function() {
Address.super(this, 'validate', arguments); Address.super(this, 'validate', arguments);
if(this.data.length != 21) throw new Error('invalid data length'); if(this.data.length !== 21) throw new Error('invalid data length');
}); });
}; };
return Address; return Address;
}; }
module.defineClass(ClassSpec); module.defineClass(ClassSpec);

View File

@ -14,14 +14,22 @@ module.exports = function(grunt) {
src: ['bitcore.js'], src: ['bitcore.js'],
dest: 'browser/bundle.js', dest: 'browser/bundle.js',
options: { options: {
debug: true,
alias: ['browserify-bignum/bignumber.js:bignum'], alias: ['browserify-bignum/bignumber.js:bignum'],
standalone: 'bitcore' standalone: 'bitcore',
}
},
vendor: {
src: ['browser/vendor_load.js'],
dest: 'browser/vendor.js',
options: {
} }
} }
}, },
watch: { watch: {
scripts: { scripts: {
files: ['**/*.js', '**/*.html', '!**/node_modules/**', '!**/bundle.js'], files: ['**/*.js', '**/*.html', '!**/node_modules/**', '!**/bundle.js', '!**/vendor.js'],
tasks: ['browserify'/*, 'mochaTest'*/], tasks: ['browserify'/*, 'mochaTest'*/],
}, },
}, },

View File

@ -54,6 +54,5 @@ npm install
npm install -g grunt-cli npm install -g grunt-cli
grunt browserify grunt browserify
[![Bitdeli Badge](https://d2weczhvl823v0.cloudfront.net/bitpay/bitcore/trend.png)](https://bitdeli.com/free "Bitdeli Badge") [![Bitdeli Badge](https://d2weczhvl823v0.cloudfront.net/bitpay/bitcore/trend.png)](https://bitdeli.com/free "Bitdeli Badge")

View File

@ -5,8 +5,9 @@
module.exports.bignum = require('bignum'); module.exports.bignum = require('bignum');
module.exports.base58 = require('base58-native'); module.exports.base58 = require('base58-native');
//module.exports.Address = require('./Address'); module.exports.EncodedData = require('./util/EncodedData');
module.exports.VersionedData = require('./util/VersionedData');
module.exports.Address= require('./Address');
if (typeof process.versions === 'undefined') { if (typeof process.versions === 'undefined') {

5
browser/vendor_load.js Normal file
View File

@ -0,0 +1,5 @@
// load modules needed for testing in the browser
var fs = require('fs');

View File

@ -15,3 +15,9 @@ if (typeof require === 'undefined') {
}; };
} }
if (typeof module === 'undefined') {
var that = this;
that.module = bitcore.module;
}

View File

@ -8,14 +8,18 @@
</head> </head>
<body> <body>
<div id="mocha"></div> <div id="mocha"></div>
<script src="adapter.js"></script> <script src="../browser/vendor.js"></script>
<script src="../node_modules/mocha/mocha.js"></script> <script src="../node_modules/mocha/mocha.js"></script>
<script src="../node_modules/chai/chai.js"></script> <script src="../node_modules/chai/chai.js"></script>
<script>mocha.setup('bdd')</script> <script>mocha.setup('bdd')</script>
<script src="../browser/bundle.js"></script> <script src="../browser/bundle.js"></script>
<script src="adapter.js"></script>
<script src="test.main.js"></script> <script src="test.main.js"></script>
<script src="test.base58.js"></script> <script src="test.base58.js"></script>
<script src="test.EncodedData.js"></script>
<script src="test.VersionedData.js"></script>
<script src="test.Address.js"></script>
<script> <script>
mocha.run(); mocha.run();
</script> </script>

36
test/test.Address.js Normal file
View File

@ -0,0 +1,36 @@
'use strict';
var chai = require('chai');
var bitcore = require('../bitcore');
var should = chai.should();
var AddressModule = bitcore.Address;
var Address;
describe('Address', function() {
it('should initialze the main object', function() {
should.exist(AddressModule);
});
it('should be able to create class', function() {
Address = AddressModule.class();
should.exist(Address);
});
it('should be able to create Address object', function() {
var a = new Address('1KfyjCgBSMsLqiCbakfSdeoBUqMqLUiu3T');
should.exist(a);
});
it('should validate correctly', function() {
var a = new Address("1A1zP1eP5QGefi2DMPTfTL5SLmv7DivfNa");
var m = new Address("32QBdjycLwbDTuGafUwaU5p5GxzSLPYoF6");
var b = new Address("11111111111111111111111111122222234");
a.validate.bind(a).should.not.throw(Error);
m.validate.bind(m).should.not.throw(Error);
b.validate.bind(b).should.throw(Error);
});
});

28
test/test.EncodedData.js Normal file
View File

@ -0,0 +1,28 @@
'use strict';
var chai = require('chai');
var bitcore = require('../bitcore');
var should = chai.should();
var EncodedDataModule = bitcore.EncodedData;
var EncodedData;
describe('EncodedData', function() {
it('should initialze the main object', function() {
should.exist(EncodedDataModule);
});
it('should be able to create class', function() {
EncodedData = EncodedDataModule.class();
should.exist(EncodedData);
});
it('should be able to create an instance', function() {
var ed = new EncodedData('1GMx4HdDmN78xzGvdQYkwrVqkmLDG1aMNT');
should.exist(ed);
});
});

View File

@ -0,0 +1,34 @@
'use strict';
var chai = require('chai');
var bitcore = require('../bitcore');
var should = chai.should();
var VersionedDataModule = bitcore.VersionedData;
var VersionedData;
describe('VersionedData', function() {
it('should initialze the main object', function() {
should.exist(VersionedDataModule);
});
it('should be able to create class', function() {
VersionedData = VersionedDataModule.class();
should.exist(VersionedData);
});
it('should be able to create an instance', function() {
var vd = new VersionedData();
should.exist(vd);
});
it('should get correct version', function() {
var vda = new VersionedData('1GMx4HdDmN78xzGvdQYkwrVqkmLDG1aMNT');
var vdb = new VersionedData('3746djr32k2Lp23UUbdkCTQ6zhMJ7d8MD7');
vda.version().should.equal(0);
vdb.version().should.equal(5);
});
});

View File

@ -1,3 +1,4 @@
'use strict';
var assert = require('assert'); var assert = require('assert');
var fs = require('fs'); var fs = require('fs');

View File

@ -130,17 +130,20 @@ function ClassSpec(b) {
}, },
}; };
var no_conversion = function() {return this.data;};
for(var k in encodings) { for(var k in encodings) {
if(!encodings[k].converters[k]) if(encodings.hasOwnProperty(k)){
encodings[k].converters[k] = function() {return this.data;}; if(!encodings[k].converters[k])
encodings[k]._encoding = k; encodings[k].converters[k] = no_conversion;
encodings[k]._encoding = k;
}
} }
EncodedData.applyEncodingsTo = function(aClass) { EncodedData.applyEncodingsTo = function(aClass) {
var tmp = {}; var tmp = {};
for(var k in encodings) { for(var k in encodings) {
var enc = encodings[k]; var enc = encodings[k];
var obj = {}; var obj = {};
for(var j in enc) { for(var j in enc) {
obj[j] = enc[j]; obj[j] = enc[j];
} }
@ -152,5 +155,5 @@ function ClassSpec(b) {
EncodedData.applyEncodingsTo(EncodedData); EncodedData.applyEncodingsTo(EncodedData);
return EncodedData; return EncodedData;
}; }
module.defineClass(ClassSpec); module.defineClass(ClassSpec);