1
0
mirror of https://github.com/redis/node-redis.git synced 2025-08-10 11:43:01 +03:00
Files
node-redis/lib/multi-command.spec.ts
Leibale Eidelman e592d9403d v4.0.0-rc.2 (#1664)
* 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>
2021-09-23 16:36:40 -04:00

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]
);
});
});
});