summaryrefslogtreecommitdiff
path: root/cli/tests/unit
diff options
context:
space:
mode:
authorIgor Zinkovsky <igor@deno.com>2023-08-26 18:26:09 -0700
committerGitHub <noreply@github.com>2023-08-26 18:26:09 -0700
commite4cebf3e0da539321727b0f0e43ddce5679635b1 (patch)
tree8c3999e9d7dfe219e8e8a1036d058c89285c631b /cli/tests/unit
parentd104a09f796d3176ccd73a24906da87073cab85f (diff)
fix(kv) increase number of allowed mutations in atomic (#20126)
fixes #19741 Impose a limit on the total atomic payload size
Diffstat (limited to 'cli/tests/unit')
-rw-r--r--cli/tests/unit/kv_test.ts54
1 files changed, 52 insertions, 2 deletions
diff --git a/cli/tests/unit/kv_test.ts b/cli/tests/unit/kv_test.ts
index acda9a0e2..de764cf80 100644
--- a/cli/tests/unit/kv_test.ts
+++ b/cli/tests/unit/kv_test.ts
@@ -1214,6 +1214,28 @@ dbTest("operation size limit", async (db) => {
"too many checks (max 10)",
);
+ const validMutateKeys: Deno.KvKey[] = new Array(1000).fill(0).map((
+ _,
+ i,
+ ) => ["a", i]);
+ const invalidMutateKeys: Deno.KvKey[] = new Array(1001).fill(0).map((
+ _,
+ i,
+ ) => ["a", i]);
+
+ const res4 = await db.atomic()
+ .check(...lastValidKeys.map((key) => ({
+ key,
+ versionstamp: null,
+ })))
+ .mutate(...validMutateKeys.map((key) => ({
+ key,
+ type: "set",
+ value: 1,
+ } satisfies Deno.KvMutation)))
+ .commit();
+ assert(res4);
+
await assertRejects(
async () => {
await db.atomic()
@@ -1221,7 +1243,7 @@ dbTest("operation size limit", async (db) => {
key,
versionstamp: null,
})))
- .mutate(...firstInvalidKeys.map((key) => ({
+ .mutate(...invalidMutateKeys.map((key) => ({
key,
type: "set",
value: 1,
@@ -1229,7 +1251,35 @@ dbTest("operation size limit", async (db) => {
.commit();
},
TypeError,
- "too many mutations (max 10)",
+ "too many mutations (max 1000)",
+ );
+});
+
+dbTest("total mutation size limit", async (db) => {
+ const keys: Deno.KvKey[] = new Array(1000).fill(0).map((
+ _,
+ i,
+ ) => ["a", i]);
+
+ const atomic = db.atomic();
+ for (const key of keys) {
+ atomic.set(key, "foo");
+ }
+ const res = await atomic.commit();
+ assert(res);
+
+ // Use bigger values to trigger "total mutation size too large" error
+ await assertRejects(
+ async () => {
+ const value = new Array(3000).fill("a").join("");
+ const atomic = db.atomic();
+ for (const key of keys) {
+ atomic.set(key, value);
+ }
+ await atomic.commit();
+ },
+ TypeError,
+ "total mutation size too large (max 819200 bytes)",
);
});