You've already forked node-redis
mirror of
https://github.com/redis/node-redis.git
synced 2025-08-10 11:43:01 +03:00
* update workflows & README
* add .deepsource.toml
* fix client.quit, add error events on cluster, fix some "deepsource.io" warnings
* Release 4.0.0-rc.1
* add cluster.duplicate, add some tests
* fix #1650 - add support for Buffer in some commands, add GET_BUFFER command
* fix GET and GET_BUFFER return type
* update FAQ
* Update invalid code example in README.md (#1654)
* Update invalid code example in README.md
* Update README.md
Co-authored-by: Leibale Eidelman <leibale1998@gmail.com>
* fix #1652
* ref #1653 - better types
* better types
* fix 54124793ad
* Update GEOSEARCHSTORE.spec.ts
* fix #1660 - add support for client.HSET('key', 'field', 'value')
* upgrade dependencies, update README
* fix #1659 - add support for db-number in client options url
* fix README, remove unused import, downgrade typedoc & typedoc-plugin-markdown
* update client-configurations.md
* fix README
* add CLUSTER_SLOTS, add some tests
* fix "createClient with url" test with redis 5
* remove unused imports
* Release 4.0.0-rc.2
Co-authored-by: Richard Samuelsson <noobtoothfairy@gmail.com>
127 lines
3.5 KiB
TypeScript
127 lines
3.5 KiB
TypeScript
import { strict as assert } from 'assert';
|
|
import RedisMultiCommand from './multi-command';
|
|
import { WatchError } from './errors';
|
|
import { spy } from 'sinon';
|
|
import { SQUARE_SCRIPT } from './client.spec';
|
|
|
|
describe('Multi Command', () => {
|
|
describe('exec', () => {
|
|
it('simple', async () => {
|
|
const multi = RedisMultiCommand.create((queue, symbol) => {
|
|
assert.deepEqual(
|
|
queue.map(({ args }) => args),
|
|
[
|
|
['MULTI'],
|
|
['PING'],
|
|
['EXEC'],
|
|
]
|
|
);
|
|
|
|
assert.equal(
|
|
typeof symbol,
|
|
'symbol'
|
|
);
|
|
|
|
return Promise.resolve(['QUEUED', 'QUEUED', ['PONG']]);
|
|
});
|
|
|
|
multi.ping();
|
|
|
|
assert.deepEqual(
|
|
await multi.exec(),
|
|
['PONG']
|
|
);
|
|
});
|
|
|
|
it('executing an empty queue should resolve without executing on the server', async () => {
|
|
const executor = spy();
|
|
|
|
assert.deepEqual(
|
|
await RedisMultiCommand.create(executor).exec(),
|
|
[]
|
|
);
|
|
|
|
assert.ok(executor.notCalled);
|
|
});
|
|
|
|
it('WatchError', () => {
|
|
return assert.rejects(
|
|
RedisMultiCommand.create(() => Promise.resolve([null])).ping().exec(),
|
|
WatchError
|
|
);
|
|
});
|
|
|
|
it('execAsPipeline', async () => {
|
|
const multi = RedisMultiCommand.create(queue => {
|
|
assert.deepEqual(
|
|
queue.map(({ args }) => args),
|
|
[['PING']]
|
|
);
|
|
|
|
return Promise.resolve(['PONG']);
|
|
});
|
|
|
|
multi.ping();
|
|
|
|
assert.deepEqual(
|
|
await multi.exec(true),
|
|
['PONG']
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('execAsPipeline', () => {
|
|
it('simple', async () => {
|
|
const multi = RedisMultiCommand.create(queue => {
|
|
assert.deepEqual(
|
|
queue.map(({ args }) => args),
|
|
[['PING']]
|
|
);
|
|
|
|
return Promise.resolve(['PONG']);
|
|
});
|
|
|
|
multi.ping();
|
|
|
|
assert.deepEqual(
|
|
await multi.execAsPipeline(),
|
|
['PONG']
|
|
);
|
|
});
|
|
|
|
it('executing an empty queue should resolve without executing on the server', async () => {
|
|
const executor = spy();
|
|
|
|
assert.deepEqual(
|
|
await RedisMultiCommand.create(executor).execAsPipeline(),
|
|
[]
|
|
);
|
|
|
|
assert.ok(executor.notCalled);
|
|
});
|
|
|
|
it('with scripts', async () => {
|
|
const MultiWithScript = RedisMultiCommand.extend({
|
|
scripts: {
|
|
square: SQUARE_SCRIPT
|
|
}
|
|
});
|
|
|
|
assert.deepEqual(
|
|
await new MultiWithScript(queue => {
|
|
assert.deepEqual(
|
|
queue.map(({ args }) => args),
|
|
[
|
|
['EVAL', SQUARE_SCRIPT.SCRIPT, '0', '2'],
|
|
['EVALSHA', SQUARE_SCRIPT.SHA1, '0', '3'],
|
|
]
|
|
);
|
|
|
|
return Promise.resolve([4, 9]);
|
|
}).square(2).square(3).execAsPipeline(),
|
|
[4, 9]
|
|
);
|
|
});
|
|
});
|
|
});
|