Browse Source

api tests working

activeAddress
Matias Alejo Garcia 10 years ago
parent
commit
dc446c5f2b
  1. 6
      lib/client/api.js
  2. 5
      lib/expressapp.js
  3. 131
      test/integration/clientApi.js
  4. 1
      test/integration/server.js

6
lib/client/api.js

@ -60,8 +60,11 @@ function API(opts) {
this.verbose = !!opts.verbose; this.verbose = !!opts.verbose;
this.request = request || opts.request; this.request = request || opts.request;
this.baseUrl = opts.baseUrl || BASE_URL; this.baseUrl = opts.baseUrl || BASE_URL;
this.basePath = this.baseUrl.replace(/http.?:\/\/[a-zA-Z0-9:-]*\//,'/');
if (this.verbose) { if (this.verbose) {
log.level = 'debug'; log.level = 'debug';
} else {
log.level = 'info';
} }
}; };
@ -127,7 +130,8 @@ API.prototype._doRequest = function(method, url, args, data, cb) {
var absUrl = this.baseUrl + url; var absUrl = this.baseUrl + url;
var args = { var args = {
relUrl: url, // relUrl: only for testing with `supertest`
relUrl: this.basePath + url,
headers: { headers: {
'x-identity': data.copayerId, 'x-identity': data.copayerId,
'x-signature': reqSignature, 'x-signature': reqSignature,

5
lib/expressapp.js

@ -83,6 +83,11 @@ ExpressApp.start = function(opts) {
function getServerWithAuth(req, res, cb) { function getServerWithAuth(req, res, cb) {
var credentials = getCredentials(req); var credentials = getCredentials(req);
if (!credentials)
return returnError(new CopayServer.ClientError({
code: 'NOTAUTHORIZED'
}), res, req);
var auth = { var auth = {
copayerId: credentials.copayerId, copayerId: credentials.copayerId,
message: req.method.toLowerCase() + '|' + req.url + '|' + JSON.stringify(req.body), message: req.method.toLowerCase() + '|' + req.url + '|' + JSON.stringify(req.body),

131
test/integration/clientApi.js

@ -6,6 +6,7 @@ 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 async = require('async');
var request = require('supertest'); var request = require('supertest');
var Client = require('../../lib/client'); var Client = require('../../lib/client');
var API = Client.API; var API = Client.API;
@ -15,66 +16,124 @@ var WalletUtils = require('../../lib/walletutils');
var ExpressApp = require('../../lib/expressapp'); var ExpressApp = require('../../lib/expressapp');
var Storage = require('../../lib/storage'); var Storage = require('../../lib/storage');
var helpers = {};
helpers.getRequest = function(app) {
return function(args, cb) {
var req = request(app);
var r = req[args.method](args.relUrl);
if (args.headers) {
_.each(args.headers, function(v, k) {
r.set(k, v);
})
}
if (!_.isEmpty(args.body)) {
r.send(args.body);
};
r.end(function(err, res) {
return cb(err, res, res.body);
});
};
};
helpers.createAndJoinWallet = function(clients, m, n, cb) {
clients[0].createWallet('wallet name', 'creator copayer', m, n, 'testnet',
function(err, secret) {
if (err) return cb(err);
if (n == 1) return cb();
should.exist(secret);
async.each(_.range(n-1), function(i, cb) {
clients[i + 1].joinWallet(secret, 'copayer ' + (i + 1), function(err, result) {
should.not.exist(err);
return cb(err);
});
}, function(err) {
if (err) return new Error('Could not generate wallet');
return cb();
});
});
};
var fsmock = {};
var content = {};
fsmock.readFile = function(name, enc, cb) {
if (!content || _.isEmpty(content[name]))
return cb('empty');
return cb(null, content[name]);
};
fsmock.writeFile = function(name, data, cb) {
content[name] = data;
return cb();
};
describe('client API ', function() { describe('client API ', function() {
var client, app; var clients;
beforeEach(function() { beforeEach(function() {
var fsmock = {};; clients = [];
fsmock.readFile = sinon.mock().yields(null, JSON.stringify(TestData.storage.wallet11)); // Generates 5 clients
fsmock.writeFile = sinon.mock().yields(); _.each(_.range(5), function(i) {
var storage = new Client.FileStorage({ var storage = new Client.FileStorage({
filename: 'dummy', filename: 'client' + i,
fs: fsmock, fs: fsmock,
}); });
client = new Client({ var client = new Client({
storage: storage storage: storage,
}); });
var db = levelup(memdown, { var db = levelup(memdown, {
valueEncoding: 'json' valueEncoding: 'json'
}); });
var storage = new Storage({ var storage = new Storage({
db: db db: db
}); });
app = ExpressApp.start({ var app = ExpressApp.start({
CopayServer: { CopayServer: {
storage: storage storage: storage
} }
}); });
client.request = helpers.getRequest(app);
clients.push(client);
});
content={};
}); });
var helpers = {}; describe.only('#getBalance', function() {
it('should check balance in a 1-1 ', function(done) {
helpers.request = function(args) { helpers.createAndJoinWallet(clients, 1, 1, function(err) {
if (args.method == 'get') { should.not.exist(err);
request(app) clients[0].getBalance(function(err, x) {
.get(relUrl) should.not.exist(err);
.end(cb); done();
} else { })
request(app) });
.post(relUrl) });
.send(body) it('should be able to check balance in a 2-3 wallet ', function(done) {
.end(function(err, res) { helpers.createAndJoinWallet(clients, 2, 3, function(err) {
console.log('[clientApi.js.59:err:]', err, res); //TODO should.not.exist(err);
return cb(err, res); clients[0].getBalance(function(err, x) {
should.not.exist(err);
clients[1].getBalance(function(err, x) {
should.not.exist(err);
clients[2].getBalance(function(err, x) {
should.not.exist(err);
done();
})
})
})
});
});
}); });
}
};
describe('#_tryToComplete ', function() { describe('#_tryToComplete ', function() {
it.only('should complete a wallet ', function(done) { it('should complete a wallet ', function(done) {
var request = sinon.stub(); client.storage.fs.readFile =
sinon.stub().yields(null, JSON.stringify(TestData.storage.incompleteWallet22));
// Wallet request
request.onCall(0).yields(null, {
statusCode: 200,
}, TestData.serverResponse.completeWallet);
request.onCall(1).yields(null, {
statusCode: 200,
}, "pepe");
client.request = request;
client.storage.fs.readFile = sinon.stub().yields(null, JSON.stringify(TestData.storage.incompleteWallet22));
client.getBalance(function(err, x) { client.getBalance(function(err, x) {
should.not.exist(err); should.not.exist(err);
done(); done();

1
test/integration/server.js

@ -20,7 +20,6 @@ var Copayer = require('../../lib/model/copayer');
var CopayServer = require('../../lib/server'); var CopayServer = require('../../lib/server');
var TestData = require('../testdata'); var TestData = require('../testdata');
var helpers = {}; var helpers = {};
helpers.getAuthServer = function(copayerId, cb) { helpers.getAuthServer = function(copayerId, cb) {
var signatureStub = sinon.stub(CopayServer.prototype, '_verifySignature'); var signatureStub = sinon.stub(CopayServer.prototype, '_verifySignature');

Loading…
Cancel
Save