1
0
mirror of https://github.com/redis/node-redis.git synced 2025-08-06 02:15:48 +03:00
This commit is contained in:
Leibale
2023-10-23 15:05:16 -04:00
parent 42b05b025b
commit 817818aa91
29 changed files with 628 additions and 854 deletions

View File

@@ -1,56 +1,62 @@
// import { strict as assert } from 'node:assert';
// import testUtils, { GLOBAL } from '../test-utils';
// import { transformArguments, FilterBy } from './COMMAND_LIST';
import { strict as assert } from 'node:assert';
import testUtils, { GLOBAL } from '../test-utils';
import COMMAND_LIST from './COMMAND_LIST';
// describe('COMMAND LIST', () => {
// testUtils.isVersionGreaterThanHook([7]);
describe('COMMAND LIST', () => {
testUtils.isVersionGreaterThanHook([7]);
// describe('transformArguments', () => {
// it('simple', () => {
// assert.deepEqual(
// transformArguments(),
// ['COMMAND', 'LIST']
// );
// });
describe('transformArguments', () => {
it('simple', () => {
assert.deepEqual(
COMMAND_LIST.transformArguments(),
['COMMAND', 'LIST']
);
});
// describe('with FILTERBY', () => {
// it('MODULE', () => {
// assert.deepEqual(
// transformArguments({
// filterBy: FilterBy.MODULE,
// value: 'json'
// }),
// ['COMMAND', 'LIST', 'FILTERBY', 'MODULE', 'json']
// );
// });
describe('with FILTERBY', () => {
it('MODULE', () => {
assert.deepEqual(
COMMAND_LIST.transformArguments({
FILTERBY: {
type: 'MODULE',
value: 'JSON'
}
}),
['COMMAND', 'LIST', 'FILTERBY', 'MODULE', 'JSON']
);
});
// it('ACLCAT', () => {
// assert.deepEqual(
// transformArguments({
// filterBy: FilterBy.ACLCAT,
// value: 'admin'
// }),
// ['COMMAND', 'LIST', 'FILTERBY', 'ACLCAT', 'admin']
// );
// });
it('ACLCAT', () => {
assert.deepEqual(
COMMAND_LIST.transformArguments({
FILTERBY: {
type: 'ACLCAT',
value: 'admin'
}
}),
['COMMAND', 'LIST', 'FILTERBY', 'ACLCAT', 'admin']
);
});
// it('PATTERN', () => {
// assert.deepEqual(
// transformArguments({
// filterBy: FilterBy.PATTERN,
// value: 'a*'
// }),
// ['COMMAND', 'LIST', 'FILTERBY', 'PATTERN', 'a*']
// );
// });
// });
// });
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);
// });
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);
});

View File

@@ -1,31 +1,35 @@
// import { RedisCommandArguments } from '.';
import { RedisArgument, ArrayReply, BlobStringReply, Command } from '../RESP/types';
// export const IS_READ_ONLY = true;
export const COMMAND_LIST_FILTER_BY = {
MODULE: 'MODULE',
ACLCAT: 'ACLCAT',
PATTERN: 'PATTERN'
} as const;
// export enum FilterBy {
// MODULE = 'MODULE',
// ACLCAT = 'ACLCAT',
// PATTERN = 'PATTERN'
// }
export type CommandListFilterBy = typeof COMMAND_LIST_FILTER_BY[keyof typeof COMMAND_LIST_FILTER_BY];
// interface Filter {
// filterBy: FilterBy;
// value: string;
// }
export interface CommandListOptions {
FILTERBY?: {
type: CommandListFilterBy;
value: RedisArgument;
};
}
export default {
FIRST_KEY_INDEX: undefined,
IS_READ_ONLY: true,
transformArguments(options?: CommandListOptions) {
const args: Array<RedisArgument> = ['COMMAND', 'LIST'];
// export function transformArguments(filter?: Filter): RedisCommandArguments {
// const args = ['COMMAND', 'LIST'];
if (options?.FILTERBY) {
args.push(
'FILTERBY',
options.FILTERBY.type,
options.FILTERBY.value
);
}
// if (filter) {
// args.push(
// 'FILTERBY',
// filter.filterBy,
// filter.value
// );
// }
// return args;
// }
// export declare function transformReply(): Array<string>;
return args;
},
transformReply: undefined as unknown as () => ArrayReply<BlobStringReply>
} as const satisfies Command;

View File

@@ -2,7 +2,7 @@ import { RedisArgument, Command } from '../RESP/types';
import { transformSortedSetReply } from './generic-transformers';
export default {
FIRST_KEY_INDEX: undefined,
FIRST_KEY_INDEX: 1,
IS_READ_ONLY: false,
transformArguments(key: RedisArgument, count: number) {
return ['ZPOPMIN', key, count.toString()];

View File

@@ -73,7 +73,7 @@ import COMMAND_COUNT from './COMMAND_COUNT';
import COMMAND_GETKEYS from './COMMAND_GETKEYS';
import COMMAND_GETKEYSANDFLAGS from './COMMAND_GETKEYSANDFLAGS';
// import COMMAND_INFO from './COMMAND_INFO';
// import COMMAND_LIST from './COMMAND_LIST';
import COMMAND_LIST from './COMMAND_LIST';
// import COMMAND from './COMMAND';
import CONFIG_GET from './CONFIG_GET';
import CONFIG_RESETASTAT from './CONFIG_RESETSTAT';
@@ -483,8 +483,8 @@ export default {
commandGetKeysAndFlags: COMMAND_GETKEYSANDFLAGS,
// COMMAND_INFO,
// commandInfo: COMMAND_INFO,
// COMMAND_LIST,
// commandList: COMMAND_LIST,
COMMAND_LIST,
commandList: COMMAND_LIST,
// COMMAND,
// command: COMMAND,
CONFIG_GET,