Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(20)

Side by Side Diff: test/mjsunit/wasm/grow-memory.js

Issue 2216443002: [wasm] Grow memory should return -1 on failure. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Created 4 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2016 the V8 project authors. All rights reserved. 1 // Copyright 2016 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 // Flags: --expose-wasm --expose-gc --stress-compaction 5 // Flags: --expose-wasm --expose-gc --stress-compaction
6 6
7 load("test/mjsunit/wasm/wasm-constants.js"); 7 load("test/mjsunit/wasm/wasm-constants.js");
8 load("test/mjsunit/wasm/wasm-module-builder.js"); 8 load("test/mjsunit/wasm/wasm-module-builder.js");
9 9
10 var kPageSize = 0x10000; 10 var kPageSize = 0x10000;
(...skipping 23 matching lines...) Expand all
34 34
35 for(offset = 0; offset <= (kPageSize - 4); offset++) { 35 for(offset = 0; offset <= (kPageSize - 4); offset++) {
36 poke(20); 36 poke(20);
37 assertEquals(peek(), 20); 37 assertEquals(peek(), 20);
38 } 38 }
39 for (offset = kPageSize - 3; offset < kPageSize + 4; offset++) { 39 for (offset = kPageSize - 3; offset < kPageSize + 4; offset++) {
40 assertTraps(kTrapMemOutOfBounds, poke); 40 assertTraps(kTrapMemOutOfBounds, poke);
41 assertTraps(kTrapMemOutOfBounds, peek); 41 assertTraps(kTrapMemOutOfBounds, peek);
42 } 42 }
43 43
44 try { 44 var result = growMem(3);
45 assertEquals(growMem(3), 1); 45 assertTrue(result === 1 || result === -1);
ahaas 2016/08/04 07:17:34 What do you actually assert here? Should growMem f
gdeepti 2016/08/04 16:12:43 The intent here was to reduce flakiness due to all
46 } catch (e) {
47 assertEquals("object", typeof e);
48 assertEquals(e.message, kTrapMsgs[kTrapMemAllocationFail]);
49 return;
50 }
51 46
52 for (offset = kPageSize; offset <= 4*kPageSize -4; offset++) { 47 for (offset = kPageSize; offset <= 4*kPageSize -4; offset++) {
53 poke(20); 48 poke(20);
54 assertEquals(peek(), 20); 49 assertEquals(peek(), 20);
55 } 50 }
56 for (offset = 4*kPageSize - 3; offset < 4*kPageSize + 4; offset++) { 51 for (offset = 4*kPageSize - 3; offset < 4*kPageSize + 4; offset++) {
57 assertTraps(kTrapMemOutOfBounds, poke); 52 assertTraps(kTrapMemOutOfBounds, poke);
58 assertTraps(kTrapMemOutOfBounds, peek); 53 assertTraps(kTrapMemOutOfBounds, peek);
59 } 54 }
60 55
61 try { 56 var result = growMem(15);
62 assertEquals(growMem(15), 4); 57 assertTrue(result === 4 || result === -1);
ahaas 2016/08/04 07:17:34 Same here.
63 } catch (e) {
64 assertEquals("object", typeof e);
65 assertEquals(e.message, kTrapMsgs[kTrapMemAllocationFail]);
66 return;
67 }
68 58
69 for (offset = 4*kPageSize - 3; offset <= 4*kPageSize + 4; offset++) { 59 for (offset = 4*kPageSize - 3; offset <= 4*kPageSize + 4; offset++) {
70 poke(20); 60 poke(20);
71 assertEquals(peek(), 20); 61 assertEquals(peek(), 20);
72 } 62 }
73 for (offset = 19*kPageSize - 10; offset <= 19*kPageSize - 4; offset++) { 63 for (offset = 19*kPageSize - 10; offset <= 19*kPageSize - 4; offset++) {
74 poke(20); 64 poke(20);
75 assertEquals(peek(), 20); 65 assertEquals(peek(), 20);
76 } 66 }
77 for (offset = 19*kPageSize - 3; offset < 19*kPageSize + 5; offset++) { 67 for (offset = 19*kPageSize - 3; offset < 19*kPageSize + 5; offset++) {
78 assertTraps(kTrapMemOutOfBounds, poke); 68 assertTraps(kTrapMemOutOfBounds, poke);
79 assertTraps(kTrapMemOutOfBounds, peek); 69 assertTraps(kTrapMemOutOfBounds, peek);
80 } 70 }
81 } 71 }
82 72
83 testGrowMemoryReadWrite(); 73 testGrowMemoryReadWrite();
84 74
85 function testGrowMemoryZeroInitialSize() { 75 function testGrowMemoryZeroInitialSize() {
86 var builder = genGrowMemoryBuilder(); 76 var builder = genGrowMemoryBuilder();
87 var module = builder.instantiate(); 77 var module = builder.instantiate();
88 var offset; 78 var offset;
89 function peek() { return module.exports.load(offset); } 79 function peek() { return module.exports.load(offset); }
90 function poke(value) { return module.exports.store(offset, value); } 80 function poke(value) { return module.exports.store(offset, value); }
91 function growMem(pages) { return module.exports.grow_memory(pages); } 81 function growMem(pages) { return module.exports.grow_memory(pages); }
92 82
93 assertTraps(kTrapMemOutOfBounds, peek); 83 assertTraps(kTrapMemOutOfBounds, peek);
94 assertTraps(kTrapMemOutOfBounds, poke); 84 assertTraps(kTrapMemOutOfBounds, poke);
95 85
96 try { 86 var result = growMem(1);
97 assertEquals(growMem(1), 0); 87 assertTrue(result === 0 || result === -1);
ahaas 2016/08/04 07:17:34 Same here.
98 } catch (e) {
99 assertEquals("object", typeof e);
100 assertEquals(e.message, kTrapMsgs[kTrapMemAllocationFail]);
101 return;
102 }
103 88
104 for(offset = 0; offset <= kPageSize - 4; offset++) { 89 for(offset = 0; offset <= kPageSize - 4; offset++) {
105 poke(20); 90 poke(20);
106 assertEquals(peek(), 20); 91 assertEquals(peek(), 20);
107 } 92 }
108 93
109 //TODO(gdeepti): Fix tests with correct write boundaries 94 //TODO(gdeepti): Fix tests with correct write boundaries
110 //when runtime function is fixed. 95 //when runtime function is fixed.
111 for(offset = kPageSize; offset <= kPageSize + 5; offset++) { 96 for(offset = kPageSize; offset <= kPageSize + 5; offset++) {
112 assertTraps(kTrapMemOutOfBounds, peek); 97 assertTraps(kTrapMemOutOfBounds, peek);
113 } 98 }
114 } 99 }
115 100
116 testGrowMemoryZeroInitialSize(); 101 testGrowMemoryZeroInitialSize();
117 102
118 function testGrowMemoryTrapMaxPagesZeroInitialMemory() { 103 function testGrowMemoryTrapMaxPagesZeroInitialMemory() {
119 var builder = genGrowMemoryBuilder(); 104 var builder = genGrowMemoryBuilder();
120 var module = builder.instantiate(); 105 var module = builder.instantiate();
121 var maxPages = 16385; 106 var maxPages = 16385;
122 function growMem() { return module.exports.grow_memory(maxPages); } 107 function growMem(pages) { return module.exports.grow_memory(pages); }
123 assertTraps(kTrapMemOutOfBounds, growMem); 108 assertEquals(growMem(maxPages), -1);
124 } 109 }
125 110
126 testGrowMemoryTrapMaxPagesZeroInitialMemory(); 111 testGrowMemoryTrapMaxPagesZeroInitialMemory();
127 112
128 function testGrowMemoryTrapMaxPages() { 113 function testGrowMemoryTrapMaxPages() {
129 var builder = genGrowMemoryBuilder(); 114 var builder = genGrowMemoryBuilder();
130 builder.addMemory(1, 1, false); 115 builder.addMemory(1, 1, false);
131 var module = builder.instantiate(); 116 var module = builder.instantiate();
132 var maxPages = 16384; 117 var maxPages = 16384;
133 function growMem() { return module.exports.grow_memory(maxPages); } 118 function growMem(pages) { return module.exports.grow_memory(pages); }
134 assertTraps(kTrapMemOutOfBounds, growMem); 119 assertEquals(growMem(maxPages), -1);
135 } 120 }
136 121
137 testGrowMemoryTrapMaxPages(); 122 testGrowMemoryTrapMaxPages();
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698