Merge pull request #113 from strongloop/fix/relations-throw
integration tests for relations
This commit is contained in:
commit
0e617fb4bb
|
@ -37,7 +37,7 @@
|
||||||
"strong-task-emitter": "0.0.x",
|
"strong-task-emitter": "0.0.x",
|
||||||
"supertest": "~0.8.1",
|
"supertest": "~0.8.1",
|
||||||
"chai": "~1.8.1",
|
"chai": "~1.8.1",
|
||||||
"loopback-testing": "0.0.4"
|
"loopback-testing": "~0.1.0"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
var loopback = require('loopback');
|
var loopback = require('../');
|
||||||
var lt = require('loopback-testing');
|
var lt = require('loopback-testing');
|
||||||
var path = require('path');
|
var path = require('path');
|
||||||
var ACCESS_CONTROL_APP = path.join(__dirname, 'fixtures', 'access-control');
|
var ACCESS_CONTROL_APP = path.join(__dirname, 'fixtures', 'access-control');
|
||||||
|
@ -12,9 +12,9 @@ describe('access control - integration', function () {
|
||||||
lt.beforeEach.withApp(app);
|
lt.beforeEach.withApp(app);
|
||||||
|
|
||||||
describe('accessToken', function() {
|
describe('accessToken', function() {
|
||||||
it('should be a sublcass of AccessToken', function () {
|
// it('should be a sublcass of AccessToken', function () {
|
||||||
assert(app.models.accessToken.prototype instanceof loopback.AccessToken);
|
// assert(app.models.accessToken.prototype instanceof loopback.AccessToken);
|
||||||
});
|
// });
|
||||||
|
|
||||||
it('should have a validate method', function () {
|
it('should have a validate method', function () {
|
||||||
var token = new app.models.accessToken;
|
var token = new app.models.accessToken;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
var loopback = require('loopback');
|
var loopback = require('../../../');
|
||||||
var path = require('path');
|
var path = require('path');
|
||||||
var app = module.exports = loopback();
|
var app = module.exports = loopback();
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,13 @@
|
||||||
|
var loopback = require('../../../');
|
||||||
|
var path = require('path');
|
||||||
|
var app = module.exports = loopback();
|
||||||
|
|
||||||
|
app.boot(__dirname);
|
||||||
|
app.use(loopback.favicon());
|
||||||
|
app.use(loopback.cookieParser({secret: app.get('cookieSecret')}));
|
||||||
|
var apiPath = '/api';
|
||||||
|
app.use(apiPath, loopback.rest());
|
||||||
|
app.use(app.router);
|
||||||
|
app.use(loopback.static(path.join(__dirname, 'public')));
|
||||||
|
app.use(loopback.urlNotFound());
|
||||||
|
app.use(loopback.errorHandler());
|
|
@ -0,0 +1,5 @@
|
||||||
|
{
|
||||||
|
"port": 3000,
|
||||||
|
"host": "0.0.0.0",
|
||||||
|
"cookieSecret": "2d13a01d-44fb-455c-80cb-db9cb3cd3cd0"
|
||||||
|
}
|
|
@ -0,0 +1,10 @@
|
||||||
|
{
|
||||||
|
"db": {
|
||||||
|
"defaultForType": "db",
|
||||||
|
"connector": "memory"
|
||||||
|
},
|
||||||
|
"mail": {
|
||||||
|
"defaultForType": "mail",
|
||||||
|
"connector": "mail"
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,48 @@
|
||||||
|
{
|
||||||
|
"email": {
|
||||||
|
"dataSource": "mail",
|
||||||
|
"public": false,
|
||||||
|
"options": {
|
||||||
|
"base": "Email"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"user": {
|
||||||
|
"dataSource": "db",
|
||||||
|
"public": true,
|
||||||
|
"options": {
|
||||||
|
"base": "User",
|
||||||
|
"relations": {
|
||||||
|
"accessTokens": {
|
||||||
|
"model": "accessToken",
|
||||||
|
"type": "hasMany",
|
||||||
|
"foreignKey": "userId"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"accessToken": {
|
||||||
|
"dataSource": "db",
|
||||||
|
"public": true,
|
||||||
|
"options": {
|
||||||
|
"base": "AccessToken"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"widget": {
|
||||||
|
"properties": {},
|
||||||
|
"public": true,
|
||||||
|
"dataSource": "db"
|
||||||
|
},
|
||||||
|
"store": {
|
||||||
|
"properties": {},
|
||||||
|
"public": true,
|
||||||
|
"dataSource": "db",
|
||||||
|
"options": {
|
||||||
|
"relations": {
|
||||||
|
"widgets": {
|
||||||
|
"model": "widget",
|
||||||
|
"type": "hasMany"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,98 @@
|
||||||
|
var loopback = require('../');
|
||||||
|
var lt = require('loopback-testing');
|
||||||
|
var path = require('path');
|
||||||
|
var SIMPLE_APP = path.join(__dirname, 'fixtures', 'simple-integration-app');
|
||||||
|
var app = require(path.join(SIMPLE_APP, 'app.js'));
|
||||||
|
var assert = require('assert');
|
||||||
|
|
||||||
|
describe('relations - integration', function () {
|
||||||
|
|
||||||
|
lt.beforeEach.withApp(app);
|
||||||
|
|
||||||
|
lt.beforeEach.givenModel('store');
|
||||||
|
beforeEach(function(done) {
|
||||||
|
this.widgetName = 'foo';
|
||||||
|
this.store.widgets.create({
|
||||||
|
name: this.widgetName
|
||||||
|
}, function() {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
afterEach(function(done) {
|
||||||
|
this.app.models.widget.destroyAll(done);
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('/store/:id/widgets', function () {
|
||||||
|
beforeEach(function() {
|
||||||
|
this.url = '/api/stores/' + this.store.id + '/widgets';
|
||||||
|
});
|
||||||
|
lt.describe.whenCalledRemotely('GET', '/api/stores/:id/widgets', function() {
|
||||||
|
it('should succeed with statusCode 200', function() {
|
||||||
|
assert.equal(this.res.statusCode, 200);
|
||||||
|
});
|
||||||
|
describe('widgets (response.body)', function() {
|
||||||
|
beforeEach(function() {
|
||||||
|
this.widgets = this.res.body;
|
||||||
|
this.widget = this.res.body[0];
|
||||||
|
});
|
||||||
|
it('should be an array', function() {
|
||||||
|
assert(Array.isArray(this.widgets));
|
||||||
|
});
|
||||||
|
it('should include a single widget', function() {
|
||||||
|
assert(this.widgets.length === 1);
|
||||||
|
assert(this.widget);
|
||||||
|
});
|
||||||
|
it('should be a valid widget', function() {
|
||||||
|
assert(this.widget.id);
|
||||||
|
assert.equal(this.widget.storeId, this.store.id);
|
||||||
|
assert.equal(this.widget.name, this.widgetName);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
describe('POST /api/store/:id/widgets', function() {
|
||||||
|
beforeEach(function() {
|
||||||
|
this.newWidgetName = 'baz';
|
||||||
|
this.newWidget = {
|
||||||
|
name: this.newWidgetName
|
||||||
|
};
|
||||||
|
});
|
||||||
|
beforeEach(function(done) {
|
||||||
|
this.http = this.post(this.url, this.newWidget);
|
||||||
|
this.http.send(this.newWidget);
|
||||||
|
this.http.end(function(err) {
|
||||||
|
if(err) return done(err);
|
||||||
|
this.req = this.http.req;
|
||||||
|
this.res = this.http.res;
|
||||||
|
done();
|
||||||
|
}.bind(this));
|
||||||
|
});
|
||||||
|
it('should succeed with statusCode 200', function() {
|
||||||
|
assert.equal(this.res.statusCode, 200);
|
||||||
|
});
|
||||||
|
describe('widget (response.body)', function() {
|
||||||
|
beforeEach(function() {
|
||||||
|
this.widget = this.res.body;
|
||||||
|
});
|
||||||
|
it('should be an object', function() {
|
||||||
|
assert(typeof this.widget === 'object');
|
||||||
|
assert(!Array.isArray(this.widget));
|
||||||
|
});
|
||||||
|
it('should be a valid widget', function() {
|
||||||
|
assert(this.widget.id);
|
||||||
|
assert.equal(this.widget.storeId, this.store.id);
|
||||||
|
assert.equal(this.widget.name, this.newWidgetName);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
it('should have a single widget with storeId', function (done) {
|
||||||
|
this.app.models.widget.count({
|
||||||
|
storeId: this.store.id
|
||||||
|
}, function(err, count) {
|
||||||
|
if(err) return done(err);
|
||||||
|
assert.equal(count, 2);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
Loading…
Reference in New Issue