2016-10-15 03:06:07 +08:00
|
|
|
/* eslint quote-props: 0 */
|
|
|
|
import Thread from '../../src/flux/models/thread';
|
|
|
|
import TestModel from '../fixtures/db-test-model';
|
|
|
|
import ModelQuery from '../../src/flux/models/query';
|
|
|
|
import DatabaseStore from '../../src/flux/stores/database-store';
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
const testMatchers = { id: 'b' };
|
2016-10-15 03:06:07 +08:00
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
describe('DatabaseStore', function DatabaseStoreSpecs() {
|
2016-10-15 03:06:07 +08:00
|
|
|
beforeEach(() => {
|
|
|
|
TestModel.configureBasic();
|
|
|
|
spyOn(ModelQuery.prototype, 'where').andCallThrough();
|
|
|
|
|
|
|
|
this.performed = [];
|
|
|
|
|
|
|
|
// Note: We spy on _query and test all of the convenience methods that sit above
|
|
|
|
// it. None of these tests evaluate whether _query works!
|
2017-09-27 02:33:08 +08:00
|
|
|
jasmine.unspy(DatabaseStore, '_query');
|
|
|
|
spyOn(DatabaseStore, '_query').andCallFake((query, values = []) => {
|
|
|
|
this.performed.push({ query, values });
|
2016-10-15 03:06:07 +08:00
|
|
|
return Promise.resolve([]);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
describe('find', () =>
|
|
|
|
it('should return a ModelQuery for retrieving a single item by Id', () => {
|
|
|
|
const q = DatabaseStore.find(TestModel, '4');
|
|
|
|
expect(q.sql()).toBe(
|
|
|
|
"SELECT `TestModel`.`data` FROM `TestModel` WHERE `TestModel`.`id` = '4' LIMIT 1"
|
|
|
|
);
|
|
|
|
}));
|
2016-10-15 03:06:07 +08:00
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
describe('findBy', () => {
|
|
|
|
it('should pass the provided predicates on to the ModelQuery', () => {
|
2016-10-15 03:06:07 +08:00
|
|
|
DatabaseStore.findBy(TestModel, testMatchers);
|
|
|
|
expect(ModelQuery.prototype.where).toHaveBeenCalledWith(testMatchers);
|
|
|
|
});
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
it('should return a ModelQuery ready to be executed', () => {
|
2016-10-15 03:06:07 +08:00
|
|
|
const q = DatabaseStore.findBy(TestModel, testMatchers);
|
2017-09-27 02:33:08 +08:00
|
|
|
expect(q.sql()).toBe(
|
|
|
|
"SELECT `TestModel`.`data` FROM `TestModel` WHERE `TestModel`.`id` = 'b' LIMIT 1"
|
|
|
|
);
|
2016-10-15 03:06:07 +08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
describe('findAll', () => {
|
|
|
|
it('should pass the provided predicates on to the ModelQuery', () => {
|
2016-10-15 03:06:07 +08:00
|
|
|
DatabaseStore.findAll(TestModel, testMatchers);
|
|
|
|
expect(ModelQuery.prototype.where).toHaveBeenCalledWith(testMatchers);
|
|
|
|
});
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
it('should return a ModelQuery ready to be executed', () => {
|
2016-10-15 03:06:07 +08:00
|
|
|
const q = DatabaseStore.findAll(TestModel, testMatchers);
|
2017-09-27 02:33:08 +08:00
|
|
|
expect(q.sql()).toBe(
|
|
|
|
"SELECT `TestModel`.`data` FROM `TestModel` WHERE `TestModel`.`id` = 'b' "
|
|
|
|
);
|
2016-10-15 03:06:07 +08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
describe('modelify', () => {
|
2016-10-15 03:06:07 +08:00
|
|
|
beforeEach(() => {
|
|
|
|
this.models = [
|
2017-09-27 02:33:08 +08:00
|
|
|
new Thread({ id: 'local-A' }),
|
|
|
|
new Thread({ id: 'local-B' }),
|
|
|
|
new Thread({ id: 'local-C' }),
|
|
|
|
new Thread({ id: 'local-D' }),
|
|
|
|
new Thread({ id: 'local-E' }),
|
|
|
|
new Thread({ id: 'local-F' }),
|
|
|
|
new Thread({ id: 'local-G' }),
|
2016-10-15 03:06:07 +08:00
|
|
|
];
|
|
|
|
// Actually returns correct sets for queries, since matchers can evaluate
|
|
|
|
// themselves against models in memory
|
|
|
|
spyOn(DatabaseStore, 'run').andCallFake(query => {
|
|
|
|
const results = this.models.filter(model =>
|
|
|
|
query._matchers.every(matcher => matcher.evaluate(model))
|
|
|
|
);
|
|
|
|
return Promise.resolve(results);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
describe('when given an array or input that is not an array', () =>
|
|
|
|
it('resolves immediately with an empty array', () =>
|
2016-10-15 03:06:07 +08:00
|
|
|
waitsForPromise(() => {
|
|
|
|
return DatabaseStore.modelify(Thread, null).then(output => {
|
|
|
|
expect(output).toEqual([]);
|
|
|
|
});
|
2017-09-27 02:33:08 +08:00
|
|
|
})));
|
2016-10-15 03:06:07 +08:00
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
describe('when given an array of mixed IDs, and models', () =>
|
|
|
|
it('resolves with an array of models', () => {
|
2017-06-22 04:12:49 +08:00
|
|
|
const input = ['local-F', 'local-B', 'local-C', 'local-D', this.models[6]];
|
2017-09-27 02:33:08 +08:00
|
|
|
const expectedOutput = [
|
|
|
|
this.models[5],
|
|
|
|
this.models[1],
|
|
|
|
this.models[2],
|
|
|
|
this.models[3],
|
|
|
|
this.models[6],
|
|
|
|
];
|
2016-10-15 03:06:07 +08:00
|
|
|
return waitsForPromise(() => {
|
|
|
|
return DatabaseStore.modelify(Thread, input).then(output => {
|
|
|
|
expect(output).toEqual(expectedOutput);
|
|
|
|
});
|
|
|
|
});
|
2017-09-27 02:33:08 +08:00
|
|
|
}));
|
2016-10-15 03:06:07 +08:00
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
describe('when the input is only IDs', () =>
|
|
|
|
it('resolves with an array of models', () => {
|
2017-06-22 04:12:49 +08:00
|
|
|
const input = ['local-D', 'local-F', 'local-G'];
|
2016-10-15 03:06:07 +08:00
|
|
|
const expectedOutput = [this.models[3], this.models[5], this.models[6]];
|
|
|
|
return waitsForPromise(() => {
|
|
|
|
return DatabaseStore.modelify(Thread, input).then(output => {
|
|
|
|
expect(output).toEqual(expectedOutput);
|
|
|
|
});
|
|
|
|
});
|
2017-09-27 02:33:08 +08:00
|
|
|
}));
|
2016-10-15 03:06:07 +08:00
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
describe('when the input is all models', () =>
|
|
|
|
it('resolves with an array of models', () => {
|
2016-10-15 03:06:07 +08:00
|
|
|
const input = [this.models[0], this.models[1], this.models[2], this.models[3]];
|
|
|
|
const expectedOutput = [this.models[0], this.models[1], this.models[2], this.models[3]];
|
|
|
|
return waitsForPromise(() => {
|
|
|
|
return DatabaseStore.modelify(Thread, input).then(output => {
|
|
|
|
expect(output).toEqual(expectedOutput);
|
|
|
|
});
|
|
|
|
});
|
2017-09-27 02:33:08 +08:00
|
|
|
}));
|
2016-10-15 03:06:07 +08:00
|
|
|
});
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
describe('count', () => {
|
|
|
|
it('should pass the provided predicates on to the ModelQuery', () => {
|
2016-10-15 03:06:07 +08:00
|
|
|
DatabaseStore.findAll(TestModel, testMatchers);
|
|
|
|
expect(ModelQuery.prototype.where).toHaveBeenCalledWith(testMatchers);
|
|
|
|
});
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
it('should return a ModelQuery configured for COUNT ready to be executed', () => {
|
2016-10-15 03:06:07 +08:00
|
|
|
const q = DatabaseStore.findAll(TestModel, testMatchers);
|
2017-09-27 02:33:08 +08:00
|
|
|
expect(q.sql()).toBe(
|
|
|
|
"SELECT `TestModel`.`data` FROM `TestModel` WHERE `TestModel`.`id` = 'b' "
|
|
|
|
);
|
2016-10-15 03:06:07 +08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|