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

Unified Diff: test/intl/break-iterator/protected-icu-internals.js

Issue 148883002: Synchronize with r15594. (Closed) Base URL: https://v8.googlecode.com/svn/branches/experimental/a64
Patch Set: Created 6 years, 11 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 side-by-side diff with in-line comments
Download patch
Index: test/intl/break-iterator/protected-icu-internals.js
diff --git a/test/mjsunit/regress/regress-237617.js b/test/intl/break-iterator/protected-icu-internals.js
similarity index 72%
copy from test/mjsunit/regress/regress-237617.js
copy to test/intl/break-iterator/protected-icu-internals.js
index dabf828ae8bbfa3223e56664a97780098e6c5e3e..ad1dc54fbedf1f52687834bcbd1c64ee2a1dc4b1 100644
--- a/test/mjsunit/regress/regress-237617.js
+++ b/test/intl/break-iterator/protected-icu-internals.js
@@ -25,19 +25,25 @@
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-"use strict"
+// Internal object we got from native code should not be writable,
+// configurable or enumerable. One can still change its public properties, but
+// we don't use them to do actual work.
-function f() {
- throw new Error("test stack");
-}
+var iterator = new Intl.v8BreakIterator([]);
+
+// Direct write should fail.
+iterator.iterator = {'zzz':'some random object'};
-var error_stack = "";
+assertFalse(iterator.iterator.hasOwnProperty('zzz'));
+
+// Try redefining the property.
+var didThrow = false;
try {
- f.call(null);
-} catch (e) {
- error_stack = e.stack;
+ Object.defineProperty(iterator, 'iterator', {value: undefined});
+} catch(e) {
+ didThrow = true;
}
+assertTrue(didThrow);
-assertTrue(error_stack.indexOf("test stack") > 0);
-assertTrue(error_stack.indexOf("illegal") < 0);
-
+// Try deleting the property.
+assertFalse(delete iterator.iterator);
« no previous file with comments | « test/intl/break-iterator/property-override.js ('k') | test/intl/break-iterator/resolved-options-is-method.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698