1
0
mirror of https://github.com/redis/node-redis.git synced 2025-08-07 13:22:56 +03:00
This commit is contained in:
dovi
2023-07-05 14:17:51 -04:00
parent de7e2b85c4
commit 935b9cbb60
2 changed files with 106 additions and 99 deletions

View File

@@ -1,80 +1,80 @@
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 './ADD'; import ADD from './ADD';
import { TimeSeriesDuplicatePolicies, TimeSeriesEncoding } from '.'; import { TimeSeriesDuplicatePolicies, TimeSeriesEncoding } from '.';
describe('ADD', () => { describe('TS.ADD', () => {
describe('transformArguments', () => { describe('transformArguments', () => {
it('without options', () => { it('without options', () => {
assert.deepEqual( assert.deepEqual(
transformArguments('key', '*', 1), ADD.transformArguments('key', '*', 1),
['TS.ADD', 'key', '*', '1'] ['TS.ADD', 'key', '*', '1']
); );
});
it('with RETENTION', () => {
assert.deepEqual(
transformArguments('key', '*', 1, {
RETENTION: 1
}),
['TS.ADD', 'key', '*', '1', 'RETENTION', '1']
);
});
it('with ENCODING', () => {
assert.deepEqual(
transformArguments('key', '*', 1, {
ENCODING: TimeSeriesEncoding.UNCOMPRESSED
}),
['TS.ADD', 'key', '*', '1', 'ENCODING', 'UNCOMPRESSED']
);
});
it('with CHUNK_SIZE', () => {
assert.deepEqual(
transformArguments('key', '*', 1, {
CHUNK_SIZE: 1
}),
['TS.ADD', 'key', '*', '1', 'CHUNK_SIZE', '1']
);
});
it('with ON_DUPLICATE', () => {
assert.deepEqual(
transformArguments('key', '*', 1, {
ON_DUPLICATE: TimeSeriesDuplicatePolicies.BLOCK
}),
['TS.ADD', 'key', '*', '1', 'ON_DUPLICATE', 'BLOCK']
);
});
it('with LABELS', () => {
assert.deepEqual(
transformArguments('key', '*', 1, {
LABELS: { label: 'value' }
}),
['TS.ADD', 'key', '*', '1', 'LABELS', 'label', 'value']
);
});
it('with RETENTION, ENCODING, CHUNK_SIZE, ON_DUPLICATE, LABELS', () => {
assert.deepEqual(
transformArguments('key', '*', 1, {
RETENTION: 1,
ENCODING: TimeSeriesEncoding.UNCOMPRESSED,
CHUNK_SIZE: 1,
ON_DUPLICATE: TimeSeriesDuplicatePolicies.BLOCK,
LABELS: { label: 'value' }
}),
['TS.ADD', 'key', '*', '1', 'RETENTION', '1', 'ENCODING', 'UNCOMPRESSED', 'CHUNK_SIZE', '1', 'ON_DUPLICATE', 'BLOCK', 'LABELS', 'label', 'value']
);
});
}); });
testUtils.testWithClient('client.ts.add', async client => { it('with RETENTION', () => {
assert.equal( assert.deepEqual(
await client.ts.add('key', 0, 1), ADD.transformArguments('key', '*', 1, {
0 RETENTION: 1
); }),
}, GLOBAL.SERVERS.OPEN); ['TS.ADD', 'key', '*', '1', 'RETENTION', '1']
);
});
it('with ENCODING', () => {
assert.deepEqual(
ADD.transformArguments('key', '*', 1, {
ENCODING: TimeSeriesEncoding.UNCOMPRESSED
}),
['TS.ADD', 'key', '*', '1', 'ENCODING', 'UNCOMPRESSED']
);
});
it('with CHUNK_SIZE', () => {
assert.deepEqual(
ADD.transformArguments('key', '*', 1, {
CHUNK_SIZE: 1
}),
['TS.ADD', 'key', '*', '1', 'CHUNK_SIZE', '1']
);
});
it('with ON_DUPLICATE', () => {
assert.deepEqual(
ADD.transformArguments('key', '*', 1, {
ON_DUPLICATE: TimeSeriesDuplicatePolicies.BLOCK
}),
['TS.ADD', 'key', '*', '1', 'ON_DUPLICATE', 'BLOCK']
);
});
it('with LABELS', () => {
assert.deepEqual(
ADD.transformArguments('key', '*', 1, {
LABELS: { label: 'value' }
}),
['TS.ADD', 'key', '*', '1', 'LABELS', 'label', 'value']
);
});
it('with RETENTION, ENCODING, CHUNK_SIZE, ON_DUPLICATE, LABELS', () => {
assert.deepEqual(
ADD.transformArguments('key', '*', 1, {
RETENTION: 1,
ENCODING: TimeSeriesEncoding.UNCOMPRESSED,
CHUNK_SIZE: 1,
ON_DUPLICATE: TimeSeriesDuplicatePolicies.BLOCK,
LABELS: { label: 'value' }
}),
['TS.ADD', 'key', '*', '1', 'RETENTION', '1', 'ENCODING', 'UNCOMPRESSED', 'CHUNK_SIZE', '1', 'ON_DUPLICATE', 'BLOCK', 'LABELS', 'label', 'value']
);
});
});
testUtils.testWithClient('client.ts.add', async client => {
assert.equal(
await client.ts.add('key', 0, 1),
0
);
}, GLOBAL.SERVERS.OPEN);
}); });

