1
0
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:
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,95 +1,100 @@
import { strict as assert } from 'assert';
import { strict as assert } from 'node:assert';
import testUtils, { GLOBAL } from '../test-utils';
import { transformArguments } from './GEOADD';
import GEOADD from './GEOADD';
describe('GEOADD', () => {
describe('transformArguments', () => {
it('one member', () => {
assert.deepEqual(
transformArguments('key', {
member: 'member',
longitude: 1,
latitude: 2
}),
['GEOADD', 'key', '1', '2', 'member']
);
});
it('multiple members', () => {
assert.deepEqual(
transformArguments('key', [{
longitude: 1,
latitude: 2,
member: '3',
}, {
longitude: 4,
latitude: 5,
member: '6',
}]),
['GEOADD', 'key', '1', '2', '3', '4', '5', '6']
);
});
it('with NX', () => {
assert.deepEqual(
transformArguments('key', {
longitude: 1,
latitude: 2,
member: 'member'
}, {
NX: true
}),
['GEOADD', 'key', 'NX', '1', '2', 'member']
);
});
it('with CH', () => {
assert.deepEqual(
transformArguments('key', {
longitude: 1,
latitude: 2,
member: 'member'
}, {
CH: true
}),
['GEOADD', 'key', 'CH', '1', '2', 'member']
);
});
it('with XX, CH', () => {
assert.deepEqual(
transformArguments('key', {
longitude: 1,
latitude: 2,
member: 'member'
}, {
XX: true,
CH: true
}),
['GEOADD', 'key', 'XX', 'CH', '1', '2', 'member']
);
});
describe('transformArguments', () => {
it('one member', () => {
assert.deepEqual(
GEOADD.transformArguments('key', {
member: 'member',
longitude: 1,
latitude: 2
}),
['GEOADD', 'key', '1', '2', 'member']
);
});
testUtils.testWithClient('client.geoAdd', async client => {
assert.equal(
await client.geoAdd('key', {
member: 'member',
longitude: 1,
latitude: 2
}),
1
);
}, GLOBAL.SERVERS.OPEN);
it('multiple members', () => {
assert.deepEqual(
GEOADD.transformArguments('key', [{
longitude: 1,
latitude: 2,
member: '3',
}, {
longitude: 4,
latitude: 5,
member: '6',
}]),
['GEOADD', 'key', '1', '2', '3', '4', '5', '6']
);
});
testUtils.testWithCluster('cluster.geoAdd', async cluster => {
assert.equal(
await cluster.geoAdd('key', {
member: 'member',
longitude: 1,
latitude: 2
}),
1
);
}, GLOBAL.CLUSTERS.OPEN);
it('with condition', () => {
assert.deepEqual(
GEOADD.transformArguments('key', {
longitude: 1,
latitude: 2,
member: 'member'
}, {
condition: 'NX'
}),
['GEOADD', 'key', 'NX', '1', '2', 'member']
);
});
it('with NX (backwards compatibility)', () => {
assert.deepEqual(
GEOADD.transformArguments('key', {
longitude: 1,
latitude: 2,
member: 'member'
}, {
NX: true
}),
['GEOADD', 'key', 'NX', '1', '2', 'member']
);
});
it('with CH', () => {
assert.deepEqual(
GEOADD.transformArguments('key', {
longitude: 1,
latitude: 2,
member: 'member'
}, {
CH: true
}),
['GEOADD', 'key', 'CH', '1', '2', 'member']
);
});
it('with condition, CH', () => {
assert.deepEqual(
GEOADD.transformArguments('key', {
longitude: 1,
latitude: 2,
member: 'member'
}, {
condition: 'XX',
CH: true
}),
['GEOADD', 'key', 'XX', 'CH', '1', '2', 'member']
);
});
});
testUtils.testAll('geoAdd', async client => {
assert.equal(
await client.geoAdd('key', {
member: 'member',
longitude: 1,
latitude: 2
}),
1
);
}, {
client: GLOBAL.SERVERS.OPEN,
cluster: GLOBAL.CLUSTERS.OPEN
});
});