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,50 +1,50 @@
|
||||
import { strict as assert } from 'assert';
|
||||
import { strict as assert } from 'node:assert';
|
||||
import testUtils, { GLOBAL } from '../../test-utils';
|
||||
import { transformArguments, transformReply } from './MERGE';
|
||||
import MERGE from './MERGE';
|
||||
|
||||
describe('TDIGEST.MERGE', () => {
|
||||
describe('transformArguments', () => {
|
||||
describe('srcKeys', () => {
|
||||
it('string', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments('dest', 'src'),
|
||||
['TDIGEST.MERGE', 'dest', '1', 'src']
|
||||
);
|
||||
});
|
||||
describe('transformArguments', () => {
|
||||
describe('source', () => {
|
||||
it('string', () => {
|
||||
assert.deepEqual(
|
||||
MERGE.transformArguments('destination', 'source'),
|
||||
['TDIGEST.MERGE', 'destination', '1', 'source']
|
||||
);
|
||||
});
|
||||
|
||||
it('Array', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments('dest', ['1', '2']),
|
||||
['TDIGEST.MERGE', 'dest', '2', '1', '2']
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
it('with COMPRESSION', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments('dest', 'src', {
|
||||
COMPRESSION: 100
|
||||
}),
|
||||
['TDIGEST.MERGE', 'dest', '1', 'src', 'COMPRESSION', '100']
|
||||
);
|
||||
});
|
||||
|
||||
it('with OVERRIDE', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments('dest', 'src', {
|
||||
OVERRIDE: true
|
||||
}),
|
||||
['TDIGEST.MERGE', 'dest', '1', 'src', 'OVERRIDE']
|
||||
);
|
||||
});
|
||||
it('Array', () => {
|
||||
assert.deepEqual(
|
||||
MERGE.transformArguments('destination', ['1', '2']),
|
||||
['TDIGEST.MERGE', 'destination', '2', '1', '2']
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
testUtils.testWithClient('client.tDigest.merge', async client => {
|
||||
const [ , reply ] = await Promise.all([
|
||||
client.tDigest.create('src'),
|
||||
client.tDigest.merge('dest', 'src')
|
||||
]);
|
||||
it('with COMPRESSION', () => {
|
||||
assert.deepEqual(
|
||||
MERGE.transformArguments('destination', 'source', {
|
||||
COMPRESSION: 100
|
||||
}),
|
||||
['TDIGEST.MERGE', 'destination', '1', 'source', 'COMPRESSION', '100']
|
||||
);
|
||||
});
|
||||
|
||||
assert.equal(reply, 'OK');
|
||||
}, GLOBAL.SERVERS.OPEN);
|
||||
it('with OVERRIDE', () => {
|
||||
assert.deepEqual(
|
||||
MERGE.transformArguments('destination', 'source', {
|
||||
OVERRIDE: true
|
||||
}),
|
||||
['TDIGEST.MERGE', 'destination', '1', 'source', 'OVERRIDE']
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
testUtils.testWithClient('client.tDigest.merge', async client => {
|
||||
const [, reply] = await Promise.all([
|
||||
client.tDigest.create('source'),
|
||||
client.tDigest.merge('destination', 'source')
|
||||
]);
|
||||
|
||||
assert.equal(reply, 'OK');
|
||||
}, GLOBAL.SERVERS.OPEN);
|
||||
});
|
||||
|
Reference in New Issue
Block a user