View File

@@ -1,31 +1,38 @@
import { RedisArgument, NumberReply, Command } from '@redis/client/dist/lib/RESP/types';
import { import {
transformTimestampArgument, transformTimestampArgument,
pushRetentionArgument, pushRetentionArgument,
TimeSeriesEncoding, TimeSeriesEncoding,
pushEncodingArgument, pushEncodingArgument,
pushChunkSizeArgument, pushChunkSizeArgument,
TimeSeriesDuplicatePolicies, TimeSeriesDuplicatePolicies,
Labels, Labels,
pushLabelsArgument, pushLabelsArgument,
Timestamp, Timestamp
} from '.'; } from '.';
interface AddOptions { export interface TsAddOptions {
RETENTION?: number; RETENTION?: number;
ENCODING?: TimeSeriesEncoding; ENCODING?: TimeSeriesEncoding;
CHUNK_SIZE?: number; CHUNK_SIZE?: number;
ON_DUPLICATE?: TimeSeriesDuplicatePolicies; ON_DUPLICATE?: TimeSeriesDuplicatePolicies;
LABELS?: Labels; LABELS?: Labels;
} }
export const FIRST_KEY_INDEX = 1; export default {
FIRST_KEY_INDEX: 1,
export function transformArguments(key: string, timestamp: Timestamp, value: number, options?: AddOptions): Array<string> { IS_READ_ONLY: false,
transformArguments(
key: RedisArgument,
timestamp: Timestamp,
value: number,
options?: TsAddOptions
) {
const args = [ const args = [
'TS.ADD', 'TS.ADD',
key, key,
transformTimestampArgument(timestamp), transformTimestampArgument(timestamp),
value.toString() value.toString()
]; ];
pushRetentionArgument(args, options?.RETENTION); pushRetentionArgument(args, options?.RETENTION);
@@ -35,12 +42,12 @@ export function transformArguments(key: string, timestamp: Timestamp, value: num
pushChunkSizeArgument(args, options?.CHUNK_SIZE); pushChunkSizeArgument(args, options?.CHUNK_SIZE);
if (options?.ON_DUPLICATE) { if (options?.ON_DUPLICATE) {
args.push('ON_DUPLICATE', options.ON_DUPLICATE); args.push('ON_DUPLICATE', options.ON_DUPLICATE);
} }
pushLabelsArgument(args, options?.LABELS); pushLabelsArgument(args, options?.LABELS);
return args; return args;
} },
transformReply: undefined as unknown as () => NumberReply
export declare function transformReply(): number; } as const satisfies Command;