You've already forked node-redis
mirror of
https://github.com/redis/node-redis.git
synced 2025-08-07 13:22:56 +03:00
fix GETEX spec
This commit is contained in:
@@ -1,96 +1,90 @@
|
|||||||
import { strict as assert } from 'assert';
|
import { strict as assert } from 'assert';
|
||||||
import testUtils, { GLOBAL } from '../test-utils';
|
import testUtils, { GLOBAL } from '../test-utils';
|
||||||
import { transformArguments } from './GETEX';
|
import GETEX from './GETEX';
|
||||||
|
|
||||||
describe('GETEX', () => {
|
describe('GETEX', () => {
|
||||||
testUtils.isVersionGreaterThanHook([6, 2]);
|
testUtils.isVersionGreaterThanHook([6, 2]);
|
||||||
|
|
||||||
describe('transformArguments', () => {
|
describe('transformArguments', () => {
|
||||||
it('EX', () => {
|
it('EX', () => {
|
||||||
assert.deepEqual(
|
assert.deepEqual(
|
||||||
transformArguments('key', {
|
GETEX.transformArguments('key', {
|
||||||
EX: 1
|
EX: 1
|
||||||
}),
|
}),
|
||||||
['GETEX', 'key', 'EX', '1']
|
['GETEX', 'key', 'EX', '1']
|
||||||
);
|
);
|
||||||
});
|
|
||||||
|
|
||||||
it('PX', () => {
|
|
||||||
assert.deepEqual(
|
|
||||||
transformArguments('key', {
|
|
||||||
PX: 1
|
|
||||||
}),
|
|
||||||
['GETEX', 'key', 'PX', '1']
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('EXAT', () => {
|
|
||||||
it('number', () => {
|
|
||||||
assert.deepEqual(
|
|
||||||
transformArguments('key', {
|
|
||||||
EXAT: 1
|
|
||||||
}),
|
|
||||||
['GETEX', 'key', 'EXAT', '1']
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('date', () => {
|
|
||||||
const d = new Date();
|
|
||||||
assert.deepEqual(
|
|
||||||
transformArguments('key', {
|
|
||||||
EXAT: d
|
|
||||||
}),
|
|
||||||
['GETEX', 'key', 'EXAT', Math.floor(d.getTime() / 1000).toString()]
|
|
||||||
);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('PXAT', () => {
|
|
||||||
it('number', () => {
|
|
||||||
assert.deepEqual(
|
|
||||||
transformArguments('key', {
|
|
||||||
PXAT: 1
|
|
||||||
}),
|
|
||||||
['GETEX', 'key', 'PXAT', '1']
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('date', () => {
|
|
||||||
const d = new Date();
|
|
||||||
assert.deepEqual(
|
|
||||||
transformArguments('key', {
|
|
||||||
PXAT: d
|
|
||||||
}),
|
|
||||||
['GETEX', 'key', 'PXAT', d.getTime().toString()]
|
|
||||||
);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
it('PERSIST', () => {
|
|
||||||
assert.deepEqual(
|
|
||||||
transformArguments('key', {
|
|
||||||
PERSIST: true
|
|
||||||
}),
|
|
||||||
['GETEX', 'key', 'PERSIST']
|
|
||||||
);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
testUtils.testWithClient('client.getEx', async client => {
|
it('PX', () => {
|
||||||
assert.equal(
|
assert.deepEqual(
|
||||||
await client.getEx('key', {
|
GETEX.transformArguments('key', {
|
||||||
PERSIST: true
|
PX: 1
|
||||||
}),
|
}),
|
||||||
null
|
['GETEX', 'key', 'PX', '1']
|
||||||
);
|
);
|
||||||
}, GLOBAL.SERVERS.OPEN);
|
});
|
||||||
|
|
||||||
testUtils.testWithCluster('cluster.getEx', async cluster => {
|
describe('EXAT', () => {
|
||||||
assert.equal(
|
it('number', () => {
|
||||||
await cluster.getEx('key', {
|
assert.deepEqual(
|
||||||
PERSIST: true
|
GETEX.transformArguments('key', {
|
||||||
}),
|
EXAT: 1
|
||||||
null
|
}),
|
||||||
|
['GETEX', 'key', 'EXAT', '1']
|
||||||
);
|
);
|
||||||
}, GLOBAL.CLUSTERS.OPEN);
|
});
|
||||||
|
|
||||||
|
it('date', () => {
|
||||||
|
const d = new Date();
|
||||||
|
assert.deepEqual(
|
||||||
|
GETEX.transformArguments('key', {
|
||||||
|
EXAT: d
|
||||||
|
}),
|
||||||
|
['GETEX', 'key', 'EXAT', Math.floor(d.getTime() / 1000).toString()]
|
||||||
|
);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('PXAT', () => {
|
||||||
|
it('number', () => {
|
||||||
|
assert.deepEqual(
|
||||||
|
GETEX.transformArguments('key', {
|
||||||
|
PXAT: 1
|
||||||
|
}),
|
||||||
|
['GETEX', 'key', 'PXAT', '1']
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('date', () => {
|
||||||
|
const d = new Date();
|
||||||
|
assert.deepEqual(
|
||||||
|
GETEX.transformArguments('key', {
|
||||||
|
PXAT: d
|
||||||
|
}),
|
||||||
|
['GETEX', 'key', 'PXAT', d.getTime().toString()]
|
||||||
|
);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('PERSIST', () => {
|
||||||
|
assert.deepEqual(
|
||||||
|
GETEX.transformArguments('key', {
|
||||||
|
PERSIST: true
|
||||||
|
}),
|
||||||
|
['GETEX', 'key', 'PERSIST']
|
||||||
|
);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
testUtils.testAll('getEx', async client => {
|
||||||
|
assert.equal(
|
||||||
|
await client.getEx('key', {
|
||||||
|
PERSIST: true
|
||||||
|
}),
|
||||||
|
null
|
||||||
|
);
|
||||||
|
}, {
|
||||||
|
client: GLOBAL.SERVERS.OPEN,
|
||||||
|
cluster: GLOBAL.CLUSTERS.OPEN
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
Reference in New Issue
Block a user