123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196 |
- var assert = require('assert');
- var util = require('util');
- var _ = require('@sailshq/lodash');
- var Waterline = require('../../../lib/waterline');
- describe('Collection Query ::', function() {
- describe('.findOne()', function() {
- describe('with autoPK', function() {
- var query;
- before(function(done) {
- var waterline = new Waterline();
- var Model = Waterline.Model.extend({
- identity: 'user',
- datastore: 'foo',
- primaryKey: 'id',
- attributes: {
- id: {
- type: 'number'
- },
- name: {
- type: 'string',
- defaultsTo: 'Foo Bar'
- }
- }
- });
- waterline.registerModel(Model);
- // Fixture Adapter Def
- var adapterDef = { find: function(con, query, cb) { return cb(null, [{id: 1, criteria: query.criteria}]); }};
- var connections = {
- 'foo': {
- adapter: 'foobar'
- }
- };
- waterline.initialize({ adapters: { foobar: adapterDef }, datastores: connections }, function(err, orm) {
- if (err) {
- return done(err);
- }
- query = orm.collections.user;
- return done();
- });
- });
- it('should allow an integer to be passed in as criteria', function(done) {
- query.findOne(1, function(err, record) {
- if (err) {
- return done(err);
- }
- assert(_.isObject(record.criteria.where), 'Expected `record.where` to be a dictionary, but it is not. Here is `record`:\n```\n'+util.inspect(record,{depth:5})+'\n```\n');
- assert.equal(record.criteria.where.id, 1);
- return done();
- });
- });
- it('should allow a query to be built using deferreds', function(done) {
- query.findOne()
- .where({
- name: 'Foo Bar',
- id: {
- '>': 1
- }
- })
- .exec(function(err, results) {
- if (err) {
- return done(err);
- }
- assert(!_.isArray(results));
- assert.equal(_.keys(results.criteria.where).length, 1);
- assert.equal(results.criteria.where.and[0].name, 'Foo Bar');
- assert.equal(results.criteria.where.and[1].id['>'], 1);
- return done();
- });
- });
- });
- describe('with custom PK', function() {
- describe('with no columnName set', function() {
- var query;
- before(function(done) {
- var waterline = new Waterline();
- // Extend for testing purposes
- var Model = Waterline.Model.extend({
- identity: 'user',
- datastore: 'foo',
- primaryKey: 'myPk',
- attributes: {
- name: {
- type: 'string',
- defaultsTo: 'Foo Bar'
- },
- myPk: {
- type: 'number'
- }
- }
- });
- waterline.registerModel(Model);
- // Fixture Adapter Def
- var adapterDef = { find: function(con, query, cb) { return cb(null, [{myPk: 1, criteria: query.criteria}]); }};
- var connections = {
- 'foo': {
- adapter: 'foobar'
- }
- };
- waterline.initialize({ adapters: { foobar: adapterDef }, datastores: connections }, function(err, orm) {
- if (err) {
- return done(err);
- }
- query = orm.collections.user;
- return done();
- });
- });
- it('should use the custom primary key when a single value is passed in', function(done) {
- query.findOne(1, function(err, values) {
- if (err) {
- return done(err);
- }
- assert.equal(values.criteria.where.myPk, 1);
- return done();
- });
- });
- });
- describe('with custom columnName set', function() {
- var query;
- before(function(done) {
- var waterline = new Waterline();
- // Extend for testing purposes
- var Model = Waterline.Model.extend({
- identity: 'user',
- datastore: 'foo',
- primaryKey: 'myPk',
- attributes: {
- name: {
- type: 'string',
- defaultsTo: 'Foo Bar'
- },
- myPk: {
- type: 'number',
- columnName: 'pkColumn'
- }
- }
- });
- waterline.registerModel(Model);
- // Fixture Adapter Def
- var adapterDef = { find: function(con, query, cb) { return cb(null, [{myPk: 1, criteria: query.criteria}]); }};
- var connections = {
- 'foo': {
- adapter: 'foobar'
- }
- };
- waterline.initialize({ adapters: { foobar: adapterDef }, datastores: connections }, function(err, orm) {
- if (err) {
- return done(err);
- }
- query = orm.collections.user;
- return done();
- });
- });
- it('should use the custom primary key when a single value is passed in', function(done) {
- query.findOne(1, function(err, values) {
- if (err) {
- return done(err);
- }
- assert.equal(values.criteria.where.pkColumn, 1);
- return done();
- });
- });
- });
- });
- });
- });
|