Thanks to visit codestin.com
Credit goes to github.com

Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 3 additions & 5 deletions .github/workflows/tests.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -430,18 +430,16 @@ jobs:
pnpm add -g wrangler
working-directory: examples/cloudflare-workers

- name: Add account ID
run: echo 'account_id = "${{ secrets.CLOUDFLARE_ACCOUNT_ID }}"' >> wrangler.toml
working-directory: examples/cloudflare-workers
# - name: Add account ID
# run: echo 'account_id = "${{ secrets.CLOUDFLARE_ACCOUNT_ID }}"' >> wrangler.toml
# working-directory: examples/cloudflare-workers

- name: Start example
run: wrangler dev & sleep 5
working-directory: examples/cloudflare-workers
env:
CLOUDFLARE_API_TOKEN: ${{ secrets.CF_API_TOKEN }}

# - run: while [[ "$(curl -s -o /dev/null -w ''%{http_code}'' localhost:8787)" != "200" ]]; do sleep 1; done
# timeout-minutes: 2

- name: Test
run: deno test -A ./test.ts
Expand Down
43 changes: 43 additions & 0 deletions pkg/commands/zrange.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -132,3 +132,46 @@ Deno.test("bylex", async (t) => {
assertEquals(res3![1], "b");
});
});

Deno.test("rev", async (t) => {
await t.step("returns the set in reverse order", async () => {
const key = newKey();
const score1 = 2;
const member1 = randomID();

const score2 = 5;
const member2 = randomID();

await new ZAddCommand([
key,
{ score: score1, member: member1 },
{ score: score2, member: member2 },
]).exec(client);

const res = await new ZRangeCommand([key, 0, 7, { rev: true }]).exec(
client,
);
assertEquals(res.length, 2);
assertEquals(res![0], member2);
assertEquals(res![1], member1);
});
});

Deno.test("limit", async (t) => {
await t.step("returns only the first 2", async () => {
const key = newKey();
for (let i = 0; i < 10; i++) {
await new ZAddCommand([
key,
{ score: i, member: randomID() },
]).exec(client);
}

const res = await new ZRangeCommand([key, 0, 7, { offset: 0, count: 2 }])
.exec(
client,
);
console.log({ res });
assertEquals(res.length, 2);
});
});
18 changes: 16 additions & 2 deletions pkg/commands/zrange.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,19 @@
import { Command, CommandOptions } from "./command.ts";

export type ZRangeCommandOptions =
& { withScores?: boolean }
& {
withScores?: boolean;
rev?: boolean;
}
& (
| { byScore: true; byLex?: never }
| { byScore?: never; byLex: true }
| { byScore?: never; byLex?: never }
)
& (
| { offset: number; count: number }
| { offset?: never; count?: never }
);

/**
* @see https://redis.io/commands/zrange
*/
Expand Down Expand Up @@ -55,6 +61,14 @@ export class ZRangeCommand<TData extends unknown[]> extends Command<
if (opts?.byLex) {
command.push("bylex");
}
if (opts?.rev) {
command.push("rev");
}
if (
typeof opts?.count !== "undefined" && typeof opts?.offset !== "undefined"
) {
command.push("limit", opts.offset, opts.count);
}
if (opts?.withScores) {
command.push("withscores");
}
Expand Down