1
0
mirror of https://github.com/redis/node-redis.git synced 2025-08-07 13:22:56 +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:
Shaya Potter
2024-10-15 17:46:52 +03:00
committed by GitHub
parent 2fc79bdfb3
commit b2d35c5286
1174 changed files with 45931 additions and 36274 deletions

View File

@@ -1,52 +1,68 @@
import { strict as assert } from 'assert';
import { strict as assert } from 'node:assert';
import testUtils, { GLOBAL } from '../test-utils';
import { transformArguments } from './MRANGE_WITHLABELS';
import { TimeSeriesAggregationType, TimeSeriesReducers } from '.';
import MRANGE_WITHLABELS from './MRANGE_WITHLABELS';
import { TIME_SERIES_AGGREGATION_TYPE } from './CREATERULE';
describe('MRANGE_WITHLABELS', () => {
it('transformArguments', () => {
assert.deepEqual(
transformArguments('-', '+', 'label=value', {
FILTER_BY_TS: [0],
FILTER_BY_VALUE: {
min: 0,
max: 1
},
SELECTED_LABELS: ['label'],
COUNT: 1,
ALIGN: '-',
AGGREGATION: {
type: TimeSeriesAggregationType.AVERAGE,
timeBucket: 1
},
GROUPBY: {
label: 'label',
reducer: TimeSeriesReducers.SUM
},
describe('TS.MRANGE_WITHLABELS', () => {
it('transformArguments', () => {
assert.deepEqual(
MRANGE_WITHLABELS.transformArguments('-', '+', 'label=value', {
LATEST: true,
FILTER_BY_TS: [0],
FILTER_BY_VALUE: {
min: 0,
max: 1
},
COUNT: 1,
ALIGN: '-',
AGGREGATION: {
type: TIME_SERIES_AGGREGATION_TYPE.AVG,
timeBucket: 1
}
}),
[
'TS.MRANGE', '-', '+',
'LATEST',
'FILTER_BY_TS', '0',
'FILTER_BY_VALUE', '0', '1',
'COUNT', '1',
'ALIGN', '-',
'AGGREGATION', 'AVG', '1',
'WITHLABELS',
'FILTER', 'label=value'
]
);
});
testUtils.testWithClient('client.ts.mRangeWithLabels', async client => {
const [, reply] = await Promise.all([
client.ts.add('key', 0, 0, {
LABELS: { label: 'value' }
}),
client.ts.mRangeWithLabels('-', '+', 'label=value')
]);
assert.deepStrictEqual(
reply,
Object.create(null, {
key: {
configurable: true,
enumerable: true,
value: {
labels: Object.create(null, {
label: {
configurable: true,
enumerable: true,
value: 'value'
}
}),
['TS.MRANGE', '-', '+', 'FILTER_BY_TS', '0', 'FILTER_BY_VALUE', '0', '1',
'COUNT', '1', 'ALIGN', '-', 'AGGREGATION', 'AVG', '1', 'SELECTED_LABELS', 'label',
'FILTER', 'label=value', 'GROUPBY', 'label', 'REDUCE', 'SUM']
);
});
testUtils.testWithClient('client.ts.mRangeWithLabels', async client => {
await client.ts.add('key', 0, 0, {
LABELS: { label: 'value'}
});
assert.deepEqual(
await client.ts.mRangeWithLabels('-', '+', 'label=value', {
COUNT: 1
}),
[{
key: 'key',
labels: { label: 'value' },
samples: [{
timestamp: 0,
value: 0
}]
samples: [{
timestamp: 0,
value: 0
}]
);
}, GLOBAL.SERVERS.OPEN);
}
}
})
);
}, GLOBAL.SERVERS.OPEN);
});