Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 80 } | 80 } |
| 81 return true; | 81 return true; |
| 82 } | 82 } |
| 83 if (objectClass == 'String' || objectClass == 'Number' || | 83 if (objectClass == 'String' || objectClass == 'Number' || |
| 84 objectClass == 'Boolean' || objectClass == 'Date') { | 84 objectClass == 'Boolean' || objectClass == 'Date') { |
| 85 if (a.valueOf() !== b.valueOf()) return false; | 85 if (a.valueOf() !== b.valueOf()) return false; |
| 86 } | 86 } |
| 87 return deepObjectEquals(a, b); | 87 return deepObjectEquals(a, b); |
| 88 } | 88 } |
| 89 | 89 |
| 90 | |
| 91 /** | 90 /** |
| 92 * Throws an exception, and prints the values in case of error. | 91 * Throws an exception containing the user_message (if any) and the values. |
| 93 */ | 92 */ |
| 94 function fail(expected, found) { | 93 function fail(expected, found, user_message = '') { |
| 95 // TODO(cira): Replace String with PrettyPrint for objects and arrays. | 94 // TODO(cira): Replace String with PrettyPrint for objects and arrays. |
| 96 var message = 'Failure: expected <' + String(expected) + '>, found <' + | 95 var message = 'Failure' + (user_message ? ' (' + user_message + ')' : "") + |
|
JF
2016/04/06 17:00:20
Mixing single and double quotes is odd :-)
Clemens Hammacher
2016/04/07 07:42:52
Done.
| |
| 97 String(found) + '>.'; | 96 ': expected <' + String(expected) + '>, found <' + String(found) + '>.'; |
| 98 throw new Error(message); | 97 throw new Error(message); |
| 99 } | 98 } |
| 100 | 99 |
| 101 | 100 |
| 102 /** | 101 /** |
| 103 * Throws if two variables have different types or values. | 102 * Throws if two variables have different types or values. |
| 104 */ | 103 */ |
| 105 function assertEquals(expected, found) { | 104 function assertEquals(expected, found, user_message = '') { |
| 106 if (!deepEquals(expected, found)) { | 105 if (!deepEquals(expected, found)) { |
| 107 fail(expected, found); | 106 fail(expected, found, user_message); |
| 108 } | 107 } |
| 109 } | 108 } |
| 110 | 109 |
| 111 | 110 |
| 112 /** | 111 /** |
| 113 * Throws if value is false. | 112 * Throws if value is false. |
| 114 */ | 113 */ |
| 115 function assertTrue(value) { | 114 function assertTrue(value, user_message = '') { |
| 116 assertEquals(true, value) | 115 assertEquals(true, value, user_message); |
| 117 } | 116 } |
| 118 | 117 |
| 119 | 118 |
| 120 /** | 119 /** |
| 121 * Throws if value is true. | 120 * Throws if value is true. |
| 122 */ | 121 */ |
| 123 function assertFalse(value) { | 122 function assertFalse(value, user_message = '') { |
| 124 assertEquals(false, value); | 123 assertEquals(false, value, user_message); |
| 125 } | 124 } |
| 126 | 125 |
| 127 | 126 |
| 128 /** | 127 /** |
| 129 * Returns true if code throws specified exception. | 128 * Returns if the code throws the specified exception, throws otherwise. |
|
titzer
2016/04/06 18:22:10
You can just reword to "Runs {code} and asserts th
Clemens Hammacher
2016/04/07 07:42:52
Done.
| |
| 130 */ | 129 */ |
| 131 function assertThrows(code, type_opt, cause_opt) { | 130 function assertThrows(code, type_opt, cause_opt) { |
| 132 var threwException = true; | 131 var threwException = true; |
|
titzer
2016/04/06 18:22:10
I just noticed this variable is dead.
Clemens Hammacher
2016/04/07 07:42:52
Right, I will remove it.
| |
| 133 try { | 132 try { |
| 134 if (typeof code == 'function') { | 133 if (typeof code == 'function') { |
| 135 code(); | 134 code(); |
| 136 } else { | 135 } else { |
| 137 eval(code); | 136 eval(code); |
| 138 } | 137 } |
| 139 threwException = false; | 138 threwException = false; |
| 140 } catch (e) { | 139 } catch (e) { |
| 141 if (typeof type_opt == 'function') { | 140 if (typeof type_opt == 'function') { |
| 142 assertInstanceof(e, type_opt); | 141 assertInstanceof(e, type_opt); |
| 143 } | 142 } |
| 144 if (arguments.length >= 3) { | 143 if (arguments.length >= 3) { |
| 145 assertEquals(e.type, cause_opt); | 144 assertEquals(cause_opt, e.type, 'thrown exception type mismatch'); |
| 146 } | 145 } |
| 147 // Success. | 146 // Success. |
| 148 return; | 147 return; |
| 149 } | 148 } |
| 150 throw new Error("Did not throw exception"); | 149 var expected = arguments.length >= 3 ? cause_opt : |
| 150 typeof type_opt == 'function' ? type_opt : 'any exception'; | |
| 151 fail(expected, "no exception", "expected thrown exception"); | |
| 151 } | 152 } |
| 152 | 153 |
| 153 | 154 |
| 154 /** | 155 /** |
| 155 * Throws an exception if code throws. | 156 * Throws an exception if code throws. |
|
titzer
2016/04/06 18:22:10
You can reword this similarly. "Runs {code} and as
Clemens Hammacher
2016/04/07 07:42:52
Done.
| |
| 156 */ | 157 */ |
| 157 function assertDoesNotThrow(code, name_opt) { | 158 function assertDoesNotThrow(code, user_message = '') { |
| 158 try { | 159 try { |
| 159 if (typeof code == 'function') { | 160 if (typeof code == 'function') { |
| 160 code(); | 161 code(); |
| 161 } else { | 162 } else { |
| 162 eval(code); | 163 eval(code); |
| 163 } | 164 } |
| 164 } catch (e) { | 165 } catch (e) { |
| 165 fail("threw an exception: ", e.message || e, name_opt); | 166 fail("no expection", "exception: " + String(e), user_message); |
| 166 } | 167 } |
| 167 } | 168 } |
| 168 | 169 |
| 169 | 170 |
| 170 /** | 171 /** |
| 171 * Throws if obj is not of given type. | 172 * Throws if obj is not of given type. |
| 172 */ | 173 */ |
| 173 function assertInstanceof(obj, type) { | 174 function assertInstanceof(obj, type) { |
| 174 if (!(obj instanceof type)) { | 175 if (!(obj instanceof type)) { |
| 175 var actualTypeName = null; | 176 var actualTypeName = null; |
| 176 var actualConstructor = Object.prototypeOf(obj).constructor; | 177 var actualConstructor = Object.prototypeOf(obj).constructor; |
| 177 if (typeof actualConstructor == "function") { | 178 if (typeof actualConstructor == "function") { |
| 178 actualTypeName = actualConstructor.name || String(actualConstructor); | 179 actualTypeName = actualConstructor.name || String(actualConstructor); |
| 179 } | 180 } |
| 180 throw new Error('Object <' + obj + '> is not an instance of <' + | 181 throw new Error('Object <' + obj + '> is not an instance of <' + |
| 181 (type.name || type) + '>' + | 182 (type.name || type) + '>' + |
| 182 (actualTypeName ? ' but of < ' + actualTypeName + '>' : '')); | 183 (actualTypeName ? ' but of < ' + actualTypeName + '>' : '')); |
| 183 } | 184 } |
| 184 } | 185 } |
| OLD | NEW |