Left: | ||
Right: |
LEFT | RIGHT |
---|---|
1 /* | 1 /* |
2 * This file is part of Adblock Plus <https://adblockplus.org/>, | 2 * This file is part of Adblock Plus <https://adblockplus.org/>, |
3 * Copyright (C) 2006-present eyeo GmbH | 3 * Copyright (C) 2006-present eyeo GmbH |
4 * | 4 * |
5 * Adblock Plus is free software: you can redistribute it and/or modify | 5 * Adblock Plus is free software: you can redistribute it and/or modify |
6 * it under the terms of the GNU General Public License version 3 as | 6 * it under the terms of the GNU General Public License version 3 as |
7 * published by the Free Software Foundation. | 7 * published by the Free Software Foundation. |
8 * | 8 * |
9 * Adblock Plus is distributed in the hope that it will be useful, | 9 * Adblock Plus is distributed in the hope that it will be useful, |
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
(...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
68 result, | 68 result, |
69 `The property "${property}" ${result ? "should" : "shouldn't"} trigger an exception.` | 69 `The property "${property}" ${result ? "should" : "shouldn't"} trigger an exception.` |
70 ); | 70 ); |
71 test.equal( | 71 test.equal( |
72 value, | 72 value, |
73 result ? 1 : undefined, | 73 result ? 1 : undefined, |
74 `The value for "${property}" ${result ? "shouldn't" : "should"} have been read.` | 74 `The value for "${property}" ${result ? "shouldn't" : "should"} have been read.` |
75 ); | 75 ); |
76 } | 76 } |
77 | 77 |
78 window.abpTest = "foo"; | 78 window.abpTest = "fortytwo"; |
79 await runSnippet(test, "abort-on-property-read", "abpTest"); | 79 await runSnippet(test, "abort-on-property-read", "abpTest"); |
80 testProperty("abpTest"); | 80 testProperty("abpTest"); |
81 | 81 |
82 window.abpTest2 = {prop1: "foo"}; | 82 window.abpTest2 = {prop1: "fortytwo"}; |
Manish Jethani
2019/03/20 15:20:52
Would be nice if we did't use "foo" for the value
hub
2019/03/20 16:19:05
Done.
| |
83 await runSnippet(test, "abort-on-property-read", "abpTest2.prop1"); | 83 await runSnippet(test, "abort-on-property-read", "abpTest2.prop1"); |
84 testProperty("abpTest2.prop1"); | 84 testProperty("abpTest2.prop1"); |
85 | 85 |
86 // Test that we try to catch a property that doesn't exist yet. | 86 // Test that we try to catch a property that doesn't exist yet. |
87 await runSnippet(test, "abort-on-property-read", "abpTest3.prop1"); | 87 await runSnippet(test, "abort-on-property-read", "abpTest3.prop1"); |
88 window.abpTest3 = {prop1: "foo"}; | 88 window.abpTest3 = {prop1: "fortytwo"}; |
89 testProperty("abpTest3.prop1"); | 89 testProperty("abpTest3.prop1"); |
90 | 90 |
91 // Test that other properties don't trigger. | 91 // Test that other properties don't trigger. |
92 testProperty("abpTest3.prop2", false); | 92 testProperty("abpTest3.prop2", false); |
93 | 93 |
94 // Test overwriting the object with another object. | 94 // Test overwriting the object with another object. |
95 window.abpTest4 = {bar: {}}; | 95 window.abpTest4 = {prop3: {}}; |
Manish Jethani
2019/03/20 15:17:48
If we agree about the convention here then it shou
hub
2019/03/20 16:19:04
Done.
Manish Jethani
2019/03/20 16:43:32
LGTM
(What I really meant was that within a new l
hub
2019/03/20 16:52:16
the intent was to really get these unique across t
| |
96 await runSnippet(test, "abort-on-property-read", "abpTest4.bar.lambda"); | 96 await runSnippet(test, "abort-on-property-read", "abpTest4.prop3.foo"); |
97 testProperty("abpTest4.bar.lambda"); | 97 testProperty("abpTest4.prop3.foo"); |
98 window.abpTest4.bar = {}; | 98 window.abpTest4.prop3 = {}; |
99 testProperty("abpTest4.bar.lambda"); | 99 testProperty("abpTest4.prop3.foo"); |
100 | 100 |
101 // Test if we start with a non-object. | 101 // Test if we start with a non-object. |
102 window.abpTest5 = 5; | 102 window.abpTest5 = 42; |
Manish Jethani
2019/03/20 15:20:52
Nit: Same as above, would be nice to use 42 consis
hub
2019/03/20 16:19:05
Done.
| |
103 await runSnippet(test, "abort-on-property-read", "abpTest5.bar2.lambda"); | 103 await runSnippet(test, "abort-on-property-read", "abpTest5.prop4.bar"); |
104 | 104 |
105 testProperty("abpTest5.bar2.lambda", true, "TypeError"); | 105 testProperty("abpTest5.prop4.bar", true, "TypeError"); |
Manish Jethani
2019/03/20 15:17:48
Similarly, `abpTest5.prop1.foo`
(Sorry, the next
hub
2019/03/20 16:19:04
Done.
| |
106 | 106 |
107 window.abpTest5 = {bar2: 42}; | 107 window.abpTest5 = {prop4: 42}; |
108 testProperty("abpTest5.bar2.lambda", false); | 108 testProperty("abpTest5.prop4.bar", false); |
109 window.abpTest5 = {bar2: {}}; | 109 window.abpTest5 = {prop4: {}}; |
110 testProperty("abpTest5.bar2.lambda"); | 110 testProperty("abpTest5.prop4.bar"); |
111 | 111 |
112 test.done(); | 112 test.done(); |
113 }; | 113 }; |
LEFT | RIGHT |