Files
NodeBB/test/database/list.js

261 lines
6.9 KiB
JavaScript
Raw Normal View History

2014-12-29 16:20:35 -05:00
'use strict';
2014-12-29 16:20:35 -05:00
const async = require('async');
2021-02-04 00:06:15 -07:00
const assert = require('assert');
const db = require('../mocks/databasemock');
2014-12-29 16:20:35 -05:00
2021-02-04 00:01:39 -07:00
describe('List methods', () => {
describe('listAppend()', () => {
it('should append to a list', (done) => {
db.listAppend('testList1', 5, function (err) {
2017-05-19 20:24:54 -04:00
assert.ifError(err);
2015-01-15 14:02:51 -05:00
assert.equal(arguments.length, 1);
2014-12-29 16:20:35 -05:00
done();
});
});
2017-05-19 20:24:54 -04:00
2021-02-04 00:01:39 -07:00
it('should not add anyhing if key is falsy', (done) => {
db.listAppend(null, 3, (err) => {
2017-05-19 20:24:54 -04:00
assert.ifError(err);
done();
});
});
it('should append each element to list', async () => {
await db.listAppend('arrayListAppend', ['a', 'b', 'c']);
let values = await db.getListRange('arrayListAppend', 0, -1);
assert.deepStrictEqual(values, ['a', 'b', 'c']);
await db.listAppend('arrayListAppend', ['d', 'e']);
values = await db.getListRange('arrayListAppend', 0, -1);
assert.deepStrictEqual(values, ['a', 'b', 'c', 'd', 'e']);
});
2014-12-29 16:20:35 -05:00
});
2021-02-04 00:01:39 -07:00
describe('listPrepend()', () => {
it('should prepend to a list', (done) => {
db.listPrepend('testList2', 3, function (err) {
2015-01-15 14:02:51 -05:00
assert.equal(err, null);
assert.equal(arguments.length, 1);
2014-12-29 16:20:35 -05:00
done();
});
});
2021-02-04 00:01:39 -07:00
it('should prepend 2 more elements to a list', (done) => {
2014-12-29 16:20:35 -05:00
async.series([
function (next) {
2014-12-29 16:20:35 -05:00
db.listPrepend('testList2', 2, next);
},
function (next) {
2014-12-29 16:20:35 -05:00
db.listPrepend('testList2', 1, next);
2017-02-17 19:31:21 -07:00
},
2021-02-04 00:01:39 -07:00
], (err) => {
2015-01-15 14:02:51 -05:00
assert.equal(err, null);
2014-12-29 16:20:35 -05:00
done();
});
});
2017-05-19 20:24:54 -04:00
2021-02-04 00:01:39 -07:00
it('should not add anyhing if key is falsy', (done) => {
db.listPrepend(null, 3, (err) => {
2017-05-19 20:24:54 -04:00
assert.ifError(err);
done();
});
});
it('should prepend each element to list', async () => {
await db.listPrepend('arrayListPrepend', ['a', 'b', 'c']);
let values = await db.getListRange('arrayListPrepend', 0, -1);
assert.deepStrictEqual(values, ['c', 'b', 'a']);
await db.listPrepend('arrayListPrepend', ['d', 'e']);
values = await db.getListRange('arrayListPrepend', 0, -1);
assert.deepStrictEqual(values, ['e', 'd', 'c', 'b', 'a']);
});
2014-12-29 16:20:35 -05:00
});
2021-02-04 00:01:39 -07:00
describe('getListRange()', () => {
2023-10-03 12:50:20 -04:00
before(async () => {
await db.listAppend('testList3', 7);
await db.listPrepend('testList3', 3);
await db.listAppend('testList4', 5);
2015-01-15 14:02:51 -05:00
});
2021-02-04 00:01:39 -07:00
it('should return an empty list', (done) => {
db.getListRange('doesnotexist', 0, -1, function (err, list) {
2015-01-15 14:02:51 -05:00
assert.equal(err, null);
assert.equal(arguments.length, 2);
assert.equal(Array.isArray(list), true);
assert.equal(list.length, 0);
2014-12-29 16:20:35 -05:00
done();
});
});
2021-02-04 00:01:39 -07:00
it('should return a list with one element', (done) => {
db.getListRange('testList4', 0, 0, (err, list) => {
2015-01-15 14:02:51 -05:00
assert.equal(err, null);
2015-01-15 15:06:02 -05:00
assert.equal(Array.isArray(list), true);
2015-01-15 14:02:51 -05:00
assert.equal(list[0], 5);
2014-12-29 16:20:35 -05:00
done();
});
});
2021-02-04 00:01:39 -07:00
it('should return a list with 2 elements 3, 7', (done) => {
db.getListRange('testList3', 0, -1, (err, list) => {
2015-01-15 14:02:51 -05:00
assert.equal(err, null);
assert.equal(Array.isArray(list), true);
assert.equal(list.length, 2);
assert.deepEqual(list, ['3', '7']);
2014-12-29 16:20:35 -05:00
done();
});
});
2017-05-19 20:24:54 -04:00
2021-02-04 00:01:39 -07:00
it('should not get anything if key is falsy', (done) => {
db.getListRange(null, 0, -1, (err, data) => {
2017-05-19 20:24:54 -04:00
assert.ifError(err);
assert.equal(data, undefined);
done();
});
});
2023-10-03 12:50:20 -04:00
it('should return list elements in reverse order', async () => {
await db.listAppend('reverselisttest', ['one', 'two', 'three', 'four']);
assert.deepStrictEqual(
await db.getListRange('reverselisttest', -4, -3),
['one', 'two']
);
assert.deepStrictEqual(
await db.getListRange('reverselisttest', -2, -1),
['three', 'four']
);
});
2014-12-29 16:20:35 -05:00
});
2021-02-04 00:01:39 -07:00
describe('listRemoveLast()', () => {
before((done) => {
2015-01-15 14:02:51 -05:00
async.series([
function (next) {
db.listAppend('testList7', 12, next);
2015-01-15 14:02:51 -05:00
},
function (next) {
db.listPrepend('testList7', 9, next);
2017-02-17 19:31:21 -07:00
},
2015-01-15 14:02:51 -05:00
], done);
});
2021-02-04 00:01:39 -07:00
it('should remove the last element of list and return it', (done) => {
db.listRemoveLast('testList7', function (err, lastElement) {
2015-01-15 14:02:51 -05:00
assert.equal(err, null);
assert.equal(arguments.length, 2);
assert.equal(lastElement, '12');
2014-12-29 16:20:35 -05:00
done();
});
});
2017-05-19 20:24:54 -04:00
2021-02-04 00:01:39 -07:00
it('should not remove anyhing if key is falsy', (done) => {
db.listRemoveLast(null, (err) => {
2017-05-19 20:24:54 -04:00
assert.ifError(err);
done();
});
});
2014-12-29 16:20:35 -05:00
});
2021-02-04 00:01:39 -07:00
describe('listRemoveAll()', () => {
before((done) => {
2015-01-15 14:02:51 -05:00
async.series([
async.apply(db.listAppend, 'testList5', 1),
async.apply(db.listAppend, 'testList5', 1),
async.apply(db.listAppend, 'testList5', 1),
async.apply(db.listAppend, 'testList5', 2),
2017-02-17 19:31:21 -07:00
async.apply(db.listAppend, 'testList5', 5),
2015-01-15 14:02:51 -05:00
], done);
});
2021-02-04 00:01:39 -07:00
it('should remove all the matching elements of list', (done) => {
db.listRemoveAll('testList5', '1', function (err) {
2015-01-15 14:02:51 -05:00
assert.equal(err, null);
assert.equal(arguments.length, 1);
2014-12-29 16:20:35 -05:00
2021-02-04 00:01:39 -07:00
db.getListRange('testList5', 0, -1, (err, list) => {
2016-08-16 19:46:59 +02:00
assert.equal(err, null);
2015-01-15 14:02:51 -05:00
assert.equal(Array.isArray(list), true);
assert.equal(list.length, 2);
assert.equal(list.indexOf('1'), -1);
2014-12-29 16:20:35 -05:00
done();
});
});
});
2017-05-19 20:24:54 -04:00
2021-02-04 00:01:39 -07:00
it('should not remove anyhing if key is falsy', (done) => {
db.listRemoveAll(null, 3, (err) => {
2017-05-19 20:24:54 -04:00
assert.ifError(err);
done();
});
});
it('should remove multiple elements from list', async () => {
await db.listAppend('multiRemoveList', ['a', 'b', 'c', 'd', 'e']);
const initial = await db.getListRange('multiRemoveList', 0, -1);
assert.deepStrictEqual(initial, ['a', 'b', 'c', 'd', 'e']);
await db.listRemoveAll('multiRemoveList', ['b', 'd']);
const values = await db.getListRange('multiRemoveList', 0, -1);
assert.deepStrictEqual(values, ['a', 'c', 'e']);
});
2014-12-29 16:20:35 -05:00
});
2021-02-04 00:01:39 -07:00
describe('listTrim()', () => {
it('should trim list to a certain range', (done) => {
2021-02-04 00:06:15 -07:00
const list = ['1', '2', '3', '4', '5'];
2021-02-04 00:01:39 -07:00
async.eachSeries(list, (value, next) => {
2015-01-15 14:02:51 -05:00
db.listAppend('testList6', value, next);
2021-02-04 00:01:39 -07:00
}, (err) => {
2014-12-29 16:20:35 -05:00
if (err) {
return done(err);
}
db.listTrim('testList6', 0, 2, function (err) {
2015-01-15 15:33:22 -05:00
assert.equal(err, null);
assert.equal(arguments.length, 1);
2021-02-04 00:01:39 -07:00
db.getListRange('testList6', 0, -1, (err, list) => {
2016-08-16 19:46:59 +02:00
assert.equal(err, null);
2015-01-15 15:33:22 -05:00
assert.equal(list.length, 3);
assert.deepEqual(list, ['1', '2', '3']);
2014-12-29 17:34:56 -05:00
done();
2014-12-29 16:20:35 -05:00
});
});
});
});
2017-05-19 20:24:54 -04:00
2021-02-04 00:01:39 -07:00
it('should not add anyhing if key is falsy', (done) => {
db.listTrim(null, 0, 3, (err) => {
2017-05-19 20:24:54 -04:00
assert.ifError(err);
done();
});
});
2014-12-29 16:20:35 -05:00
});
2018-03-15 12:06:40 -04:00
2021-02-04 00:01:39 -07:00
describe('listLength', () => {
it('should get the length of a list', (done) => {
db.listAppend('getLengthList', 1, (err) => {
2018-03-15 12:06:40 -04:00
assert.ifError(err);
2021-02-04 00:01:39 -07:00
db.listAppend('getLengthList', 2, (err) => {
2018-03-15 12:06:40 -04:00
assert.ifError(err);
2021-02-04 00:01:39 -07:00
db.listLength('getLengthList', (err, length) => {
Async refactor in place (#7736) * feat: allow both callback&and await * feat: ignore async key * feat: callbackify and promisify in same file * Revert "feat: callbackify and promisify in same file" This reverts commit cea206a9b8e6d8295310074b18cc82a504487862. * feat: no need to store .callbackify * feat: change getTopics to async * feat: remove .async * fix: byScore * feat: rewrite topics/index and social with async/await * fix: rewrite topics/data.js fix issue with async.waterfall, only pass result if its not undefined * feat: add callbackify to redis/psql * feat: psql use await * fix: redis :volcano: * feat: less returns * feat: more await rewrite * fix: redis tests * feat: convert sortedSetAdd rewrite psql transaction to async/await * feat: :dog: * feat: test * feat: log client and query * feat: log bind * feat: more logs * feat: more logs * feat: check perform * feat: dont callbackify transaction * feat: remove logs * fix: main functions * feat: more logs * fix: increment * fix: rename * feat: remove cls * fix: remove console.log * feat: add deprecation message to .async usage * feat: update more dbal methods * fix: redis :voodoo: * feat: fix redis zrem, convert setObject * feat: upgrade getObject methods * fix: psql getObjectField * fix: redis tests * feat: getObjectKeys * feat: getObjectValues * feat: isObjectField * fix: add missing return * feat: delObjectField * feat: incrObjectField * fix: add missing await * feat: remove exposed helpers * feat: list methods * feat: flush/empty * feat: delete * fix: redis delete all * feat: get/set * feat: incr/rename * feat: type * feat: expire * feat: setAdd * feat: setRemove * feat: isSetMember * feat: getSetMembers * feat: setCount, setRemoveRandom * feat: zcard,zcount * feat: sortedSetRank * feat: isSortedSetMember * feat: zincrby * feat: sortedSetLex * feat: processSortedSet * fix: add mising await * feat: debug psql * fix: psql test * fix: test * fix: another test * fix: test fix * fix: psql tests * feat: remove logs * feat: user arrow func use builtin async promises * feat: topic bookmarks * feat: topic.delete * feat: topic.restore * feat: topics.purge * feat: merge * feat: suggested * feat: topics/user.js * feat: topics modules * feat: topics/follow * fix: deprecation msg * feat: fork * feat: topics/posts * feat: sorted/recent * feat: topic/teaser * feat: topics/tools * feat: topics/unread * feat: add back node versions disable deprecation notice wrap async controllers in try/catch * feat: use db directly * feat: promisify in place * fix: redis/psql * feat: deprecation message logs for psql * feat: more logs * feat: more logs * feat: logs again * feat: more logs * fix: call release * feat: restore travis, remove logs * fix: loops * feat: remove .async. usage
2019-07-09 12:46:49 -04:00
assert.ifError(err);
assert.equal(length, 2);
done();
});
2018-03-15 12:06:40 -04:00
});
});
});
Async refactor in place (#7736) * feat: allow both callback&and await * feat: ignore async key * feat: callbackify and promisify in same file * Revert "feat: callbackify and promisify in same file" This reverts commit cea206a9b8e6d8295310074b18cc82a504487862. * feat: no need to store .callbackify * feat: change getTopics to async * feat: remove .async * fix: byScore * feat: rewrite topics/index and social with async/await * fix: rewrite topics/data.js fix issue with async.waterfall, only pass result if its not undefined * feat: add callbackify to redis/psql * feat: psql use await * fix: redis :volcano: * feat: less returns * feat: more await rewrite * fix: redis tests * feat: convert sortedSetAdd rewrite psql transaction to async/await * feat: :dog: * feat: test * feat: log client and query * feat: log bind * feat: more logs * feat: more logs * feat: check perform * feat: dont callbackify transaction * feat: remove logs * fix: main functions * feat: more logs * fix: increment * fix: rename * feat: remove cls * fix: remove console.log * feat: add deprecation message to .async usage * feat: update more dbal methods * fix: redis :voodoo: * feat: fix redis zrem, convert setObject * feat: upgrade getObject methods * fix: psql getObjectField * fix: redis tests * feat: getObjectKeys * feat: getObjectValues * feat: isObjectField * fix: add missing return * feat: delObjectField * feat: incrObjectField * fix: add missing await * feat: remove exposed helpers * feat: list methods * feat: flush/empty * feat: delete * fix: redis delete all * feat: get/set * feat: incr/rename * feat: type * feat: expire * feat: setAdd * feat: setRemove * feat: isSetMember * feat: getSetMembers * feat: setCount, setRemoveRandom * feat: zcard,zcount * feat: sortedSetRank * feat: isSortedSetMember * feat: zincrby * feat: sortedSetLex * feat: processSortedSet * fix: add mising await * feat: debug psql * fix: psql test * fix: test * fix: another test * fix: test fix * fix: psql tests * feat: remove logs * feat: user arrow func use builtin async promises * feat: topic bookmarks * feat: topic.delete * feat: topic.restore * feat: topics.purge * feat: merge * feat: suggested * feat: topics/user.js * feat: topics modules * feat: topics/follow * fix: deprecation msg * feat: fork * feat: topics/posts * feat: sorted/recent * feat: topic/teaser * feat: topics/tools * feat: topics/unread * feat: add back node versions disable deprecation notice wrap async controllers in try/catch * feat: use db directly * feat: promisify in place * fix: redis/psql * feat: deprecation message logs for psql * feat: more logs * feat: more logs * feat: logs again * feat: more logs * fix: call release * feat: restore travis, remove logs * fix: loops * feat: remove .async. usage
2019-07-09 12:46:49 -04:00
2021-02-04 00:01:39 -07:00
it('should return 0 if list does not have any elements', (done) => {
db.listLength('doesnotexist', (err, length) => {
Async refactor in place (#7736) * feat: allow both callback&and await * feat: ignore async key * feat: callbackify and promisify in same file * Revert "feat: callbackify and promisify in same file" This reverts commit cea206a9b8e6d8295310074b18cc82a504487862. * feat: no need to store .callbackify * feat: change getTopics to async * feat: remove .async * fix: byScore * feat: rewrite topics/index and social with async/await * fix: rewrite topics/data.js fix issue with async.waterfall, only pass result if its not undefined * feat: add callbackify to redis/psql * feat: psql use await * fix: redis :volcano: * feat: less returns * feat: more await rewrite * fix: redis tests * feat: convert sortedSetAdd rewrite psql transaction to async/await * feat: :dog: * feat: test * feat: log client and query * feat: log bind * feat: more logs * feat: more logs * feat: check perform * feat: dont callbackify transaction * feat: remove logs * fix: main functions * feat: more logs * fix: increment * fix: rename * feat: remove cls * fix: remove console.log * feat: add deprecation message to .async usage * feat: update more dbal methods * fix: redis :voodoo: * feat: fix redis zrem, convert setObject * feat: upgrade getObject methods * fix: psql getObjectField * fix: redis tests * feat: getObjectKeys * feat: getObjectValues * feat: isObjectField * fix: add missing return * feat: delObjectField * feat: incrObjectField * fix: add missing await * feat: remove exposed helpers * feat: list methods * feat: flush/empty * feat: delete * fix: redis delete all * feat: get/set * feat: incr/rename * feat: type * feat: expire * feat: setAdd * feat: setRemove * feat: isSetMember * feat: getSetMembers * feat: setCount, setRemoveRandom * feat: zcard,zcount * feat: sortedSetRank * feat: isSortedSetMember * feat: zincrby * feat: sortedSetLex * feat: processSortedSet * fix: add mising await * feat: debug psql * fix: psql test * fix: test * fix: another test * fix: test fix * fix: psql tests * feat: remove logs * feat: user arrow func use builtin async promises * feat: topic bookmarks * feat: topic.delete * feat: topic.restore * feat: topics.purge * feat: merge * feat: suggested * feat: topics/user.js * feat: topics modules * feat: topics/follow * fix: deprecation msg * feat: fork * feat: topics/posts * feat: sorted/recent * feat: topic/teaser * feat: topics/tools * feat: topics/unread * feat: add back node versions disable deprecation notice wrap async controllers in try/catch * feat: use db directly * feat: promisify in place * fix: redis/psql * feat: deprecation message logs for psql * feat: more logs * feat: more logs * feat: logs again * feat: more logs * fix: call release * feat: restore travis, remove logs * fix: loops * feat: remove .async. usage
2019-07-09 12:46:49 -04:00
assert.ifError(err);
assert.strictEqual(length, 0);
done();
});
});
2018-03-15 12:06:40 -04:00
});
2014-12-29 16:20:35 -05:00
});