You've already forked node-redis
mirror of
https://github.com/redis/node-redis.git
synced 2025-08-04 15:02:09 +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,62 +1,60 @@
|
||||
import { strict as assert } from 'assert';
|
||||
import { strict as assert } from 'node:assert';
|
||||
import testUtils, { GLOBAL } from '../test-utils';
|
||||
import { transformArguments } from './XPENDING';
|
||||
import XPENDING from './XPENDING';
|
||||
|
||||
describe('XPENDING', () => {
|
||||
describe('transformArguments', () => {
|
||||
it('transformArguments', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments('key', 'group'),
|
||||
['XPENDING', 'key', 'group']
|
||||
);
|
||||
});
|
||||
describe('transformArguments', () => {
|
||||
it('transformArguments', () => {
|
||||
assert.deepEqual(
|
||||
XPENDING.transformArguments('key', 'group'),
|
||||
['XPENDING', 'key', 'group']
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
describe('client.xPending', () => {
|
||||
testUtils.testWithClient('simple', async client => {
|
||||
await client.xGroupCreate('key', 'group', '$', {
|
||||
MKSTREAM: true
|
||||
});
|
||||
describe('client.xPending', () => {
|
||||
testUtils.testWithClient('simple', async client => {
|
||||
const [, reply] = await Promise.all([
|
||||
client.xGroupCreate('key', 'group', '$', {
|
||||
MKSTREAM: true
|
||||
}),
|
||||
client.xPending('key', 'group')
|
||||
]);
|
||||
|
||||
assert.deepEqual(
|
||||
await client.xPending('key', 'group'),
|
||||
{
|
||||
pending: 0,
|
||||
firstId: null,
|
||||
lastId: null,
|
||||
consumers: null
|
||||
}
|
||||
);
|
||||
}, GLOBAL.SERVERS.OPEN);
|
||||
assert.deepEqual(reply, {
|
||||
pending: 0,
|
||||
firstId: null,
|
||||
lastId: null,
|
||||
consumers: null
|
||||
});
|
||||
}, GLOBAL.SERVERS.OPEN);
|
||||
|
||||
testUtils.testWithClient('with consumers', async client => {
|
||||
const [,, id] = await Promise.all([
|
||||
client.xGroupCreate('key', 'group', '$', {
|
||||
MKSTREAM: true
|
||||
}),
|
||||
client.xGroupCreateConsumer('key', 'group', 'consumer'),
|
||||
client.xAdd('key', '*', { field: 'value' }),
|
||||
client.xReadGroup('group', 'consumer', {
|
||||
key: 'key',
|
||||
id: '>'
|
||||
})
|
||||
]);
|
||||
testUtils.testWithClient('with consumers', async client => {
|
||||
const [, , id, , reply] = await Promise.all([
|
||||
client.xGroupCreate('key', 'group', '$', {
|
||||
MKSTREAM: true
|
||||
}),
|
||||
client.xGroupCreateConsumer('key', 'group', 'consumer'),
|
||||
client.xAdd('key', '*', { field: 'value' }),
|
||||
client.xReadGroup('group', 'consumer', {
|
||||
key: 'key',
|
||||
id: '>'
|
||||
}),
|
||||
client.xPending('key', 'group')
|
||||
]);
|
||||
|
||||
assert.deepEqual(
|
||||
await client.xPending('key', 'group'),
|
||||
{
|
||||
pending: 1,
|
||||
firstId: id,
|
||||
lastId: id,
|
||||
consumers: [{
|
||||
name: 'consumer',
|
||||
deliveriesCounter: 1
|
||||
}]
|
||||
}
|
||||
);
|
||||
}, {
|
||||
...GLOBAL.SERVERS.OPEN,
|
||||
minimumDockerVersion: [6, 2]
|
||||
});
|
||||
assert.deepEqual(reply, {
|
||||
pending: 1,
|
||||
firstId: id,
|
||||
lastId: id,
|
||||
consumers: [{
|
||||
name: 'consumer',
|
||||
deliveriesCounter: 1
|
||||
}]
|
||||
});
|
||||
}, {
|
||||
...GLOBAL.SERVERS.OPEN,
|
||||
minimumDockerVersion: [6, 2]
|
||||
});
|
||||
});
|
||||
});
|
||||
|
Reference in New Issue
Block a user