1
0
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:
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,43 +1,38 @@
import { strict as assert } from 'assert';
import { strict as assert } from 'node:assert';
import testUtils, { GLOBAL } from '../test-utils';
import { transformArguments, transformReply } from './XINFO_CONSUMERS';
import XINFO_CONSUMERS from './XINFO_CONSUMERS';
describe('XINFO CONSUMERS', () => {
it('transformArguments', () => {
assert.deepEqual(
transformArguments('key', 'group'),
['XINFO', 'CONSUMERS', 'key', 'group']
);
});
it('transformArguments', () => {
assert.deepEqual(
XINFO_CONSUMERS.transformArguments('key', 'group'),
['XINFO', 'CONSUMERS', 'key', 'group']
);
});
it('transformReply', () => {
assert.deepEqual(
transformReply([
['name', 'Alice', 'pending', 1, 'idle', 9104628, 'inactive', 9281221],
['name', 'Bob', 'pending', 1, 'idle', 83841983, 'inactive', 7213871]
]),
[{
name: 'Alice',
pending: 1,
idle: 9104628,
inactive: 9281221,
}, {
name: 'Bob',
pending: 1,
idle: 83841983,
inactive: 7213871,
}]
);
});
testUtils.testAll('xInfoConsumers', async client => {
const [, , reply] = await Promise.all([
client.xGroupCreate('key', 'group', '$', {
MKSTREAM: true
}),
// using `XREADGROUP` and not `XGROUP CREATECONSUMER` because the latter was introduced in Redis 6.2
client.xReadGroup('group', 'consumer', {
key: 'key',
id: '0-0'
}),
client.xInfoConsumers('key', 'group')
]);
testUtils.testWithClient('client.xInfoConsumers', async client => {
await client.xGroupCreate('key', 'group', '$', {
MKSTREAM: true
});
assert.deepEqual(
await client.xInfoConsumers('key', 'group'),
[]
);
}, GLOBAL.SERVERS.OPEN);
for (const consumer of reply) {
assert.equal(typeof consumer.name, 'string');
assert.equal(typeof consumer.pending, 'number');
assert.equal(typeof consumer.idle, 'number');
if (testUtils.isVersionGreaterThan([7, 2])) {
assert.equal(typeof consumer.inactive, 'number');
}
}
}, {
client: GLOBAL.SERVERS.OPEN,
cluster: GLOBAL.CLUSTERS.OPEN
});
});