Skip to content

Commit

Permalink
fix scan tests (valkey-io#2290)
Browse files Browse the repository at this point in the history
Signed-off-by: avifenesh <[email protected]>
  • Loading branch information
avifenesh authored Sep 13, 2024
1 parent 4cf70d2 commit e782355
Show file tree
Hide file tree
Showing 2 changed files with 36 additions and 43 deletions.
1 change: 0 additions & 1 deletion node/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -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",
Expand Down
78 changes: 36 additions & 42 deletions node/tests/ScanTest.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -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[] = [];
Expand All @@ -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[] = [];
Expand All @@ -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[] = [];
Expand All @@ -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");
},
Expand Down Expand Up @@ -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 () => {
Expand All @@ -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[] = [];
Expand All @@ -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[] = [];
Expand All @@ -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[] = [];
Expand All @@ -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");
},
Expand Down

0 comments on commit e782355

Please sign in to comment.