You've already forked node-redis
mirror of
https://github.com/redis/node-redis.git
synced 2025-07-31 05:44:24 +03:00
* move all doctests from emb-examples branch * fix readme * add package-lock.json * --wip-- [skip ci] * fix: replace client.quit() with client.close() as quit is deprecated - doctests/cmds-hash.js - doctests/cmds-list.js - doctests/cmds-servermgmt.js - doctests/cmds-set.js * fix: replace client.quit() with client.close() as quit is deprecated - doctests/cmds-sorted-set.js - doctests/cmds-string.js - doctests/dt-bitfield.js - doctests/dt-bitmap.js * fix: replace client.quit() with client.close() as quit is deprecated - dt-bloom.js: replace client.quit() with client.close() - dt-cms.js: replace client.quit() with client.close() - dt-cuckoo.js: replace client.quit() with client.close() and update expected output comments to reflect v5 boolean returns - dt-geo.js: replace client.quit() with client.close() * fix(doctests): correct pfAdd return values and replace quit with close - Fix dt-hll.js: pfAdd returns 1 instead of true in comments and assertions - Fix dt-hash.js and dt-hll.js: replace deprecated client.quit() with client.close() * fix(doctests): correct API usage and return values in json and list examples - Fix dt-json.js: use options object for json.type, json.strLen, json.del, json.arrPop, json.objLen, json.objKeys - Fix dt-json.js: correct json.del return value from [1] to 1 - Fix dt-list.js: correct client initialization, return values (null, OK, 1), and error type - Replace deprecated client.quit() with client.close() in both files * fix(doctests): update dt-set.js and dt-ss.js for v5 compliance - Updated boolean return values to numbers for SISMEMBER and SMISMEMBER commands - Fixed client lifecycle to use client.close() instead of client.quit() - Removed unnecessary await from createClient() - Added order-independent assertions for set operations - Removed debug statement * fix(doctests): update deprecated methods and imports for v5 compliance - Fix dt-string.js: remove await from client creation and replace client.quit() with client.close() - Fix dt-tdigest.js: replace deprecated client.quit() with client.close() - Fix dt-topk.js: replace client.quit() with client.close() and fix output comment from [1, 0] to [true, false] - Fix query-agg.js: update @redis/search imports to use new constant names and replace client.disconnect() with client.close() * fix(doctests): update imports and replace deprecated disconnect with close - Replace SchemaFieldTypes/VectorAlgorithms with SCHEMA_FIELD_TYPE/SCHEMA_VECTOR_FIELD_ALGORITHM - Replace client.disconnect() with client.close() for consistent deprecation handling - Update query-combined.js, query-em.js, query-ft.js, and query-geo.js * fix(doctests): update imports and replace deprecated methods in remaining files - Update imports to use SCHEMA_FIELD_TYPE and SCHEMA_VECTOR_FIELD_ALGORITHM constants - Replace deprecated disconnect() and quit() methods with close() - Fix assertion in search-quickstart.js to use correct bicycle ID * fix(doctests): update cmds-generic.js and cmds-cnxmgmt.js for v5 compliance - Replace deprecated client.quit() with client.close() - Update sScanIterator to use collection-yielding behavior (value -> values) - Fix HSCAN API changes: tuples renamed to entries - Fix cursor type issues: use string '0' instead of number 0 for hScan - Fix infinite loop in scan cleanup by using do-while pattern * fix(doctests): update dt-streams.js object shapes and parameters for v5 compliance - Update stream result objects from tuple format to proper object format with id/message properties - Change xRead/xReadGroup results from nested arrays to objects with name/messages structure - Update xAutoClaim results to use nextId, messages, and deletedMessages properties - Add missing properties to xInfo* results (max-deleted-entry-id, entries-added, recorded-first-entry-id, entries-read, lag, inactive) - Modernize parameter names (count -> COUNT, block -> BLOCK, etc.) - Update MAXLEN/APPROXIMATE options to new TRIM object structure - Fix error message format for XADD duplicate ID error - Update boolean return values (True -> OK) --------- Co-authored-by: Nikolay Karadzhov <nkaradzhov89@gmail.com>
196 lines
5.2 KiB
JavaScript
196 lines
5.2 KiB
JavaScript
// EXAMPLE: cmds_generic
|
|
// REMOVE_START
|
|
import assert from "node:assert";
|
|
// REMOVE_END
|
|
|
|
// HIDE_START
|
|
import { createClient } from 'redis';
|
|
|
|
const client = createClient();
|
|
await client.connect().catch(console.error);
|
|
// HIDE_END
|
|
|
|
// STEP_START del
|
|
const delRes1 = await client.set('key1', 'Hello');
|
|
console.log(delRes1); // OK
|
|
|
|
const delRes2 = await client.set('key2', 'World');
|
|
console.log(delRes2); // OK
|
|
|
|
const delRes3 = await client.del(['key1', 'key2', 'key3']);
|
|
console.log(delRes3); // 2
|
|
// REMOVE_START
|
|
assert.equal(delRes3, 2);
|
|
// REMOVE_END
|
|
// STEP_END
|
|
|
|
// STEP_START expire
|
|
const expireRes1 = await client.set('mykey', 'Hello');
|
|
console.log(expireRes1); // OK
|
|
|
|
const expireRes2 = await client.expire('mykey', 10);
|
|
console.log(expireRes2); // 1
|
|
|
|
const expireRes3 = await client.ttl('mykey');
|
|
console.log(expireRes3); // 10
|
|
// REMOVE_START
|
|
assert.equal(expireRes3, 10);
|
|
// REMOVE_END
|
|
|
|
const expireRes4 = await client.set('mykey', 'Hello World');
|
|
console.log(expireRes4); // OK
|
|
|
|
const expireRes5 = await client.ttl('mykey');
|
|
console.log(expireRes5); // -1
|
|
// REMOVE_START
|
|
assert.equal(expireRes5, -1);
|
|
// REMOVE_END
|
|
|
|
const expireRes6 = await client.expire('mykey', 10, "XX");
|
|
console.log(expireRes6); // 0
|
|
// REMOVE_START
|
|
assert.equal(expireRes6, 0)
|
|
// REMOVE_END
|
|
|
|
const expireRes7 = await client.ttl('mykey');
|
|
console.log(expireRes7); // -1
|
|
// REMOVE_START
|
|
assert.equal(expireRes7, -1);
|
|
// REMOVE_END
|
|
|
|
const expireRes8 = await client.expire('mykey', 10, "NX");
|
|
console.log(expireRes8); // 1
|
|
// REMOVE_START
|
|
assert.equal(expireRes8, 1);
|
|
// REMOVE_END
|
|
|
|
const expireRes9 = await client.ttl('mykey');
|
|
console.log(expireRes9); // 10
|
|
// REMOVE_START
|
|
assert.equal(expireRes9, 10);
|
|
await client.del('mykey');
|
|
// REMOVE_END
|
|
// STEP_END
|
|
|
|
// STEP_START ttl
|
|
const ttlRes1 = await client.set('mykey', 'Hello');
|
|
console.log(ttlRes1); // OK
|
|
|
|
const ttlRes2 = await client.expire('mykey', 10);
|
|
console.log(ttlRes2); // 1
|
|
|
|
const ttlRes3 = await client.ttl('mykey');
|
|
console.log(ttlRes3); // 10
|
|
// REMOVE_START
|
|
assert.equal(ttlRes3, 10);
|
|
await client.del('mykey');
|
|
// REMOVE_END
|
|
// STEP_END
|
|
|
|
// STEP_START scan1
|
|
const scan1Res1 = await client.sAdd('myset', ['1', '2', '3', 'foo', 'foobar', 'feelsgood']);
|
|
console.log(scan1Res1); // 6
|
|
|
|
let scan1Res2 = [];
|
|
for await (const values of client.sScanIterator('myset', { MATCH: 'f*' })) {
|
|
scan1Res2 = scan1Res2.concat(values);
|
|
}
|
|
console.log(scan1Res2); // ['foo', 'foobar', 'feelsgood']
|
|
// REMOVE_START
|
|
console.assert(scan1Res2.sort().toString() === ['foo', 'foobar', 'feelsgood'].sort().toString());
|
|
await client.del('myset');
|
|
// REMOVE_END
|
|
// STEP_END
|
|
|
|
// STEP_START scan2
|
|
// REMOVE_START
|
|
for (let i = 1; i <= 1000; i++) {
|
|
await client.set(`key:${i}`, i);
|
|
}
|
|
// REMOVE_END
|
|
let cursor = '0';
|
|
let scanResult;
|
|
|
|
scanResult = await client.scan(cursor, { MATCH: '*11*' });
|
|
console.log(scanResult.cursor, scanResult.keys);
|
|
|
|
scanResult = await client.scan(scanResult.cursor, { MATCH: '*11*' });
|
|
console.log(scanResult.cursor, scanResult.keys);
|
|
|
|
scanResult = await client.scan(scanResult.cursor, { MATCH: '*11*' });
|
|
console.log(scanResult.cursor, scanResult.keys);
|
|
|
|
scanResult = await client.scan(scanResult.cursor, { MATCH: '*11*' });
|
|
console.log(scanResult.cursor, scanResult.keys);
|
|
|
|
scanResult = await client.scan(scanResult.cursor, { MATCH: '*11*', COUNT: 1000 });
|
|
console.log(scanResult.cursor, scanResult.keys);
|
|
// REMOVE_START
|
|
console.assert(scanResult.keys.length === 18);
|
|
cursor = '0';
|
|
const prefix = 'key:*';
|
|
do {
|
|
scanResult = await client.scan(cursor, { MATCH: prefix, COUNT: 1000 });
|
|
console.log(scanResult.cursor, scanResult.keys);
|
|
cursor = scanResult.cursor;
|
|
const keys = scanResult.keys;
|
|
if (keys.length) {
|
|
await client.del(keys);
|
|
}
|
|
} while (cursor !== '0');
|
|
// REMOVE_END
|
|
// STEP_END
|
|
|
|
// STEP_START scan3
|
|
const scan3Res1 = await client.geoAdd('geokey', { longitude: 0, latitude: 0, member: 'value' });
|
|
console.log(scan3Res1); // 1
|
|
|
|
const scan3Res2 = await client.zAdd('zkey', [{ score: 1000, value: 'value' }]);
|
|
console.log(scan3Res2); // 1
|
|
|
|
const scan3Res3 = await client.type('geokey');
|
|
console.log(scan3Res3); // zset
|
|
// REMOVE_START
|
|
console.assert(scan3Res3 === 'zset');
|
|
// REMOVE_END
|
|
|
|
const scan3Res4 = await client.type('zkey');
|
|
console.log(scan3Res4); // zset
|
|
// REMOVE_START
|
|
console.assert(scan3Res4 === 'zset');
|
|
// REMOVE_END
|
|
|
|
const scan3Res5 = await client.scan('0', { TYPE: 'zset' });
|
|
console.log(scan3Res5.keys); // ['zkey', 'geokey']
|
|
// REMOVE_START
|
|
console.assert(scan3Res5.keys.sort().toString() === ['zkey', 'geokey'].sort().toString());
|
|
await client.del(['geokey', 'zkey']);
|
|
// REMOVE_END
|
|
// STEP_END
|
|
|
|
// STEP_START scan4
|
|
const scan4Res1 = await client.hSet('myhash', { a: 1, b: 2 });
|
|
console.log(scan4Res1); // 2
|
|
|
|
const scan4Res2 = await client.hScan('myhash', '0');
|
|
console.log(scan4Res2.entries); // [{field: 'a', value: '1'}, {field: 'b', value: '2'}]
|
|
// REMOVE_START
|
|
assert.deepEqual(scan4Res2.entries, [
|
|
{ field: 'a', value: '1' },
|
|
{ field: 'b', value: '2' }
|
|
]);
|
|
// REMOVE_END
|
|
|
|
const scan4Res3 = await client.hScan('myhash', '0', { COUNT: 10 });
|
|
const items = scan4Res3.entries.map((item) => item.field)
|
|
console.log(items); // ['a', 'b']
|
|
// REMOVE_START
|
|
assert.deepEqual(items, ['a', 'b'])
|
|
await client.del('myhash');
|
|
// REMOVE_END
|
|
// STEP_END
|
|
|
|
// HIDE_START
|
|
await client.close();
|
|
// HIDE_END
|