From e7823553440225b68498c232ea0db6abfbbf447f Mon Sep 17 00:00:00 2001 From: Avi Fenesh <55848801+avifenesh@users.noreply.github.com> Date: Fri, 13 Sep 2024 23:42:39 +0300 Subject: [PATCH] fix scan tests (#2290) Signed-off-by: avifenesh --- node/package.json | 1 - node/tests/ScanTest.test.ts | 78 +++++++++++++++++-------------------- 2 files changed, 36 insertions(+), 43 deletions(-) diff --git a/node/package.json b/node/package.json index c70f108b74..823885e9bf 100644 --- a/node/package.json +++ b/node/package.json @@ -51,7 +51,6 @@ "@types/redis-server": "^1.2.2", "@types/semver": "^7.5.8", "@types/uuid": "^10.0.0", - "babel-jest": "^29.7.0", "find-free-port": "^2.0.0", "jest": "^29.7.0", "jest-html-reporter": "^3.10.2", diff --git a/node/tests/ScanTest.test.ts b/node/tests/ScanTest.test.ts index eaec19e640..faf0ac739c 100644 --- a/node/tests/ScanTest.test.ts +++ b/node/tests/ScanTest.test.ts @@ -59,10 +59,15 @@ describe("Scan GlideClusterClient", () => { getClientConfigurationOption(cluster.getAddresses(), protocol), ); // Iterate over all keys in the cluster + const [key1, key2, key3] = [ + `key:${uuidv4()}`, + `key:${uuidv4()}`, + `key:${uuidv4()}`, + ]; await client.mset([ - { key: "key1", value: "value1" }, - { key: "key2", value: "value2" }, - { key: "key3", value: "value3" }, + { key: key1, value: "value1" }, + { key: key2, value: "value2" }, + { key: key3, value: "value3" }, ]); let cursor = new ClusterScanCursor(); const allKeys: GlideString[] = []; @@ -74,16 +79,13 @@ describe("Scan GlideClusterClient", () => { } expect(allKeys).toHaveLength(3); - expect(allKeys).toEqual( - expect.arrayContaining(["key1", "key2", "key3"]), - ); + expect(allKeys).toEqual(expect.arrayContaining([key1, key2, key3])); // Iterate over keys matching a pattern + const [key4, key5] = ["notMykey", "somethingElse"]; await client.mset([ - { key: "key1", value: "value1" }, - { key: "key2", value: "value2" }, - { key: "notMykey", value: "value3" }, - { key: "somethingElse", value: "value4" }, + { key: key4, value: "value4" }, + { key: key5, value: "value5" }, ]); cursor = new ClusterScanCursor(); const matchedKeys: GlideString[] = []; @@ -97,16 +99,11 @@ describe("Scan GlideClusterClient", () => { } expect(matchedKeys).toEqual( - expect.arrayContaining(["key1", "key2", "key3", "notMykey"]), + expect.arrayContaining([key1, key2, key3, key4]), ); expect(matchedKeys).not.toContain("somethingElse"); // Iterate over keys of a specific type - await client.mset([ - { key: "key1", value: "value1" }, - { key: "key2", value: "value2" }, - { key: "key3", value: "value3" }, - ]); await client.sadd("thisIsASet", ["value4"]); cursor = new ClusterScanCursor(); const stringKeys: GlideString[] = []; @@ -119,7 +116,7 @@ describe("Scan GlideClusterClient", () => { } expect(stringKeys).toEqual( - expect.arrayContaining(["key1", "key2", "key3"]), + expect.arrayContaining([key1, key2, key3, key4, key5]), ); expect(stringKeys).not.toContain("thisIsASet"); }, @@ -386,16 +383,15 @@ describe("Scan GlideClient", () => { let cluster: ValkeyCluster; let client: GlideClient; beforeAll(async () => { - const clusterAddresses = parseCommandLineArgs()["cluster-endpoints"]; - // Connect to cluster or create a new one based on the parsed addresses - cluster = clusterAddresses + const standaloneAddresses = + parseCommandLineArgs()["standalone-endpoints"]; + cluster = standaloneAddresses ? await ValkeyCluster.initFromExistingCluster( - true, - parseEndpoints(clusterAddresses), + false, + parseEndpoints(standaloneAddresses), getServerVersion, ) - : // setting replicaCount to 1 to facilitate tests routed to replicas - await ValkeyCluster.createCluster(false, 3, 1, getServerVersion); + : await ValkeyCluster.createCluster(false, 1, 1, getServerVersion); }, 20000); afterEach(async () => { @@ -409,16 +405,21 @@ describe("Scan GlideClient", () => { }); it.each([ProtocolVersion.RESP2, ProtocolVersion.RESP3])( - `GlideClient test basic cluster scan_%p`, + `GlideClient test basic scan_%p`, async (protocol) => { client = await GlideClient.createClient( getClientConfigurationOption(cluster.getAddresses(), protocol), ); // Iterate over all keys in the cluster + const [key1, key2, key3] = [ + `key:${uuidv4()}`, + `key:${uuidv4()}`, + `key:${uuidv4()}`, + ]; await client.mset([ - { key: "key1", value: "value1" }, - { key: "key2", value: "value2" }, - { key: "key3", value: "value3" }, + { key: key1, value: "value1" }, + { key: key2, value: "value2" }, + { key: key3, value: "value3" }, ]); let cursor: GlideString = "0"; const allKeys: GlideString[] = []; @@ -430,16 +431,14 @@ describe("Scan GlideClient", () => { } while (cursor !== "0"); expect(allKeys).toHaveLength(3); - expect(allKeys).toEqual( - expect.arrayContaining(["key1", "key2", "key3"]), - ); + expect(allKeys).toEqual(expect.arrayContaining([key1, key2, key3])); // Iterate over keys matching a pattern + const key4 = "notMykey"; + const key5 = "somethingElse"; await client.mset([ - { key: "key1", value: "value1" }, - { key: "key2", value: "value2" }, - { key: "notMykey", value: "value3" }, - { key: "somethingElse", value: "value4" }, + { key: key4, value: "value4" }, + { key: key5, value: "value5" }, ]); cursor = "0"; const matchedKeys: GlideString[] = []; @@ -453,16 +452,11 @@ describe("Scan GlideClient", () => { } while (cursor !== "0"); expect(matchedKeys).toEqual( - expect.arrayContaining(["key1", "key2", "key3", "notMykey"]), + expect.arrayContaining([key1, key2, key3, key4]), ); expect(matchedKeys).not.toContain("somethingElse"); // Iterate over keys of a specific type - await client.mset([ - { key: "key1", value: "value1" }, - { key: "key2", value: "value2" }, - { key: "key3", value: "value3" }, - ]); await client.sadd("thisIsASet", ["value4"]); cursor = "0"; const stringKeys: GlideString[] = []; @@ -475,7 +469,7 @@ describe("Scan GlideClient", () => { } while (cursor !== "0"); expect(stringKeys).toEqual( - expect.arrayContaining(["key1", "key2", "key3"]), + expect.arrayContaining([key1, key2, key3, key4, key5]), ); expect(stringKeys).not.toContain("thisIsASet"); },