470d8a2e56
While dateStyle or timeStye is specified, we should not add property listed in "Table Components of date and time formats" per https://tc39.github.io/proposal-intl-datetime-style/#sec-initializedatetimeformat Bug: v8:9107 Change-Id: I3e39112ed5f99b05f30b2f50f3cd3102d094f98e Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1559213 Reviewed-by: Sathya Gunasekaran <gsathya@chromium.org> Commit-Queue: Frank Tang <ftang@chromium.org> Cr-Commit-Position: refs/heads/master@{#60725}
52 lines
1.3 KiB
JavaScript
52 lines
1.3 KiB
JavaScript
// Copyright 2019 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
// Flags: --harmony-intl-datetime-style
|
|
|
|
// Checks for security holes introduced by Object.property overrides.
|
|
// For example:
|
|
// Object.defineProperty(Array.prototype, 'locale', {
|
|
// set: function(value) {
|
|
// throw new Error('blah');
|
|
// },
|
|
// configurable: true,
|
|
// enumerable: false
|
|
// });
|
|
//
|
|
// would throw in case of (JS) x.locale = 'us' or (C++) x->Set('locale', 'us').
|
|
|
|
// First get supported properties.
|
|
// Some of the properties are optional, so we request them.
|
|
var properties = [];
|
|
var options = Intl.DateTimeFormat(
|
|
'en-US', {dateStyle: 'full', timeStyle: 'full'}).resolvedOptions();
|
|
for (var prop in options) {
|
|
if (options.hasOwnProperty(prop)) {
|
|
properties.push(prop);
|
|
}
|
|
}
|
|
|
|
// In the order of Table 6 of
|
|
// ecma402 #sec-intl.datetimeformat.prototype.resolvedoptions
|
|
var expectedProperties = [
|
|
'locale',
|
|
'calendar',
|
|
'numberingSystem',
|
|
'timeZone',
|
|
'hourCycle',
|
|
'hour12',
|
|
'dateStyle',
|
|
'timeStyle',
|
|
];
|
|
|
|
assertEquals(expectedProperties.length, properties.length);
|
|
|
|
properties.forEach(function(prop) {
|
|
assertFalse(expectedProperties.indexOf(prop) === -1);
|
|
});
|
|
|
|
taintProperties(properties);
|
|
|
|
var locale = Intl.DateTimeFormat().resolvedOptions().locale;
|