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,90 +1,93 @@
|
||||
import { strict as assert } from 'assert';
|
||||
import { strict as assert } from 'node:assert';
|
||||
import testUtils, { GLOBAL } from '../test-utils';
|
||||
import { transformArguments } from './ADD';
|
||||
import { TimeSeriesDuplicatePolicies, TimeSeriesEncoding } from '.';
|
||||
import ADD from './ADD';
|
||||
import { TIME_SERIES_ENCODING, TIME_SERIES_DUPLICATE_POLICIES } from '.';
|
||||
|
||||
describe('ADD', () => {
|
||||
describe('transformArguments', () => {
|
||||
it('without options', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments('key', '*', 1),
|
||||
['TS.ADD', 'key', '*', '1']
|
||||
);
|
||||
});
|
||||
|
||||
it('with RETENTION', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments('key', '*', 1, {
|
||||
RETENTION: 1
|
||||
}),
|
||||
['TS.ADD', 'key', '*', '1', 'RETENTION', '1']
|
||||
);
|
||||
});
|
||||
|
||||
it('with ENCODING', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments('key', '*', 1, {
|
||||
ENCODING: TimeSeriesEncoding.UNCOMPRESSED
|
||||
}),
|
||||
['TS.ADD', 'key', '*', '1', 'ENCODING', 'UNCOMPRESSED']
|
||||
);
|
||||
});
|
||||
|
||||
it('with CHUNK_SIZE', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments('key', '*', 1, {
|
||||
CHUNK_SIZE: 1
|
||||
}),
|
||||
['TS.ADD', 'key', '*', '1', 'CHUNK_SIZE', '1']
|
||||
);
|
||||
});
|
||||
|
||||
it('with ON_DUPLICATE', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments('key', '*', 1, {
|
||||
ON_DUPLICATE: TimeSeriesDuplicatePolicies.BLOCK
|
||||
}),
|
||||
['TS.ADD', 'key', '*', '1', 'ON_DUPLICATE', 'BLOCK']
|
||||
);
|
||||
});
|
||||
|
||||
it('with LABELS', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments('key', '*', 1, {
|
||||
LABELS: { label: 'value' }
|
||||
}),
|
||||
['TS.ADD', 'key', '*', '1', 'LABELS', 'label', 'value']
|
||||
);
|
||||
});
|
||||
|
||||
it('with IGNORE', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments('key', '*', 1, {
|
||||
IGNORE: { MAX_TIME_DIFF: 1, MAX_VAL_DIFF: 1}
|
||||
}),
|
||||
['TS.ADD', 'key', '*', '1', 'IGNORE', '1', '1']
|
||||
)
|
||||
});
|
||||
|
||||
it('with RETENTION, ENCODING, CHUNK_SIZE, ON_DUPLICATE, LABELS, IGNORE', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments('key', '*', 1, {
|
||||
RETENTION: 1,
|
||||
ENCODING: TimeSeriesEncoding.UNCOMPRESSED,
|
||||
CHUNK_SIZE: 1,
|
||||
ON_DUPLICATE: TimeSeriesDuplicatePolicies.BLOCK,
|
||||
LABELS: { label: 'value' },
|
||||
IGNORE: { MAX_TIME_DIFF: 1, MAX_VAL_DIFF: 1}
|
||||
}),
|
||||
['TS.ADD', 'key', '*', '1', 'RETENTION', '1', 'ENCODING', 'UNCOMPRESSED', 'CHUNK_SIZE', '1', 'ON_DUPLICATE', 'BLOCK', 'LABELS', 'label', 'value', 'IGNORE', '1', '1']
|
||||
);
|
||||
});
|
||||
describe('TS.ADD', () => {
|
||||
describe('transformArguments', () => {
|
||||
it('without options', () => {
|
||||
assert.deepEqual(
|
||||
ADD.transformArguments('key', '*', 1),
|
||||
['TS.ADD', 'key', '*', '1']
|
||||
);
|
||||
});
|
||||
|
||||
testUtils.testWithClient('client.ts.add', async client => {
|
||||
assert.equal(
|
||||
await client.ts.add('key', 0, 1),
|
||||
0
|
||||
);
|
||||
}, GLOBAL.SERVERS.OPEN);
|
||||
it('with RETENTION', () => {
|
||||
assert.deepEqual(
|
||||
ADD.transformArguments('key', '*', 1, {
|
||||
RETENTION: 1
|
||||
}),
|
||||
['TS.ADD', 'key', '*', '1', 'RETENTION', '1']
|
||||
);
|
||||
});
|
||||
|
||||
it('with ENCODING', () => {
|
||||
assert.deepEqual(
|
||||
ADD.transformArguments('key', '*', 1, {
|
||||
ENCODING: TIME_SERIES_ENCODING.UNCOMPRESSED
|
||||
}),
|
||||
['TS.ADD', 'key', '*', '1', 'ENCODING', 'UNCOMPRESSED']
|
||||
);
|
||||
});
|
||||
|
||||
it('with CHUNK_SIZE', () => {
|
||||
assert.deepEqual(
|
||||
ADD.transformArguments('key', '*', 1, {
|
||||
CHUNK_SIZE: 1
|
||||
}),
|
||||
['TS.ADD', 'key', '*', '1', 'CHUNK_SIZE', '1']
|
||||
);
|
||||
});
|
||||
|
||||
it('with ON_DUPLICATE', () => {
|
||||
assert.deepEqual(
|
||||
ADD.transformArguments('key', '*', 1, {
|
||||
ON_DUPLICATE: TIME_SERIES_DUPLICATE_POLICIES.BLOCK
|
||||
}),
|
||||
['TS.ADD', 'key', '*', '1', 'ON_DUPLICATE', 'BLOCK']
|
||||
);
|
||||
});
|
||||
|
||||
it('with LABELS', () => {
|
||||
assert.deepEqual(
|
||||
ADD.transformArguments('key', '*', 1, {
|
||||
LABELS: { label: 'value' }
|
||||
}),
|
||||
['TS.ADD', 'key', '*', '1', 'LABELS', 'label', 'value']
|
||||
);
|
||||
});
|
||||
|
||||
it ('with IGNORE', () => {
|
||||
assert.deepEqual(
|
||||
ADD.transformArguments('key', '*', 1, {
|
||||
IGNORE: {
|
||||
maxTimeDiff: 1,
|
||||
maxValDiff: 1
|
||||
}
|
||||
}),
|
||||
['TS.ADD', 'key', '*', '1', 'IGNORE', '1', '1']
|
||||
)
|
||||
});
|
||||
|
||||
it('with RETENTION, ENCODING, CHUNK_SIZE, ON_DUPLICATE, LABELS, IGNORE', () => {
|
||||
assert.deepEqual(
|
||||
ADD.transformArguments('key', '*', 1, {
|
||||
RETENTION: 1,
|
||||
ENCODING: TIME_SERIES_ENCODING.UNCOMPRESSED,
|
||||
CHUNK_SIZE: 1,
|
||||
ON_DUPLICATE: TIME_SERIES_DUPLICATE_POLICIES.BLOCK,
|
||||
LABELS: { label: 'value' },
|
||||
IGNORE: { maxTimeDiff: 1, maxValDiff: 1}
|
||||
}),
|
||||
['TS.ADD', 'key', '*', '1', 'RETENTION', '1', 'ENCODING', 'UNCOMPRESSED', 'CHUNK_SIZE', '1', 'ON_DUPLICATE', 'BLOCK', 'LABELS', 'label', 'value', 'IGNORE', '1', '1']
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
testUtils.testWithClient('client.ts.add', async client => {
|
||||
assert.equal(
|
||||
await client.ts.add('key', 0, 1),
|
||||
0
|
||||
);
|
||||
}, GLOBAL.SERVERS.OPEN);
|
||||
});
|
||||
|
Reference in New Issue
Block a user