OLD | NEW |
---|---|
(Empty) | |
1 <!DOCTYPE html> | |
2 <meta charset="utf-8"> | |
3 <title>Key Generator behavior with explicit keys generator overflow</title> | |
4 <link rel=help href="https://w3c.github.io/IndexedDB/#key-generator-construct"> | |
5 <script src="/resources/testharness.js"></script> | |
6 <script src="/resources/testharnessreport.js"></script> | |
7 <script src="support.js"></script> | |
8 <script> | |
9 | |
10 function big_key_test(key, description) { | |
11 indexeddb_test( | |
12 (t, db) => { | |
13 assert_equals(indexedDB.cmp(key, key), 0, 'Key is valid'); | |
14 | |
15 db.createObjectStore('store', {autoIncrement: true}); | |
16 }, | |
17 (t, db) => { | |
18 const tx = db.transaction('store', 'readwrite'); | |
19 const store = tx.objectStore('store'); | |
20 const value = 0; | |
21 let request; | |
22 | |
23 request = store.put(value); | |
24 request.onerror = t.unreached_func('put should succeed'); | |
25 request.onsuccess = t.step_func(e => { | |
26 assert_equals(e.target.result, 1, | |
27 'Key generator should initially be 1'); | |
28 }); | |
29 | |
30 request = store.put(value); | |
31 request.onerror = t.unreached_func('put should succeed'); | |
32 request.onsuccess = t.step_func(e => { | |
33 assert_equals(e.target.result, 2, | |
34 'Key generator should increment'); | |
35 }); | |
36 | |
37 request = store.put(value, 1000); | |
38 request.onerror = t.unreached_func('put should succeed'); | |
39 request.onsuccess = t.step_func(e => { | |
40 assert_equals(e.target.result, 1000, | |
41 'Explicit key should be used'); | |
42 }); | |
43 | |
44 request = store.put(value); | |
45 request.onerror = t.unreached_func('put should succeed'); | |
46 request.onsuccess = t.step_func(e => { | |
47 assert_equals(e.target.result, 1001, | |
48 'Key generator should have updated'); | |
49 }); | |
50 | |
51 request = store.put(value, key); | |
52 request.onerror = t.unreached_func('put should succeed'); | |
53 request.onsuccess = t.step_func(e => { | |
54 assert_equals(e.target.result, key, | |
55 'Explicit key should be used'); | |
56 }); | |
57 | |
58 if (key >= 0) { | |
59 // Large positive values will max out the key generator, so it | |
60 // can no longer produce keys. | |
61 request = store.put(value); | |
62 request.onsuccess = t.unreached_func('put should fail'); | |
63 request.onerror = t.step_func(e => { | |
64 e.preventDefault(); | |
65 assert_equals(e.target.error.name, 'ConstraintError', | |
66 'Key generator should have returned failure'); | |
67 }); | |
68 } else { | |
69 // Large negative values are always lower than the key generator's | |
70 // current number, so have no effect on the generator. | |
71 request = store.put(value); | |
72 request.onerror = t.unreached_func('put should succeed'); | |
73 request.onsuccess = t.step_func(e => { | |
74 assert_equals(e.target.result, 1002, | |
75 'Key generator should have updated'); | |
76 }); | |
77 } | |
78 | |
79 request = store.put(value, 2000); | |
80 request.onerror = t.unreached_func('put should succeed'); | |
81 request.onsuccess = t.step_func(e => { | |
82 assert_equals(e.target.result, 2000, | |
83 'Explicit key should be used'); | |
84 }); | |
85 | |
86 tx.onabort = t.step_func(() => { | |
87 assert_unreached(`Transaction aborted: ${tx.error.message}`); | |
88 }); | |
89 tx.oncomplete = t.step_func(() => { t.done(); }); | |
90 }, | |
91 description); | |
92 } | |
93 | |
94 [ | |
95 { | |
pwnall
2017/03/07 19:42:41
Would it make sense to have two tests around the e
jsbell
2017/03/07 20:27:57
keygenerator-overflow.htm tests this, in theory. I
| |
96 key: Math.pow(2, 60), | |
97 description: 'greater than 53 bits, less than 64 bits' | |
98 }, | |
99 { | |
100 key: -Math.pow(2, 60), | |
101 description: 'greater than 53 bits, less than 64 bits (negative)' | |
102 }, | |
103 { | |
104 key: Math.pow(2, 63), | |
105 description: '63 bits' | |
106 }, | |
107 { | |
108 key: -Math.pow(2, 63), | |
109 description: '63 bits (negative)' | |
110 }, | |
111 { | |
112 key: Math.pow(2, 64), | |
113 description: '64 bits' | |
114 }, | |
115 { | |
116 key: -Math.pow(2, 64), | |
117 description: '64 bits (negative)' | |
118 }, | |
119 { | |
120 key: Math.pow(2, 70), | |
121 description: 'greater than 64 bits, but still finite' | |
122 }, | |
123 { | |
124 key: -Math.pow(2, 70), | |
125 description: 'greater than 64 bits, but still finite (negative)' | |
126 }, | |
127 { | |
128 key: Infinity, | |
129 description: 'equal to Infinity' | |
130 }, | |
131 { | |
132 key: -Infinity, | |
133 description: 'equal to -Infinity' | |
134 } | |
135 ].forEach(function(testCase) { | |
136 big_key_test(testCase.key, | |
137 `Key generator vs. explicit key ${testCase.description}`); | |
138 }); | |
139 | |
140 | |
141 | |
142 </script> | |
OLD | NEW |