You've already forked node-redis
mirror of
https://github.com/redis/node-redis.git
synced 2025-08-06 02:15:48 +03:00
V5 bringing RESP3, Sentinel and TypeMapping to node-redis
RESP3 Support - Some commands responses in RESP3 aren't stable yet and therefore return an "untyped" ReplyUnion. Sentinel TypeMapping Correctly types Multi commands Note: some API changes to be further documented in v4-to-v5.md
This commit is contained in:
@@ -1,56 +1,62 @@
|
||||
import { strict as assert } from 'assert';
|
||||
import { strict as assert } from 'node:assert';
|
||||
import testUtils, { GLOBAL } from '../test-utils';
|
||||
import { transformArguments, FilterBy } from './COMMAND_LIST';
|
||||
import COMMAND_LIST from './COMMAND_LIST';
|
||||
|
||||
describe('COMMAND LIST', () => {
|
||||
testUtils.isVersionGreaterThanHook([7]);
|
||||
testUtils.isVersionGreaterThanHook([7]);
|
||||
|
||||
describe('transformArguments', () => {
|
||||
it('simple', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments(),
|
||||
['COMMAND', 'LIST']
|
||||
);
|
||||
});
|
||||
|
||||
describe('with FILTERBY', () => {
|
||||
it('MODULE', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments({
|
||||
filterBy: FilterBy.MODULE,
|
||||
value: 'json'
|
||||
}),
|
||||
['COMMAND', 'LIST', 'FILTERBY', 'MODULE', 'json']
|
||||
);
|
||||
});
|
||||
|
||||
it('ACLCAT', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments({
|
||||
filterBy: FilterBy.ACLCAT,
|
||||
value: 'admin'
|
||||
}),
|
||||
['COMMAND', 'LIST', 'FILTERBY', 'ACLCAT', 'admin']
|
||||
);
|
||||
});
|
||||
|
||||
it('PATTERN', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments({
|
||||
filterBy: FilterBy.PATTERN,
|
||||
value: 'a*'
|
||||
}),
|
||||
['COMMAND', 'LIST', 'FILTERBY', 'PATTERN', 'a*']
|
||||
);
|
||||
});
|
||||
});
|
||||
describe('transformArguments', () => {
|
||||
it('simple', () => {
|
||||
assert.deepEqual(
|
||||
COMMAND_LIST.transformArguments(),
|
||||
['COMMAND', 'LIST']
|
||||
);
|
||||
});
|
||||
|
||||
testUtils.testWithClient('client.commandList', async client => {
|
||||
const commandList = await client.commandList();
|
||||
assert.ok(Array.isArray(commandList));
|
||||
for (const command of commandList) {
|
||||
assert.ok(typeof command === 'string');
|
||||
}
|
||||
}, GLOBAL.SERVERS.OPEN);
|
||||
describe('with FILTERBY', () => {
|
||||
it('MODULE', () => {
|
||||
assert.deepEqual(
|
||||
COMMAND_LIST.transformArguments({
|
||||
FILTERBY: {
|
||||
type: 'MODULE',
|
||||
value: 'JSON'
|
||||
}
|
||||
}),
|
||||
['COMMAND', 'LIST', 'FILTERBY', 'MODULE', 'JSON']
|
||||
);
|
||||
});
|
||||
|
||||
it('ACLCAT', () => {
|
||||
assert.deepEqual(
|
||||
COMMAND_LIST.transformArguments({
|
||||
FILTERBY: {
|
||||
type: 'ACLCAT',
|
||||
value: 'admin'
|
||||
}
|
||||
}),
|
||||
['COMMAND', 'LIST', 'FILTERBY', 'ACLCAT', 'admin']
|
||||
);
|
||||
});
|
||||
|
||||
it('PATTERN', () => {
|
||||
assert.deepEqual(
|
||||
COMMAND_LIST.transformArguments({
|
||||
FILTERBY: {
|
||||
type: 'PATTERN',
|
||||
value: 'a*'
|
||||
}
|
||||
}),
|
||||
['COMMAND', 'LIST', 'FILTERBY', 'PATTERN', 'a*']
|
||||
);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
testUtils.testWithClient('client.commandList', async client => {
|
||||
const commandList = await client.commandList();
|
||||
assert.ok(Array.isArray(commandList));
|
||||
for (const command of commandList) {
|
||||
assert.ok(typeof command === 'string');
|
||||
}
|
||||
}, GLOBAL.SERVERS.OPEN);
|
||||
});
|
||||
|
Reference in New Issue
Block a user