mirror of
				https://github.com/NodeBB/NodeBB.git
				synced 2025-10-31 19:15:58 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			702 lines
		
	
	
		
			21 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			702 lines
		
	
	
		
			21 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 'use strict';
 | |
| /*global require, after, before*/
 | |
| 
 | |
| var	async = require('async'),
 | |
| 	assert = require('assert'),
 | |
| 	db = require('../mocks/databasemock');
 | |
| 
 | |
| describe('Sorted Set methods', function () {
 | |
| 
 | |
| 	before(function (done) {
 | |
| 		async.parallel([
 | |
| 			function (next) {
 | |
| 				db.sortedSetAdd('sortedSetTest1', [1, 2, 3], ['value1', 'value2', 'value3'], next);
 | |
| 			},
 | |
| 			function (next) {
 | |
| 				db.sortedSetAdd('sortedSetTest2', [1, 4], ['value1', 'value4'], next);
 | |
| 			},
 | |
| 			function (next) {
 | |
| 				db.sortedSetAdd('sortedSetTest3', [2, 4], ['value2', 'value4'], next);
 | |
| 			}
 | |
| 		], done);
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetAdd()', function () {
 | |
| 		it('should add an element to a sorted set', function (done) {
 | |
| 			db.sortedSetAdd('sorted1', 1, 'value1', function (err) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 1);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should add two elements to a sorted set', function (done) {
 | |
| 			db.sortedSetAdd('sorted2', [1, 2], ['value1', 'value2'], function (err) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 1);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetsAdd()', function () {
 | |
| 		it('should add an element to two sorted sets', function (done) {
 | |
| 			db.sortedSetsAdd(['sorted1', 'sorted2'], 3, 'value3', function (err) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 1);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('getSortedSetRange()', function () {
 | |
| 		it('should return the lowest scored element', function (done) {
 | |
| 			db.getSortedSetRange('sortedSetTest1', 0, 0, function (err, value) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(value, ['value1']);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return elements sorted by score lowest to highest', function (done) {
 | |
| 			db.getSortedSetRange('sortedSetTest1', 0, -1, function (err, values) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(values, ['value1', 'value2', 'value3']);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('getSortedSetRevRange()', function () {
 | |
| 		it('should return the highest scored element', function (done) {
 | |
| 			db.getSortedSetRevRange('sortedSetTest1', 0, 0, function (err, value) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(value, ['value3']);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return elements sorted by score highest to lowest', function (done) {
 | |
| 			db.getSortedSetRevRange('sortedSetTest1', 0, -1, function (err, values) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(values, ['value3', 'value2', 'value1']);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('getSortedSetRangeWithScores()', function () {
 | |
| 		it('should return array of elements sorted by score lowest to highest with scores', function (done) {
 | |
| 			db.getSortedSetRangeWithScores('sortedSetTest1', 0, -1, function (err, values) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(values, [{value: 'value1', score: 1}, {value: 'value2', score: 2}, {value: 'value3', score: 3}]);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('getSortedSetRevRangeWithScores()', function () {
 | |
| 		it('should return array of elements sorted by score highest to lowest with scores', function (done) {
 | |
| 			db.getSortedSetRevRangeWithScores('sortedSetTest1', 0, -1, function (err, values) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(values, [{value: 'value3', score: 3}, {value: 'value2', score: 2}, {value: 'value1', score: 1}]);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('getSortedSetRangeByScore()', function () {
 | |
| 		it('should get count elements with score between min max sorted by score lowest to highest', function (done) {
 | |
| 			db.getSortedSetRangeByScore('sortedSetTest1', 0, -1, '-inf', 2, function (err, values) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(values, ['value1', 'value2']);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('getSortedSetRevRangeByScore()', function () {
 | |
| 		it('should get count elements with score between max min sorted by score highest to lowest', function (done) {
 | |
| 			db.getSortedSetRevRangeByScore('sortedSetTest1', 0, -1, '+inf', 2, function (err, values) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(values, ['value3', 'value2']);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('getSortedSetRangeByScoreWithScores()', function () {
 | |
| 		it('should get count elements with score between min max sorted by score lowest to highest with scores', function (done) {
 | |
| 			db.getSortedSetRangeByScoreWithScores('sortedSetTest1', 0, -1, '-inf', 2, function (err, values) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(values, [{value: 'value1', score: 1}, {value: 'value2', score: 2}]);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('getSortedSetRevRangeByScoreWithScores()', function () {
 | |
| 		it('should get count elements with score between max min sorted by score highest to lowest', function (done) {
 | |
| 			db.getSortedSetRevRangeByScoreWithScores('sortedSetTest1', 0, -1, '+inf', 2, function (err, values) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(values, [{value: 'value3', score: 3}, {value: 'value2', score: 2}]);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetCount()', function () {
 | |
| 		it('should return 0 for a sorted set that does not exist', function (done) {
 | |
| 			db.sortedSetCount('doesnotexist', 0, 10, function (err, count) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(count, 0);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return number of elements between scores min max inclusive', function (done) {
 | |
| 			db.sortedSetCount('sortedSetTest1', '-inf', 2, function (err, count) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(count, 2);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return number of elements between scores -inf +inf inclusive', function (done) {
 | |
| 			db.sortedSetCount('sortedSetTest1', '-inf', '+inf', function (err, count) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(count, 3);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetCard()', function () {
 | |
| 		it('should return 0 for a sorted set that does not exist', function (done) {
 | |
| 			db.sortedSetCard('doesnotexist', function (err, count) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(count, 0);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return number of elements in a sorted set', function (done) {
 | |
| 			db.sortedSetCard('sortedSetTest1', function (err, count) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(count, 3);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetsCard()', function () {
 | |
| 		it('should return the number of elements in sorted sets', function (done) {
 | |
| 			db.sortedSetsCard(['sortedSetTest1', 'sortedSetTest2', 'doesnotexist'], function (err, counts) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(counts, [3, 2, 0]);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetRank()', function () {
 | |
| 		it('should return falsy if sorted set does not exist', function (done) {
 | |
| 			db.sortedSetRank('doesnotexist', 'value1', function (err, rank) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(!!rank, false);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return falsy if element isnt in sorted set', function (done) {
 | |
| 			db.sortedSetRank('sortedSetTest1', 'value5', function (err, rank) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(!!rank, false);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return the rank of the element in the sorted set sorted by lowest to highest score', function (done) {
 | |
| 			db.sortedSetRank('sortedSetTest1', 'value1', function (err, rank) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(rank, 0);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetRevRank()', function () {
 | |
| 		it('should return falsy if sorted set doesnot exist', function (done) {
 | |
| 			db.sortedSetRevRank('doesnotexist', 'value1', function (err, rank) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(!!rank, false);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return falsy if element isnt in sorted set', function (done) {
 | |
| 			db.sortedSetRevRank('sortedSetTest1', 'value5', function (err, rank) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(!!rank, false);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return the rank of the element in the sorted set sorted by highest to lowest score', function (done) {
 | |
| 			db.sortedSetRevRank('sortedSetTest1', 'value1', function (err, rank) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(rank, 2);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetsRanks()', function () {
 | |
| 		it('should return the ranks of values in sorted sets', function (done) {
 | |
| 			db.sortedSetsRanks(['sortedSetTest1', 'sortedSetTest2'], ['value1', 'value4'], function (err, ranks) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(ranks, [0, 1]);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetRanks()', function () {
 | |
| 		it('should return the ranks of values in a sorted set', function (done) {
 | |
| 			db.sortedSetRanks('sortedSetTest1', ['value2', 'value1', 'value3', 'value4'], function (err, ranks) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(ranks, [1, 0, 2, null]);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetScore()', function () {
 | |
| 		it('should return falsy if sorted set does not exist', function (done) {
 | |
| 			db.sortedSetScore('doesnotexist', 'value1', function (err, score) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(!!score, false);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return falsy if element is not in sorted set', function (done) {
 | |
| 			db.sortedSetScore('sortedSetTest1', 'value5', function (err, score) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(!!score, false);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return the score of an element', function (done) {
 | |
| 			db.sortedSetScore('sortedSetTest1', 'value2', function (err, score) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(score, 2);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetsScore()', function () {
 | |
| 		it('should return the scores of value in sorted sets', function (done) {
 | |
| 			db.sortedSetsScore(['sortedSetTest1', 'sortedSetTest2', 'doesnotexist'], 'value1', function (err, scores) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(scores, [1, 1, null]);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetScores()', function () {
 | |
| 		before(function (done) {
 | |
| 			db.sortedSetAdd('zeroScore', 0, 'value1', done);
 | |
| 		});
 | |
| 
 | |
| 		it('should return 0 if score is 0', function (done) {
 | |
| 			db.sortedSetScores('zeroScore', ['value1'], function (err, scores) {
 | |
| 				assert.ifError(err);
 | |
| 				assert.equal(0, scores[0]);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return the scores of value in sorted sets', function (done) {
 | |
| 			db.sortedSetScores('sortedSetTest1', ['value2', 'value1', 'doesnotexist'], function (err, scores) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(scores, [2, 1, null]);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('isSortedSetMember()', function () {
 | |
| 		before(function (done) {
 | |
| 			db.sortedSetAdd('zeroscore', 0, 'itemwithzeroscore', done);
 | |
| 		});
 | |
| 
 | |
| 		it('should return false if sorted set does not exist', function (done) {
 | |
| 			db.isSortedSetMember('doesnotexist', 'value1', function (err, isMember) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(isMember, false);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return false if element is not in sorted set', function (done) {
 | |
| 			db.isSortedSetMember('sorted2', 'value5', function (err, isMember) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(isMember, false);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return true if element is in sorted set', function (done) {
 | |
| 			db.isSortedSetMember('sortedSetTest1', 'value2', function (err, isMember) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(isMember, true);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return true if element is in sorted set with score 0', function (done) {
 | |
| 			db.isSortedSetMember('zeroscore', 'itemwithzeroscore', function (err, isMember) {
 | |
| 				assert.ifError(err);
 | |
| 				assert.deepEqual(isMember, true);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('isSortedSetMembers()', function () {
 | |
| 		it('should return an array of booleans indicating membership', function (done) {
 | |
| 			db.isSortedSetMembers('sortedSetTest1', ['value1', 'value2', 'value5'], function (err, isMembers) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(isMembers, [true, true, false]);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('isMemberOfSortedSets', function () {
 | |
| 		it('should return true for members false for non members', function (done) {
 | |
| 			db.isMemberOfSortedSets(['doesnotexist', 'sortedSetTest1', 'sortedSetTest2'], 'value2', function (err, isMembers) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(isMembers, [false, true, false]);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('getSortedSetsMembers', function () {
 | |
| 		it('should return members of multiple sorted sets', function (done) {
 | |
| 			db.getSortedSetsMembers(['doesnotexist', 'sortedSetTest1'], function (err, sortedSets) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(sortedSets[0], []);
 | |
| 				sortedSets[0].forEach(function (element) {
 | |
| 					assert.notEqual(['value1', 'value2', 'value3'].indexOf(element), -1);
 | |
| 				});
 | |
| 
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetUnionCard', function () {
 | |
| 		it('should return the number of elements in the union', function (done) {
 | |
| 			db.sortedSetUnionCard(['sortedSetTest2', 'sortedSetTest3'], function (err, count) {
 | |
| 				assert.ifError(err);
 | |
| 				assert.equal(count, 3);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('getSortedSetUnion()', function () {
 | |
| 		it('should return an array of values from both sorted sets sorted by scores lowest to highest', function (done) {
 | |
| 			db.getSortedSetUnion({sets: ['sortedSetTest2', 'sortedSetTest3'], start: 0, stop: -1}, function (err, values) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(values, ['value1', 'value2', 'value4']);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('getSortedSetRevUnion()', function () {
 | |
| 		it('should return an array of values from both sorted sets sorted by scores highest to lowest', function (done) {
 | |
| 			db.getSortedSetRevUnion({sets: ['sortedSetTest2', 'sortedSetTest3'], start: 0, stop: -1}, function (err, values) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.deepEqual(values, ['value4', 'value2', 'value1']);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetIncrBy()', function () {
 | |
| 		it('should create a sorted set with a field set to 1', function (done) {
 | |
| 			db.sortedSetIncrBy('sortedIncr', 1, 'field1', function (err, newValue) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(newValue, 1);
 | |
| 				db.sortedSetScore('sortedIncr', 'field1', function (err, score) {
 | |
| 					assert.equal(err, null);
 | |
| 					assert.equal(score, 1);
 | |
| 					done();
 | |
| 				});
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should increment a field of a sorted set by 5', function (done) {
 | |
| 			db.sortedSetIncrBy('sortedIncr', 5, 'field1', function (err, newValue) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 2);
 | |
| 				assert.equal(newValue, 6);
 | |
| 				db.sortedSetScore('sortedIncr', 'field1', function (err, score) {
 | |
| 					assert.equal(err, null);
 | |
| 					assert.equal(score, 6);
 | |
| 					done();
 | |
| 				});
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 
 | |
| 	describe('sortedSetRemove()', function () {
 | |
| 		before(function (done) {
 | |
| 			db.sortedSetAdd('sorted3', [1, 2], ['value1', 'value2'], done);
 | |
| 		});
 | |
| 
 | |
| 		it('should remove an element from a sorted set', function (done) {
 | |
| 			db.sortedSetRemove('sorted3', 'value2', function (err) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 1);
 | |
| 				db.isSortedSetMember('sorted3', 'value2', function (err, isMember) {
 | |
| 					assert.equal(err, null);
 | |
| 					assert.equal(isMember, false);
 | |
| 					done();
 | |
| 				});
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetsRemove()', function () {
 | |
| 		before(function (done) {
 | |
| 			async.parallel([
 | |
| 				async.apply(db.sortedSetAdd, 'sorted4', [1,2], ['value1', 'value2']),
 | |
| 				async.apply(db.sortedSetAdd, 'sorted5', [1,2], ['value1', 'value3']),
 | |
| 			], done);
 | |
| 		});
 | |
| 
 | |
| 		it('should remove element from multiple sorted sets', function (done) {
 | |
| 			db.sortedSetsRemove(['sorted4', 'sorted5'], 'value1', function (err) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 1);
 | |
| 				db.sortedSetsScore(['sorted4', 'sorted5'], 'value1', function (err, scores) {
 | |
| 					assert.equal(err, null);
 | |
| 					assert.deepEqual(scores, [null, null]);
 | |
| 					done();
 | |
| 				});
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetsRemoveRangeByScore()', function () {
 | |
| 		before(function (done) {
 | |
| 			db.sortedSetAdd('sorted6', [1,2,3,4,5], ['value1','value2','value3','value4','value5'], done);
 | |
| 		});
 | |
| 
 | |
| 		it('should remove elements with scores between min max inclusive', function (done) {
 | |
| 			db.sortedSetsRemoveRangeByScore(['sorted6'], 4, 5, function (err) {
 | |
| 				assert.equal(err, null);
 | |
| 				assert.equal(arguments.length, 1);
 | |
| 				db.getSortedSetRange('sorted6', 0, -1, function (err, values) {
 | |
| 					assert.equal(err, null);
 | |
| 					assert.deepEqual(values, ['value1', 'value2', 'value3']);
 | |
| 					done();
 | |
| 				});
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 	describe('getSortedSetIntersect', function () {
 | |
| 		before(function (done) {
 | |
| 			async.parallel([
 | |
| 				function (next) {
 | |
| 					db.sortedSetAdd('interSet1', [1,2,3], ['value1', 'value2', 'value3'], next);
 | |
| 				},
 | |
| 				function (next) {
 | |
| 					db.sortedSetAdd('interSet2', [4,5,6], ['value2', 'value3', 'value5'], next);
 | |
| 				}
 | |
| 			], done);
 | |
| 		});
 | |
| 
 | |
| 		it('should return the intersection of two sets', function (done) {
 | |
| 			db.getSortedSetIntersect({
 | |
| 				sets: ['interSet1', 'interSet2'],
 | |
| 				start: 0,
 | |
| 				stop: -1
 | |
| 			}, function (err, data) {
 | |
| 				assert.ifError(err);
 | |
| 				assert.deepEqual(['value2', 'value3'], data);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return the intersection of two sets with scores', function (done) {
 | |
| 			db.getSortedSetIntersect({
 | |
| 				sets: ['interSet1', 'interSet2'],
 | |
| 				start: 0,
 | |
| 				stop: -1,
 | |
| 				withScores: true
 | |
| 			}, function (err, data) {
 | |
| 				assert.ifError(err);
 | |
| 				assert.deepEqual([{value: 'value2', score: 6}, {value: 'value3', score: 8}], data);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return the intersection of two sets with scores aggregate MIN', function (done) {
 | |
| 			db.getSortedSetIntersect({
 | |
| 				sets: ['interSet1', 'interSet2'],
 | |
| 				start: 0,
 | |
| 				stop: -1,
 | |
| 				withScores: true,
 | |
| 				aggregate: 'MIN'
 | |
| 			}, function (err, data) {
 | |
| 				assert.ifError(err);
 | |
| 				assert.deepEqual([{value: 'value2', score: 2}, {value: 'value3', score: 3}], data);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return the intersection of two sets with scores aggregate MAX', function (done) {
 | |
| 			db.getSortedSetIntersect({
 | |
| 				sets: ['interSet1', 'interSet2'],
 | |
| 				start: 0,
 | |
| 				stop: -1,
 | |
| 				withScores: true,
 | |
| 				aggregate: 'MAX'
 | |
| 			}, function (err, data) {
 | |
| 				assert.ifError(err);
 | |
| 				assert.deepEqual([{value: 'value2', score: 4}, {value: 'value3', score: 5}], data);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return the intersection with scores modified by weights', function (done) {
 | |
| 			db.getSortedSetIntersect({
 | |
| 				sets: ['interSet1', 'interSet2'],
 | |
| 				start: 0,
 | |
| 				stop: -1,
 | |
| 				withScores: true,
 | |
| 				weights: [1, 0.5]
 | |
| 			}, function (err, data) {
 | |
| 				assert.ifError(err);
 | |
| 				assert.deepEqual([{value: 'value2', score: 4}, {value: 'value3', score: 5.5}], data);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return empty array if sets do not exist', function (done) {
 | |
| 			db.getSortedSetIntersect({
 | |
| 				sets: ['interSet10', 'interSet12'],
 | |
| 				start: 0,
 | |
| 				stop: -1
 | |
| 			}, function (err, data) {
 | |
| 				assert.ifError(err);
 | |
| 				assert.equal(data.length, 0);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return empty array if one set does not exist', function (done) {
 | |
| 			db.getSortedSetIntersect({
 | |
| 				sets: ['interSet1', 'interSet12'],
 | |
| 				start: 0,
 | |
| 				stop: -1
 | |
| 			}, function (err, data) {
 | |
| 				assert.ifError(err);
 | |
| 				assert.equal(data.length, 0);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 	});
 | |
| 
 | |
| 	describe('sortedSetIntersectCard', function () {
 | |
| 		before(function (done) {
 | |
| 			async.parallel([
 | |
| 				function (next) {
 | |
| 					db.sortedSetAdd('interCard1', [0, 0, 0], ['value1', 'value2', 'value3'], next);
 | |
| 				},
 | |
| 				function (next) {
 | |
| 					db.sortedSetAdd('interCard2', [0, 0, 0], ['value2', 'value3', 'value4'], next);
 | |
| 				},
 | |
| 				function (next) {
 | |
| 					db.sortedSetAdd('interCard3', [0, 0, 0], ['value3', 'value4', 'value5'], next);
 | |
| 				},
 | |
| 				function (next) {
 | |
| 					db.sortedSetAdd('interCard4', [0, 0, 0], ['value4', 'value5', 'value6'], next);
 | |
| 				}
 | |
| 			], done);
 | |
| 		});
 | |
| 
 | |
| 		it('should return # of elements in intersection', function (done) {
 | |
| 			db.sortedSetIntersectCard(['interCard1', 'interCard2', 'interCard3'], function (err, count) {
 | |
| 				assert.ifError(err);
 | |
| 				assert.strictEqual(count, 1);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		it('should return 0 if intersection is empty', function (done) {
 | |
| 			db.sortedSetIntersectCard(['interCard1', 'interCard4'], function (err, count) {
 | |
| 				assert.ifError(err);
 | |
| 				assert.strictEqual(count, 0);
 | |
| 				done();
 | |
| 			});
 | |
| 		});
 | |
| 	});
 | |
| 
 | |
| 
 | |
| 	after(function (done) {
 | |
| 		db.flushdb(done);
 | |
| 	});
 | |
| });
 |