1
0
mirror of https://github.com/redis/node-redis.git synced 2025-08-03 04:01:40 +03:00
Files
node-redis/packages/client/lib/commands/BITOP.spec.ts
Pavel Pashov b52177752e feat: added support for new bitop operations (#3001)
refactored bitop tests, covered all operations

updated default docker version on all packages
2025-06-19 13:56:00 +03:00

97 lines
2.8 KiB
TypeScript

import { strict as assert } from 'node:assert';
import testUtils, { GLOBAL } from '../test-utils';
import BITOP, { BitOperations } from './BITOP';
import { parseArgs } from './generic-transformers';
describe('BITOP', () => {
describe('transformArguments', () => {
it('single key', () => {
assert.deepEqual(
parseArgs(BITOP, 'AND', 'destKey', 'key'),
['BITOP', 'AND', 'destKey', 'key']
);
});
it('multiple keys', () => {
assert.deepEqual(
parseArgs(BITOP, 'AND', 'destKey', ['1', '2']),
['BITOP', 'AND', 'destKey', '1', '2']
);
});
});
for (const op of ['AND', 'OR', 'XOR'] as BitOperations[]) {
testUtils.testAll(`bitOp ${op} with non-existing keys`, async client => {
assert.equal(
await client.bitOp(op, '{tag}destKey', ['{tag}key1', '{tag}key2']),
0
);
}, {
client: GLOBAL.SERVERS.OPEN,
cluster: GLOBAL.CLUSTERS.OPEN
});
testUtils.testAll(`bitOp ${op} with existing keys`, async client => {
await client.set('{tag}key1', 'value1');
await client.set('{tag}key2', 'value2');
assert.equal(
await client.bitOp(op, '{tag}destKey', ['{tag}key1', '{tag}key2']),
6
);
}, {
client: GLOBAL.SERVERS.OPEN,
cluster: GLOBAL.CLUSTERS.OPEN
});
}
// NOT operation requires only one key
testUtils.testAll('bitOp NOT with non-existing keys', async client => {
assert.equal(
await client.bitOp('NOT', '{tag}destKey', '{tag}key'),
0
);
}, {
client: GLOBAL.SERVERS.OPEN,
cluster: GLOBAL.CLUSTERS.OPEN
});
testUtils.testAll('bitOp NOT with existing keys', async client => {
await client.set('{tag}key', 'value');
assert.equal(
await client.bitOp('NOT', '{tag}destKey', '{tag}key'),
5
);
}, {
client: GLOBAL.SERVERS.OPEN,
cluster: GLOBAL.CLUSTERS.OPEN
});
// newer operations supported since Redis 8.2
for (const op of ['DIFF', 'DIFF1', 'ANDOR', 'ONE'] as BitOperations[]) {
testUtils.testAll(`bitOp ${op} with non-existing keys`, async client => {
assert.equal(
await client.bitOp(op, '{tag}destKey', ['{tag}key1', '{tag}key2']),
0
);
}, {
client: { ...GLOBAL.SERVERS.OPEN, minimumDockerVersion: [8, 2] },
cluster: { ...GLOBAL.CLUSTERS.OPEN, minimumDockerVersion: [8, 2] },
});
testUtils.testAll(`bitOp ${op} with existing keys`, async client => {
await client.set('{tag}key1', 'value1');
await client.set('{tag}key2', 'value2');
assert.equal(
await client.bitOp(op, '{tag}destKey', ['{tag}key1', '{tag}key2']),
6
);
}, {
client: { ...GLOBAL.SERVERS.OPEN, minimumDockerVersion: [8, 2] },
cluster: { ...GLOBAL.CLUSTERS.OPEN, minimumDockerVersion: [8, 2] },
});
}
});