1
0
mirror of https://github.com/redis/node-redis.git synced 2025-08-06 02:15:48 +03:00

fix GEO* commands

This commit is contained in:
Leibale
2023-05-08 11:04:22 +03:00
parent d2e244a77d
commit 6a0b4db4f7
37 changed files with 1115 additions and 990 deletions

View File

@@ -1,95 +1,100 @@
import { strict as assert } from '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
});
});