You've already forked node-redis
mirror of
https://github.com/redis/node-redis.git
synced 2025-08-06 02:15:48 +03:00
JSON commands
This commit is contained in:
@@ -1,19 +1,19 @@
|
|||||||
import { strict as assert } from 'assert';
|
import { strict as assert } from 'assert';
|
||||||
import testUtils, { GLOBAL } from '../test-utils';
|
import testUtils, { GLOBAL } from '../test-utils';
|
||||||
import { transformArguments } from './ARRINSERT';
|
import ARRINSERT from './ARRINSERT';
|
||||||
|
|
||||||
describe('ARRINSERT', () => {
|
describe('ARRINSERT', () => {
|
||||||
describe('transformArguments', () => {
|
describe('transformArguments', () => {
|
||||||
it('single JSON', () => {
|
it('single JSON', () => {
|
||||||
assert.deepEqual(
|
assert.deepEqual(
|
||||||
transformArguments('key', '$', 0, 'json'),
|
ARRINSERT.transformArguments('key', '$', 0, 'json'),
|
||||||
['JSON.ARRINSERT', 'key', '$', '0', '"json"']
|
['JSON.ARRINSERT', 'key', '$', '0', '"json"']
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('multiple JSONs', () => {
|
it('multiple JSONs', () => {
|
||||||
assert.deepEqual(
|
assert.deepEqual(
|
||||||
transformArguments('key', '$', 0, '1', '2'),
|
ARRINSERT.transformArguments('key', '$', 0, '1', '2'),
|
||||||
['JSON.ARRINSERT', 'key', '$', '0', '"1"', '"2"']
|
['JSON.ARRINSERT', 'key', '$', '0', '"1"', '"2"']
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
@@ -1,8 +1,10 @@
|
|||||||
|
import { RedisArgument, ArrayReply, NumberReply, NullReply, Command } from '@redis/client/dist/lib/RESP/types';
|
||||||
import { RedisJSON, transformRedisJsonArgument } from '.';
|
import { RedisJSON, transformRedisJsonArgument } from '.';
|
||||||
|
|
||||||
export const FIRST_KEY_INDEX = 1;
|
export default {
|
||||||
|
FIRST_KEY_INDEX: 1,
|
||||||
export function transformArguments(key: string, path: string, index: number, ...jsons: Array<RedisJSON>): Array<string> {
|
IS_READ_ONLY: false,
|
||||||
|
transformArguments(key: RedisArgument, path: RedisArgument, index: number, ...jsons: Array<RedisJSON>) {
|
||||||
const args = ['JSON.ARRINSERT', key, path, index.toString()];
|
const args = ['JSON.ARRINSERT', key, path, index.toString()];
|
||||||
|
|
||||||
for (const json of jsons) {
|
for (const json of jsons) {
|
||||||
@@ -10,6 +12,6 @@ export function transformArguments(key: string, path: string, index: number, ...
|
|||||||
}
|
}
|
||||||
|
|
||||||
return args;
|
return args;
|
||||||
}
|
},
|
||||||
|
transformReply: undefined as unknown as () => NumberReply | NullReply | ArrayReply<NumberReply | NullReply>
|
||||||
export declare function transformReply(): number | Array<number>;
|
} as const satisfies Command;
|
||||||
|
@@ -1,19 +1,19 @@
|
|||||||
import { strict as assert } from 'assert';
|
import { strict as assert } from 'assert';
|
||||||
import testUtils, { GLOBAL } from '../test-utils';
|
import testUtils, { GLOBAL } from '../test-utils';
|
||||||
import { transformArguments } from './ARRLEN';
|
import ARRLEN from './ARRLEN';
|
||||||
|
|
||||||
describe('ARRLEN', () => {
|
describe('ARRLEN', () => {
|
||||||
describe('transformArguments', () => {
|
describe('transformArguments', () => {
|
||||||
it('without path', () => {
|
it('without path', () => {
|
||||||
assert.deepEqual(
|
assert.deepEqual(
|
||||||
transformArguments('key'),
|
ARRLEN.transformArguments('key'),
|
||||||
['JSON.ARRLEN', 'key']
|
['JSON.ARRLEN', 'key']
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('with path', () => {
|
it('with path', () => {
|
||||||
assert.deepEqual(
|
assert.deepEqual(
|
||||||
transformArguments('key', '$'),
|
ARRLEN.transformArguments('key', '$'),
|
||||||
['JSON.ARRLEN', 'key', '$']
|
['JSON.ARRLEN', 'key', '$']
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
@@ -1,8 +1,9 @@
|
|||||||
export const FIRST_KEY_INDEX = 1;
|
import { RedisArgument, ArrayReply, NumberReply, NullReply, Command } from '@redis/client/dist/lib/RESP/types';
|
||||||
|
|
||||||
export const IS_READ_ONLY = true;
|
export default {
|
||||||
|
FIRST_KEY_INDEX: 1,
|
||||||
export function transformArguments(key: string, path?: string): Array<string> {
|
IS_READ_ONLY: true,
|
||||||
|
transformArguments(key: RedisArgument, path?: RedisArgument) {
|
||||||
const args = ['JSON.ARRLEN', key];
|
const args = ['JSON.ARRLEN', key];
|
||||||
|
|
||||||
if (path) {
|
if (path) {
|
||||||
@@ -10,6 +11,6 @@ export function transformArguments(key: string, path?: string): Array<string> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return args;
|
return args;
|
||||||
}
|
},
|
||||||
|
transformReply: undefined as unknown as () => NumberReply | NullReply | ArrayReply<NumberReply | NullReply>
|
||||||
export declare function transformReply(): number | Array<number>;
|
} as const satisfies Command;
|
||||||
|
@@ -1,11 +1,11 @@
|
|||||||
import { strict as assert } from 'assert';
|
import { strict as assert } from 'assert';
|
||||||
import testUtils, { GLOBAL } from '../test-utils';
|
import testUtils, { GLOBAL } from '../test-utils';
|
||||||
import { transformArguments } from './ARRTRIM';
|
import ARRTRIM from './ARRTRIM';
|
||||||
|
|
||||||
describe('ARRTRIM', () => {
|
describe('ARRTRIM', () => {
|
||||||
it('transformArguments', () => {
|
it('transformArguments', () => {
|
||||||
assert.deepEqual(
|
assert.deepEqual(
|
||||||
transformArguments('key', '$', 0, 1),
|
ARRTRIM.transformArguments('key', '$', 0, 1),
|
||||||
['JSON.ARRTRIM', 'key', '$', '0', '1']
|
['JSON.ARRTRIM', 'key', '$', '0', '1']
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
@@ -1,7 +1,10 @@
|
|||||||
export const FIRST_KEY_INDEX = 1;
|
import { RedisArgument, ArrayReply, NumberReply, NullReply, Command } from '@redis/client/dist/lib/RESP/types';
|
||||||
|
|
||||||
export function transformArguments(key: string, path: string, start: number, stop: number): Array<string> {
|
export default {
|
||||||
|
FIRST_KEY_INDEX: 1,
|
||||||
|
IS_READ_ONLY: false,
|
||||||
|
transformArguments(key: RedisArgument, path: RedisArgument, start: number, stop: number) {
|
||||||
return ['JSON.ARRTRIM', key, path, start.toString(), stop.toString()];
|
return ['JSON.ARRTRIM', key, path, start.toString(), stop.toString()];
|
||||||
}
|
},
|
||||||
|
transformReply: undefined as unknown as () => NumberReply | NullReply | ArrayReply<NumberReply | NullReply>
|
||||||
export declare function transformReply(): number | Array<number>;
|
} as const satisfies Command;
|
||||||
|
@@ -1,19 +1,19 @@
|
|||||||
import { strict as assert } from 'assert';
|
import { strict as assert } from 'assert';
|
||||||
import testUtils, { GLOBAL } from '../test-utils';
|
import testUtils, { GLOBAL } from '../test-utils';
|
||||||
import { transformArguments } from './OBJLEN';
|
import OBJLEN from './OBJLEN';
|
||||||
|
|
||||||
describe('OBJLEN', () => {
|
describe('OBJLEN', () => {
|
||||||
describe('transformArguments', () => {
|
describe('transformArguments', () => {
|
||||||
it('without path', () => {
|
it('without path', () => {
|
||||||
assert.deepEqual(
|
assert.deepEqual(
|
||||||
transformArguments('key'),
|
OBJLEN.transformArguments('key'),
|
||||||
['JSON.OBJLEN', 'key']
|
['JSON.OBJLEN', 'key']
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('with path', () => {
|
it('with path', () => {
|
||||||
assert.deepEqual(
|
assert.deepEqual(
|
||||||
transformArguments('key', '$'),
|
OBJLEN.transformArguments('key', '$'),
|
||||||
['JSON.OBJLEN', 'key', '$']
|
['JSON.OBJLEN', 'key', '$']
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
@@ -1,6 +1,9 @@
|
|||||||
export const FIRST_KEY_INDEX = 1;
|
import { RedisArgument, ArrayReply, NumberReply, NullReply, Command } from '@redis/client/dist/lib/RESP/types';
|
||||||
|
|
||||||
export function transformArguments(key: string, path?: string): Array<string> {
|
export default {
|
||||||
|
FIRST_KEY_INDEX: 1,
|
||||||
|
IS_READ_ONLY: false,
|
||||||
|
transformArguments(key: RedisArgument, path?: RedisArgument) {
|
||||||
const args = ['JSON.OBJLEN', key];
|
const args = ['JSON.OBJLEN', key];
|
||||||
|
|
||||||
if (path) {
|
if (path) {
|
||||||
@@ -8,6 +11,6 @@ export function transformArguments(key: string, path?: string): Array<string> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return args;
|
return args;
|
||||||
}
|
},
|
||||||
|
transformReply: undefined as unknown as () => NumberReply | NullReply | ArrayReply<NumberReply | NullReply>
|
||||||
export declare function transformReply(): number | null | Array<number | null>;
|
} as const satisfies Command;
|
||||||
|
@@ -1,30 +1,30 @@
|
|||||||
import { strict as assert } from 'assert';
|
// import { strict as assert } from 'assert';
|
||||||
import testUtils, { GLOBAL } from '../test-utils';
|
// import testUtils, { GLOBAL } from '../test-utils';
|
||||||
import { transformArguments } from './STRAPPEND';
|
// import { transformArguments } from './STRAPPEND';
|
||||||
|
|
||||||
describe('STRAPPEND', () => {
|
// describe('STRAPPEND', () => {
|
||||||
describe('transformArguments', () => {
|
// describe('transformArguments', () => {
|
||||||
it('without path', () => {
|
// it('without path', () => {
|
||||||
assert.deepEqual(
|
// assert.deepEqual(
|
||||||
transformArguments('key', 'append'),
|
// transformArguments('key', 'append'),
|
||||||
['JSON.STRAPPEND', 'key', '"append"']
|
// ['JSON.STRAPPEND', 'key', '"append"']
|
||||||
);
|
// );
|
||||||
});
|
// });
|
||||||
|
|
||||||
it('with path', () => {
|
// it('with path', () => {
|
||||||
assert.deepEqual(
|
// assert.deepEqual(
|
||||||
transformArguments('key', '$', 'append'),
|
// transformArguments('key', '$', 'append'),
|
||||||
['JSON.STRAPPEND', 'key', '$', '"append"']
|
// ['JSON.STRAPPEND', 'key', '$', '"append"']
|
||||||
);
|
// );
|
||||||
});
|
// });
|
||||||
});
|
// });
|
||||||
|
|
||||||
testUtils.testWithClient('client.json.strAppend', async client => {
|
// testUtils.testWithClient('client.json.strAppend', async client => {
|
||||||
await client.json.set('key', '$', '');
|
// await client.json.set('key', '$', '');
|
||||||
|
|
||||||
assert.deepEqual(
|
// assert.deepEqual(
|
||||||
await client.json.strAppend('key', '$', 'append'),
|
// await client.json.strAppend('key', '$', 'append'),
|
||||||
[6]
|
// [6]
|
||||||
);
|
// );
|
||||||
}, GLOBAL.SERVERS.OPEN);
|
// }, GLOBAL.SERVERS.OPEN);
|
||||||
});
|
// });
|
||||||
|
@@ -1,21 +1,21 @@
|
|||||||
import { transformRedisJsonArgument } from '.';
|
// import { transformRedisJsonArgument } from '.';
|
||||||
|
|
||||||
export const FIRST_KEY_INDEX = 1;
|
// export const FIRST_KEY_INDEX = 1;
|
||||||
|
|
||||||
type AppendArguments = [key: string, append: string];
|
// type AppendArguments = [key: string, append: string];
|
||||||
|
|
||||||
type AppendWithPathArguments = [key: string, path: string, append: string];
|
// type AppendWithPathArguments = [key: string, path: string, append: string];
|
||||||
|
|
||||||
export function transformArguments(...[key, pathOrAppend, append]: AppendArguments | AppendWithPathArguments): Array<string> {
|
// export function transformArguments(...[key, pathOrAppend, append]: AppendArguments | AppendWithPathArguments): Array<string> {
|
||||||
const args = ['JSON.STRAPPEND', key];
|
// const args = ['JSON.STRAPPEND', key];
|
||||||
|
|
||||||
if (append !== undefined && append !== null) {
|
// if (append !== undefined && append !== null) {
|
||||||
args.push(pathOrAppend, transformRedisJsonArgument(append));
|
// args.push(pathOrAppend, transformRedisJsonArgument(append));
|
||||||
} else {
|
// } else {
|
||||||
args.push(transformRedisJsonArgument(pathOrAppend));
|
// args.push(transformRedisJsonArgument(pathOrAppend));
|
||||||
}
|
// }
|
||||||
|
|
||||||
return args;
|
// return args;
|
||||||
}
|
// }
|
||||||
|
|
||||||
export declare function transformReply(): number | Array<number>;
|
// export declare function transformReply(): number | Array<number>;
|
||||||
|
@@ -1,19 +1,19 @@
|
|||||||
import { strict as assert } from 'assert';
|
import { strict as assert } from 'assert';
|
||||||
import testUtils, { GLOBAL } from '../test-utils';
|
import testUtils, { GLOBAL } from '../test-utils';
|
||||||
import { transformArguments } from './STRLEN';
|
import STRLEN from './STRLEN';
|
||||||
|
|
||||||
describe('STRLEN', () => {
|
describe('STRLEN', () => {
|
||||||
describe('transformArguments', () => {
|
describe('transformArguments', () => {
|
||||||
it('without path', () => {
|
it('without path', () => {
|
||||||
assert.deepEqual(
|
assert.deepEqual(
|
||||||
transformArguments('key'),
|
STRLEN.transformArguments('key'),
|
||||||
['JSON.STRLEN', 'key']
|
['JSON.STRLEN', 'key']
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('with path', () => {
|
it('with path', () => {
|
||||||
assert.deepEqual(
|
assert.deepEqual(
|
||||||
transformArguments('key', '$'),
|
STRLEN.transformArguments('key', '$'),
|
||||||
['JSON.STRLEN', 'key', '$']
|
['JSON.STRLEN', 'key', '$']
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
@@ -1,8 +1,9 @@
|
|||||||
export const FIRST_KEY_INDEX = 1;
|
import { RedisArgument, ArrayReply, NumberReply, NullReply, Command } from '@redis/client/dist/lib/RESP/types';
|
||||||
|
|
||||||
export const IS_READ_ONLY = true;
|
export default {
|
||||||
|
FIRST_KEY_INDEX: 1,
|
||||||
export function transformArguments(key: string, path?: string): Array<string> {
|
IS_READ_ONLY: false,
|
||||||
|
transformArguments(key: RedisArgument, path?: RedisArgument) {
|
||||||
const args = ['JSON.STRLEN', key];
|
const args = ['JSON.STRLEN', key];
|
||||||
|
|
||||||
if (path) {
|
if (path) {
|
||||||
@@ -10,6 +11,6 @@ export function transformArguments(key: string, path?: string): Array<string> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return args;
|
return args;
|
||||||
}
|
},
|
||||||
|
transformReply: undefined as unknown as () => NumberReply | NullReply | ArrayReply<NumberReply | NullReply>
|
||||||
export declare function transformReply(): number;
|
} as const satisfies Command;
|
||||||
|
30
packages/json/lib/commands/TOGGLE.spec.ts
Normal file
30
packages/json/lib/commands/TOGGLE.spec.ts
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
import { strict as assert } from 'assert';
|
||||||
|
import testUtils, { GLOBAL } from '../test-utils';
|
||||||
|
import TOGGLE from './TOGGLE';
|
||||||
|
|
||||||
|
describe('TOGGLE', () => {
|
||||||
|
describe('transformArguments', () => {
|
||||||
|
it('without path', () => {
|
||||||
|
assert.deepEqual(
|
||||||
|
TOGGLE.transformArguments('key'),
|
||||||
|
['JSON.TOGGLE', 'key']
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('with path', () => {
|
||||||
|
assert.deepEqual(
|
||||||
|
TOGGLE.transformArguments('key', '$'),
|
||||||
|
['JSON.TOGGLE', 'key', '$']
|
||||||
|
);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
testUtils.testWithClient('client.json.toggle', async client => {
|
||||||
|
await client.json.set('key', '$', '');
|
||||||
|
|
||||||
|
assert.deepEqual(
|
||||||
|
await client.json.toggle('key', '$'),
|
||||||
|
[0]
|
||||||
|
);
|
||||||
|
}, GLOBAL.SERVERS.OPEN);
|
||||||
|
});
|
14
packages/json/lib/commands/TOGGLE.ts
Normal file
14
packages/json/lib/commands/TOGGLE.ts
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
import { RedisArgument, ArrayReply, NumberReply, NullReply, Command, } from '@redis/client/dist/lib/RESP/types';
|
||||||
|
|
||||||
|
export default {
|
||||||
|
FIRST_KEY_INDEX: undefined,
|
||||||
|
IS_READ_ONLY: false,
|
||||||
|
transformArguments(key: RedisArgument, path?: RedisArgument) {
|
||||||
|
const args = ['JSON.TOGGLE', key]
|
||||||
|
|
||||||
|
if (path) args.push(path);
|
||||||
|
|
||||||
|
return args;
|
||||||
|
},
|
||||||
|
transformReply: undefined as unknown as () => NumberReply | NullReply | ArrayReply<NumberReply | NullReply>
|
||||||
|
} as const satisfies Command;
|
Reference in New Issue
Block a user