You've already forked node-redis
mirror of
https://github.com/redis/node-redis.git
synced 2025-08-04 15:02:09 +03:00
Support COMMAND GETKEYSANDFLAGS (#2039)
* Support COMMAND GETKEYSANDFLAGS * Update COMMAND_GETKEYSANDFLAGS.spec.ts remove '.only' * clean code Co-authored-by: leibale <leibale1998@gmail.com>
This commit is contained in:
@@ -48,6 +48,7 @@ import * as CLUSTER_SETSLOT from '../commands/CLUSTER_SETSLOT';
|
|||||||
import * as CLUSTER_SLOTS from '../commands/CLUSTER_SLOTS';
|
import * as CLUSTER_SLOTS from '../commands/CLUSTER_SLOTS';
|
||||||
import * as COMMAND_COUNT from '../commands/COMMAND_COUNT';
|
import * as COMMAND_COUNT from '../commands/COMMAND_COUNT';
|
||||||
import * as COMMAND_GETKEYS from '../commands/COMMAND_GETKEYS';
|
import * as COMMAND_GETKEYS from '../commands/COMMAND_GETKEYS';
|
||||||
|
import * as COMMAND_GETKEYSANDFLAGS from '../commands/COMMAND_GETKEYSANDFLAGS';
|
||||||
import * as COMMAND_INFO from '../commands/COMMAND_INFO';
|
import * as COMMAND_INFO from '../commands/COMMAND_INFO';
|
||||||
import * as COMMAND_LIST from '../commands/COMMAND_LIST';
|
import * as COMMAND_LIST from '../commands/COMMAND_LIST';
|
||||||
import * as COMMAND from '../commands/COMMAND';
|
import * as COMMAND from '../commands/COMMAND';
|
||||||
@@ -199,6 +200,8 @@ export default {
|
|||||||
commandCount: COMMAND_COUNT,
|
commandCount: COMMAND_COUNT,
|
||||||
COMMAND_GETKEYS,
|
COMMAND_GETKEYS,
|
||||||
commandGetKeys: COMMAND_GETKEYS,
|
commandGetKeys: COMMAND_GETKEYS,
|
||||||
|
COMMAND_GETKEYSANDFLAGS,
|
||||||
|
commandGetKeysAndFlags: COMMAND_GETKEYSANDFLAGS,
|
||||||
COMMAND_INFO,
|
COMMAND_INFO,
|
||||||
commandInfo: COMMAND_INFO,
|
commandInfo: COMMAND_INFO,
|
||||||
COMMAND_LIST,
|
COMMAND_LIST,
|
||||||
|
24
packages/client/lib/commands/COMMAND_GETKEYSANDFLAGS.spec.ts
Normal file
24
packages/client/lib/commands/COMMAND_GETKEYSANDFLAGS.spec.ts
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
import { strict as assert } from 'assert';
|
||||||
|
import testUtils, { GLOBAL } from '../test-utils';
|
||||||
|
import { transformArguments } from './COMMAND_GETKEYSANDFLAGS';
|
||||||
|
|
||||||
|
describe('COMMAND GETKEYSANDFLAGS', () => {
|
||||||
|
testUtils.isVersionGreaterThanHook([7, 0]);
|
||||||
|
|
||||||
|
it('transformArguments', () => {
|
||||||
|
assert.deepEqual(
|
||||||
|
transformArguments(['GET', 'key']),
|
||||||
|
['COMMAND', 'GETKEYSANDFLAGS', 'GET', 'key']
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
testUtils.testWithClient('client.commandGetKeysAndFlags', async client => {
|
||||||
|
assert.deepEqual(
|
||||||
|
await client.commandGetKeysAndFlags(['GET', 'key']),
|
||||||
|
[{
|
||||||
|
key: 'key',
|
||||||
|
flags: ['RO', 'access']
|
||||||
|
}]
|
||||||
|
);
|
||||||
|
}, GLOBAL.SERVERS.OPEN);
|
||||||
|
});
|
24
packages/client/lib/commands/COMMAND_GETKEYSANDFLAGS.ts
Normal file
24
packages/client/lib/commands/COMMAND_GETKEYSANDFLAGS.ts
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
import { RedisCommandArgument, RedisCommandArguments } from '.';
|
||||||
|
|
||||||
|
export const IS_READ_ONLY = true;
|
||||||
|
|
||||||
|
export function transformArguments(args: Array<RedisCommandArgument>): RedisCommandArguments {
|
||||||
|
return ['COMMAND', 'GETKEYSANDFLAGS', ...args];
|
||||||
|
}
|
||||||
|
|
||||||
|
type KeysAndFlagsRawReply = Array<[
|
||||||
|
RedisCommandArgument,
|
||||||
|
RedisCommandArguments
|
||||||
|
]>;
|
||||||
|
|
||||||
|
type KeysAndFlagsReply = Array<{
|
||||||
|
key: RedisCommandArgument;
|
||||||
|
flags: RedisCommandArguments;
|
||||||
|
}>;
|
||||||
|
|
||||||
|
export function transformReply(reply: KeysAndFlagsRawReply): KeysAndFlagsReply {
|
||||||
|
return reply.map(([key, flags]) => ({
|
||||||
|
key,
|
||||||
|
flags
|
||||||
|
}));
|
||||||
|
}
|
Reference in New Issue
Block a user