You've already forked node-redis
mirror of
https://github.com/redis/node-redis.git
synced 2025-08-06 02:15:48 +03:00
WIP
This commit is contained in:
@@ -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);
|
||||
});
|
||||
|
@@ -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;
|
||||
|
@@ -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()];
|
||||
|
@@ -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,
|
||||
|
Reference in New Issue
Block a user