51e6b2135f
* centralize page size setting, and default to page size of 5 in dev * remove size arg when using lazyPaginatedQuery so that the app uses the config default size * move list-pagination component out of the loop * update store tests
247 lines
7.5 KiB
JavaScript
247 lines
7.5 KiB
JavaScript
import { resolve } from 'rsvp';
|
|
import { run } from '@ember/runloop';
|
|
import { module, test } from 'qunit';
|
|
import { setupTest } from 'ember-qunit';
|
|
import { normalizeModelName, keyForCache } from 'vault/services/store';
|
|
import clamp from 'vault/utils/clamp';
|
|
import config from 'vault/config/environment';
|
|
|
|
const { DEFAULT_PAGE_SIZE } = config.APP;
|
|
|
|
module('Unit | Service | store', function(hooks) {
|
|
setupTest(hooks);
|
|
|
|
test('normalizeModelName', function(assert) {
|
|
assert.equal(normalizeModelName('oneThing'), 'one-thing', 'dasherizes modelName');
|
|
});
|
|
|
|
test('keyForCache', function(assert) {
|
|
const query = { id: 1 };
|
|
const queryWithSize = { id: 1, size: 1 };
|
|
assert.deepEqual(keyForCache(query), JSON.stringify(query), 'generated the correct cache key');
|
|
assert.deepEqual(keyForCache(queryWithSize), JSON.stringify(query), 'excludes size from query cache');
|
|
});
|
|
|
|
test('clamp', function(assert) {
|
|
assert.equal(clamp('foo', 0, 100), 0, 'returns the min if passed a non-number');
|
|
assert.equal(clamp(0, 1, 100), 1, 'returns the min when passed number is less than the min');
|
|
assert.equal(clamp(200, 1, 100), 100, 'returns the max passed number is greater than the max');
|
|
assert.equal(clamp(50, 1, 100), 50, 'returns the passed number when it is in range');
|
|
});
|
|
|
|
test('store.storeDataset', function(assert) {
|
|
const arr = ['one', 'two'];
|
|
const store = this.owner.lookup('service:store');
|
|
const query = { id: 1 };
|
|
store.storeDataset('data', query, {}, arr);
|
|
|
|
assert.deepEqual(store.getDataset('data', query).dataset, arr, 'it stores the array as .dataset');
|
|
assert.deepEqual(store.getDataset('data', query).response, {}, 'it stores the response as .response');
|
|
assert.ok(store.get('lazyCaches').has('data'), 'it stores model map');
|
|
assert.ok(
|
|
store
|
|
.get('lazyCaches')
|
|
.get('data')
|
|
.has(keyForCache(query)),
|
|
'it stores data on the model map'
|
|
);
|
|
});
|
|
|
|
test('store.clearDataset with a prefix', function(assert) {
|
|
const store = this.owner.lookup('service:store');
|
|
const arr = ['one', 'two'];
|
|
const arr2 = ['one', 'two', 'three', 'four'];
|
|
store.storeDataset('data', { id: 1 }, {}, arr);
|
|
store.storeDataset('transit-key', { id: 2 }, {}, arr2);
|
|
assert.equal(store.get('lazyCaches').size, 2, 'it stores both keys');
|
|
|
|
store.clearDataset('transit-key');
|
|
assert.equal(store.get('lazyCaches').size, 1, 'deletes one key');
|
|
assert.notOk(store.get('lazyCaches').has(), 'cache is no longer stored');
|
|
});
|
|
|
|
test('store.clearAllDatasets', function(assert) {
|
|
const store = this.owner.lookup('service:store');
|
|
const arr = ['one', 'two'];
|
|
const arr2 = ['one', 'two', 'three', 'four'];
|
|
store.storeDataset('data', { id: 1 }, {}, arr);
|
|
store.storeDataset('transit-key', { id: 2 }, {}, arr2);
|
|
assert.equal(store.get('lazyCaches').size, 2, 'it stores both keys');
|
|
|
|
store.clearAllDatasets();
|
|
assert.equal(store.get('lazyCaches').size, 0, 'deletes all of the keys');
|
|
assert.notOk(store.get('lazyCaches').has('transit-key'), 'first cache key is no longer stored');
|
|
assert.notOk(store.get('lazyCaches').has('data'), 'second cache key is no longer stored');
|
|
});
|
|
|
|
test('store.getDataset', function(assert) {
|
|
const arr = ['one', 'two'];
|
|
const store = this.owner.lookup('service:store');
|
|
store.storeDataset('data', { id: 1 }, {}, arr);
|
|
|
|
assert.deepEqual(store.getDataset('data', { id: 1 }), { response: {}, dataset: arr });
|
|
});
|
|
|
|
test('store.constructResponse', function(assert) {
|
|
const arr = ['one', 'two', 'three', 'fifteen', 'twelve'];
|
|
const store = this.owner.lookup('service:store');
|
|
store.storeDataset('data', { id: 1 }, {}, arr);
|
|
|
|
assert.deepEqual(
|
|
store.constructResponse('data', { id: 1, pageFilter: 't', page: 1, size: 3, responsePath: 'data' }),
|
|
{
|
|
data: ['two', 'three', 'fifteen'],
|
|
meta: { currentPage: 1, lastPage: 2, nextPage: 2, prevPage: 1, total: 5, filteredTotal: 4 },
|
|
},
|
|
'it returns filtered results'
|
|
);
|
|
});
|
|
|
|
test('store.fetchPage', function(assert) {
|
|
let done = assert.async(4);
|
|
const keys = ['zero', 'one', 'two', 'three', 'four', 'five', 'six'];
|
|
const data = {
|
|
data: {
|
|
keys,
|
|
},
|
|
};
|
|
const store = this.owner.lookup('service:store');
|
|
const pageSize = 2;
|
|
const query = {
|
|
size: pageSize,
|
|
page: 1,
|
|
responsePath: 'data.keys',
|
|
};
|
|
store.storeDataset('transit-key', query, data, keys);
|
|
|
|
let result;
|
|
run(() => {
|
|
store.fetchPage('transit-key', query).then(r => {
|
|
result = r;
|
|
done();
|
|
});
|
|
});
|
|
|
|
assert.ok(result.get('length'), pageSize, 'returns the correct number of items');
|
|
assert.deepEqual(result.mapBy('id'), keys.slice(0, pageSize), 'returns the first page of items');
|
|
assert.deepEqual(
|
|
result.get('meta'),
|
|
{
|
|
nextPage: 2,
|
|
prevPage: 1,
|
|
currentPage: 1,
|
|
lastPage: 4,
|
|
total: 7,
|
|
filteredTotal: 7,
|
|
},
|
|
'returns correct meta values'
|
|
);
|
|
|
|
run(() => {
|
|
store
|
|
.fetchPage('transit-key', {
|
|
size: pageSize,
|
|
page: 3,
|
|
responsePath: 'data.keys',
|
|
})
|
|
.then(r => {
|
|
result = r;
|
|
done();
|
|
});
|
|
});
|
|
|
|
const pageThreeEnd = 3 * pageSize;
|
|
const pageThreeStart = pageThreeEnd - pageSize;
|
|
assert.deepEqual(
|
|
result.mapBy('id'),
|
|
keys.slice(pageThreeStart, pageThreeEnd),
|
|
'returns the third page of items'
|
|
);
|
|
|
|
run(() => {
|
|
store
|
|
.fetchPage('transit-key', {
|
|
size: pageSize,
|
|
page: 99,
|
|
responsePath: 'data.keys',
|
|
})
|
|
.then(r => {
|
|
result = r;
|
|
done();
|
|
});
|
|
});
|
|
|
|
assert.deepEqual(
|
|
result.mapBy('id'),
|
|
keys.slice(keys.length - 1),
|
|
'returns the last page when the page value is beyond the of bounds'
|
|
);
|
|
|
|
run(() => {
|
|
store
|
|
.fetchPage('transit-key', {
|
|
size: pageSize,
|
|
page: 0,
|
|
responsePath: 'data.keys',
|
|
})
|
|
.then(r => {
|
|
result = r;
|
|
done();
|
|
});
|
|
});
|
|
assert.deepEqual(
|
|
result.mapBy('id'),
|
|
keys.slice(0, pageSize),
|
|
'returns the first page when page value is under the bounds'
|
|
);
|
|
});
|
|
|
|
test('store.lazyPaginatedQuery', function(assert) {
|
|
let response = {
|
|
data: ['foo'],
|
|
};
|
|
let queryArgs;
|
|
const store = this.owner.factoryFor('service:store').create({
|
|
adapterFor() {
|
|
return {
|
|
query(store, modelName, query) {
|
|
queryArgs = query;
|
|
return resolve(response);
|
|
},
|
|
};
|
|
},
|
|
fetchPage() {},
|
|
});
|
|
|
|
const query = { page: 1, size: 1, responsePath: 'data' };
|
|
run(function() {
|
|
store.lazyPaginatedQuery('transit-key', query);
|
|
});
|
|
assert.deepEqual(
|
|
store.getDataset('transit-key', query),
|
|
{ response: { data: null }, dataset: ['foo'] },
|
|
'stores returned dataset'
|
|
);
|
|
|
|
run(function() {
|
|
store.lazyPaginatedQuery('secret', { page: 1, responsePath: 'data' });
|
|
});
|
|
assert.equal(queryArgs.size, DEFAULT_PAGE_SIZE, 'calls query with DEFAULT_PAGE_SIZE');
|
|
|
|
assert.throws(
|
|
() => {
|
|
store.lazyPaginatedQuery('transit-key', {});
|
|
},
|
|
/responsePath is required/,
|
|
'requires responsePath'
|
|
);
|
|
assert.throws(
|
|
() => {
|
|
store.lazyPaginatedQuery('transit-key', { responsePath: 'foo' });
|
|
},
|
|
/page is required/,
|
|
'requires page'
|
|
);
|
|
});
|
|
});
|