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,69 +1,69 @@
|
||||
import { strict as assert } from 'assert';
|
||||
import { strict as assert } from 'node:assert';
|
||||
import testUtils, { GLOBAL } from '../test-utils';
|
||||
import { transformArguments, transformReply } from './ROLE';
|
||||
import ROLE from './ROLE';
|
||||
|
||||
describe('ROLE', () => {
|
||||
it('transformArguments', () => {
|
||||
assert.deepEqual(
|
||||
transformArguments(),
|
||||
['ROLE']
|
||||
);
|
||||
it('transformArguments', () => {
|
||||
assert.deepEqual(
|
||||
ROLE.transformArguments(),
|
||||
['ROLE']
|
||||
);
|
||||
});
|
||||
|
||||
describe('transformReply', () => {
|
||||
it('master', () => {
|
||||
assert.deepEqual(
|
||||
ROLE.transformReply(['master', 3129659, [['127.0.0.1', '9001', '3129242'], ['127.0.0.1', '9002', '3129543']]] as any),
|
||||
{
|
||||
role: 'master',
|
||||
replicationOffest: 3129659,
|
||||
replicas: [{
|
||||
host: '127.0.0.1',
|
||||
port: 9001,
|
||||
replicationOffest: 3129242
|
||||
}, {
|
||||
host: '127.0.0.1',
|
||||
port: 9002,
|
||||
replicationOffest: 3129543
|
||||
}]
|
||||
}
|
||||
);
|
||||
});
|
||||
|
||||
describe('transformReply', () => {
|
||||
it('master', () => {
|
||||
assert.deepEqual(
|
||||
transformReply(['master', 3129659, [['127.0.0.1', '9001', '3129242'], ['127.0.0.1', '9002', '3129543']]]),
|
||||
{
|
||||
role: 'master',
|
||||
replicationOffest: 3129659,
|
||||
replicas: [{
|
||||
ip: '127.0.0.1',
|
||||
port: 9001,
|
||||
replicationOffest: 3129242
|
||||
}, {
|
||||
ip: '127.0.0.1',
|
||||
port: 9002,
|
||||
replicationOffest: 3129543
|
||||
}]
|
||||
}
|
||||
);
|
||||
});
|
||||
|
||||
it('replica', () => {
|
||||
assert.deepEqual(
|
||||
transformReply(['slave', '127.0.0.1', 9000, 'connected', 3167038]),
|
||||
{
|
||||
role: 'slave',
|
||||
master: {
|
||||
ip: '127.0.0.1',
|
||||
port: 9000
|
||||
},
|
||||
state: 'connected',
|
||||
dataReceived: 3167038
|
||||
}
|
||||
);
|
||||
});
|
||||
|
||||
it('sentinel', () => {
|
||||
assert.deepEqual(
|
||||
transformReply(['sentinel', ['resque-master', 'html-fragments-master', 'stats-master', 'metadata-master']]),
|
||||
{
|
||||
role: 'sentinel',
|
||||
masterNames: ['resque-master', 'html-fragments-master', 'stats-master', 'metadata-master']
|
||||
}
|
||||
);
|
||||
});
|
||||
it('replica', () => {
|
||||
assert.deepEqual(
|
||||
ROLE.transformReply(['slave', '127.0.0.1', 9000, 'connected', 3167038] as any),
|
||||
{
|
||||
role: 'slave',
|
||||
master: {
|
||||
host: '127.0.0.1',
|
||||
port: 9000
|
||||
},
|
||||
state: 'connected',
|
||||
dataReceived: 3167038
|
||||
}
|
||||
);
|
||||
});
|
||||
|
||||
testUtils.testWithClient('client.role', async client => {
|
||||
assert.deepEqual(
|
||||
await client.role(),
|
||||
{
|
||||
role: 'master',
|
||||
replicationOffest: 0,
|
||||
replicas: []
|
||||
}
|
||||
);
|
||||
}, GLOBAL.SERVERS.OPEN);
|
||||
it('sentinel', () => {
|
||||
assert.deepEqual(
|
||||
ROLE.transformReply(['sentinel', ['resque-master', 'html-fragments-master', 'stats-master', 'metadata-master']] as any),
|
||||
{
|
||||
role: 'sentinel',
|
||||
masterNames: ['resque-master', 'html-fragments-master', 'stats-master', 'metadata-master']
|
||||
}
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
testUtils.testWithClient('client.role', async client => {
|
||||
assert.deepEqual(
|
||||
await client.role(),
|
||||
{
|
||||
role: 'master',
|
||||
replicationOffest: 0,
|
||||
replicas: []
|
||||
}
|
||||
);
|
||||
}, GLOBAL.SERVERS.OPEN);
|
||||
});
|
||||
|
Reference in New Issue
Block a user