Upgrade V8 to version 4.9.385.28

https://chromium.googlesource.com/v8/v8/+/4.9.385.28

FPIIM-449

Change-Id: I4b2e74289d4bf3667f2f3dc8aa2e541f63e26eb4
diff --git a/test/test262/test262.status b/test/test262/test262.status
index d32f8f3..a7f76a4 100644
--- a/test/test262/test262.status
+++ b/test/test262/test262.status
@@ -29,66 +29,438 @@
 [ALWAYS, {
   ############################### BUGS ###################################
 
-  '15.5.4.9_CE': [['no_i18n', SKIP]],
-
   # BUG(v8:3455)
-  '11.2.3_b': [FAIL],
-  '12.2.3_b': [FAIL],
+  'intl402/11.2.3_b': [FAIL],
+  'intl402/12.2.3_b': [FAIL],
 
-  ############################### ES6 ###################################
-  # ES6 allows block-local functions.
-  'Sbp_A1_T1': [PASS, FAIL_OK],
-  'Sbp_A2_T1': [PASS, FAIL_OK],
-  'Sbp_A2_T2': [PASS, FAIL_OK],
-  'Sbp_A3_T1': [PASS, FAIL_OK],
-  'Sbp_A3_T2': [PASS, FAIL_OK],
-  'Sbp_A4_T1': [PASS, FAIL_OK],
-  'Sbp_A4_T2': [PASS, FAIL_OK],
-  'Sbp_A5_T1': [PASS], # Test is broken (strict reference to unbound variable)
-  'Sbp_A5_T2': [PASS, FAIL_OK],
+  # Unicode canonicalization is not available with i18n turned off.
+  'built-ins/String/prototype/localeCompare/15.5.4.9_CE': [['no_i18n', SKIP]],
 
-  # Passes in ES6 since {__arr} syntax is parsed as object literal.
-  'S12.1_A4_T2': [PASS, FAIL_OK],
-  'S12.6.4_A15': [PASS, FAIL_OK],
+  ###################### NEEDS INVESTIGATION #######################
+
+  # Possibly same cause as S8.5_A2.1, below: floating-point tests.
+  'built-ins/Math/cos/S15.8.2.7_A7': [PASS, FAIL_OK],
+  'built-ins/Math/sin/S15.8.2.16_A7': [PASS, FAIL_OK],
+  'built-ins/Math/tan/S15.8.2.18_A7': [PASS, FAIL_OK],
+
+  # This is an incompatibility between ES5 and V8 on enumerating
+  # shadowed elements in a for..in loop.
+  # https://code.google.com/p/v8/issues/detail?id=705
+  'language/statements/for-in/12.6.4-2': [PASS, FAIL_OK],
+
+  ###################### MISSING ES6 FEATURES #######################
+
+  # It's unclear what the right behavior for [[Enumerate]] is; we're awaiting
+  # clarification in the spec. Currently, our for-in implementation for
+  # Proxies checks all trap result values for being strings...
+  'built-ins/Proxy/enumerate/return-trap-result': [FAIL],
+  # ...and our Reflect.enumerate implementation is built on for-in by wrapping
+  # the iteration's results in a new generator; this postpones exceptions.
+  'built-ins/Reflect/enumerate/return-abrupt-from-result': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4093
+  'built-ins/Array/symbol-species': [FAIL],
+  'built-ins/Array/symbol-species-name': [FAIL],
+  'built-ins/ArrayBuffer/symbol-species': [FAIL],
+  'built-ins/ArrayBuffer/symbol-species-name': [FAIL],
+  'built-ins/ArrayBuffer/prototype/slice/species-constructor-is-not-object': [FAIL],
+  'built-ins/ArrayBuffer/prototype/slice/species-returns-smaller-arraybuffer': [FAIL],
+  'built-ins/ArrayBuffer/prototype/slice/species-is-not-object': [FAIL],
+  'built-ins/ArrayBuffer/prototype/slice/species-is-not-constructor': [FAIL],
+  'built-ins/ArrayBuffer/prototype/slice/species-returns-larger-arraybuffer': [FAIL],
+  'built-ins/ArrayBuffer/prototype/slice/species-returns-not-arraybuffer': [FAIL],
+  'built-ins/ArrayBuffer/prototype/slice/species-returns-same-arraybuffer': [FAIL],
+  'built-ins/ArrayBuffer/prototype/slice/species': [FAIL],
+  'built-ins/Map/symbol-species': [FAIL],
+  'built-ins/Map/symbol-species-name': [FAIL],
+  'built-ins/Promise/Symbol.species/prop-desc': [FAIL],
+  'built-ins/Promise/Symbol.species/return-value': [FAIL],
+  'built-ins/Promise/all/species-get-error': [PASS, FAIL],
+  'built-ins/Promise/prototype/then/ctor-custom': [FAIL],
+  'built-ins/Promise/race/species-get-error': [PASS, FAIL],
+  'built-ins/Promise/symbol-species': [FAIL],
+  'built-ins/Promise/symbol-species-name': [FAIL],
+  'built-ins/RegExp/symbol-species': [FAIL],
+  'built-ins/RegExp/symbol-species-name': [FAIL],
+  'built-ins/Set/symbol-species': [FAIL],
+  'built-ins/Set/symbol-species-name': [FAIL],
+  'built-ins/Symbol/species/basic': [FAIL],
+  'built-ins/Symbol/species/builtin-getter-name': [FAIL],
+  'built-ins/Symbol/species/subclassing': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4163
+  'built-ins/GeneratorPrototype/next/context-constructor-invocation': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=3566
+  'built-ins/Array/from/iter-map-fn-err': [FAIL],
+  'built-ins/Array/from/iter-set-elem-prop-err': [FAIL],
+  'built-ins/Map/iterator-close-after-set-failure': [FAIL],
+  'built-ins/Map/iterator-item-first-entry-returns-abrupt': [FAIL],
+  'built-ins/Map/iterator-item-second-entry-returns-abrupt': [FAIL],
+  'built-ins/Map/iterator-items-are-not-object-close-iterator': [FAIL],
+  'built-ins/Promise/all/iter-close': [FAIL],
+  'built-ins/Set/set-iterator-close-after-add-failure': [FAIL],
+  'built-ins/WeakMap/iterator-close-after-set-failure': [FAIL],
+  'built-ins/WeakMap/iterator-item-first-entry-returns-abrupt': [FAIL],
+  'built-ins/WeakMap/iterator-item-second-entry-returns-abrupt': [FAIL],
+  'built-ins/WeakMap/iterator-items-are-not-object-close-iterator': [FAIL],
+  'built-ins/WeakSet/iterator-close-after-add-failure': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4119
+  'built-ins/RegExp/call_with_non_regexp_same_constructor': [FAIL],
+  'built-ins/RegExp/from-regexp-like-short-circuit': [FAIL],
+  'built-ins/RegExp/from-regexp-like': [FAIL],
+  'built-ins/RegExp/from-regexp-like-flag-override': [FAIL],
+  'built-ins/RegExp/from-regexp-like-get-source-err': [FAIL],
+  'built-ins/RegExp/from-regexp-like-get-flags-err': [FAIL],
+  'built-ins/RegExp/from-regexp-like-get-ctor-err': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4348
+  'built-ins/String/prototype/Symbol.iterator/this-val-non-obj-coercible': [FAIL],
+
+  # The order of adding the name property is wrong
+  # https://code.google.com/p/v8/issues/detail?id=4199
+  'language/computed-property-names/class/static/method-number': [FAIL, FAIL_SLOPPY],
+  'language/computed-property-names/class/static/method-symbol': [FAIL, FAIL_SLOPPY],
+  'language/computed-property-names/class/static/method-string': [FAIL, FAIL_SLOPPY],
+
+  # https://code.google.com/p/v8/issues/detail?id=3566
+  'language/statements/for-of/body-dstr-assign-error': [FAIL],
+  'language/statements/for-of/body-put-error': [FAIL],
+  'language/statements/for-of/generator-close-via-break': [FAIL],
+  'language/statements/for-of/generator-close-via-return': [FAIL],
+  'language/statements/for-of/generator-close-via-throw': [FAIL],
+  'language/statements/for-of/iterator-close-get-method-error': [FAIL],
+  'language/statements/for-of/iterator-close-non-object': [FAIL],
+  'language/statements/for-of/iterator-close-via-break': [FAIL],
+  'language/statements/for-of/iterator-close-via-return': [FAIL],
+  'language/statements/for-of/iterator-close-via-throw': [FAIL],
+
+  # We do not expose Array.prototype.values
+  # https://code.google.com/p/v8/issues/detail?id=4247
+  'built-ins/Array/prototype/Symbol.iterator': [FAIL],
+  'built-ins/Array/prototype/values/returns-iterator': [FAIL],
+  'built-ins/Array/prototype/values/returns-iterator-from-object': [FAIL],
+  'built-ins/Array/prototype/values/prop-desc': [FAIL],
+  'built-ins/Array/prototype/values/name': [FAIL],
+  'built-ins/Array/prototype/values/length': [FAIL],
+  'built-ins/Array/prototype/values/iteration': [FAIL],
+  'built-ins/Array/prototype/values/iteration-mutable': [FAIL],
+  'built-ins/Array/prototype/Symbol.unscopables/value': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=3566
+  'built-ins/GeneratorPrototype/return/from-state-completed': [FAIL],
+  'built-ins/GeneratorPrototype/return/from-state-suspended-start': [FAIL],
+  'built-ins/GeneratorPrototype/return/property-descriptor': [FAIL],
+  'built-ins/GeneratorPrototype/return/try-catch-before-try': [FAIL],
+  'built-ins/GeneratorPrototype/return/try-catch-following-catch': [FAIL],
+  'built-ins/GeneratorPrototype/return/try-catch-within-catch': [FAIL],
+  'built-ins/GeneratorPrototype/return/try-catch-within-try': [FAIL],
+  'built-ins/GeneratorPrototype/return/try-finally-before-try': [FAIL],
+  'built-ins/GeneratorPrototype/return/try-finally-following-finally': [FAIL],
+  'built-ins/GeneratorPrototype/return/try-finally-nested-try-catch-within-catch': [FAIL],
+  'built-ins/GeneratorPrototype/return/try-finally-nested-try-catch-within-finally': [FAIL],
+  'built-ins/GeneratorPrototype/return/try-finally-nested-try-catch-within-inner-try': [FAIL],
+  'built-ins/GeneratorPrototype/return/try-finally-nested-try-catch-within-outer-try-after-nested': [FAIL],
+  'built-ins/GeneratorPrototype/return/try-finally-nested-try-catch-within-outer-try-before-nested': [FAIL],
+  'built-ins/GeneratorPrototype/return/try-finally-within-finally': [FAIL],
+  'built-ins/GeneratorPrototype/return/try-finally-within-try': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4248
+  'language/expressions/compound-assignment/S11.13.2_A5.*': [FAIL],
+  'language/expressions/compound-assignment/S11.13.2_A6.*': [FAIL],
+  'language/expressions/compound-assignment/S11.13.2_A7.10_T4': [FAIL],
+  'language/expressions/compound-assignment/S11.13.2_A7.11_T4': [FAIL],
+  'language/expressions/compound-assignment/S11.13.2_A7.1_T4': [FAIL],
+  'language/expressions/compound-assignment/S11.13.2_A7.2_T4': [FAIL],
+  'language/expressions/compound-assignment/S11.13.2_A7.3_T4': [FAIL],
+  'language/expressions/compound-assignment/S11.13.2_A7.4_T4': [FAIL],
+  'language/expressions/compound-assignment/S11.13.2_A7.5_T4': [FAIL],
+  'language/expressions/compound-assignment/S11.13.2_A7.6_T4': [FAIL],
+  'language/expressions/compound-assignment/S11.13.2_A7.7_T4': [FAIL],
+  'language/expressions/compound-assignment/S11.13.2_A7.8_T4': [FAIL],
+  'language/expressions/compound-assignment/S11.13.2_A7.9_T4': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4249
+  'language/expressions/assignment/S11.13.1_A7_T1': [FAIL],
+  'language/expressions/assignment/S11.13.1_A7_T2': [FAIL],
+  'language/expressions/assignment/S11.13.1_A7_T3': [FAIL],
+  'language/expressions/postfix-increment/S11.3.1_A6_T3': [FAIL],
+  'language/expressions/postfix-decrement/S11.3.2_A6_T3': [FAIL],
+  'language/expressions/prefix-decrement/S11.4.5_A6_T3': [FAIL],
+  'language/expressions/prefix-increment/S11.4.4_A6_T3': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4250
+  'language/expressions/assignment/S11.13.1_A5*': [FAIL],
+  'language/expressions/assignment/S11.13.1_A6*': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=3699
+  'built-ins/Proxy/revocable/revocation-function-name': [FAIL],
+  'language/expressions/assignment/destructuring/array-elem-init-fn-name-arrow': [FAIL],
+  'language/expressions/assignment/destructuring/array-elem-init-fn-name-class': [FAIL],
+  'language/expressions/assignment/destructuring/array-elem-init-fn-name-cover': [FAIL],
+  'language/expressions/assignment/destructuring/array-elem-init-fn-name-fn': [FAIL],
+  'language/expressions/assignment/destructuring/array-elem-init-fn-name-gen': [FAIL],
+  'language/expressions/assignment/destructuring/obj-id-init-fn-name-arrow': [FAIL],
+  'language/expressions/assignment/destructuring/obj-id-init-fn-name-class': [FAIL],
+  'language/expressions/assignment/destructuring/obj-id-init-fn-name-cover': [FAIL],
+  'language/expressions/assignment/destructuring/obj-id-init-fn-name-fn': [FAIL],
+  'language/expressions/assignment/destructuring/obj-id-init-fn-name-gen': [FAIL],
+  'language/expressions/assignment/destructuring/obj-prop-elem-init-fn-name-arrow': [FAIL],
+  'language/expressions/assignment/destructuring/obj-prop-elem-init-fn-name-class': [FAIL],
+  'language/expressions/assignment/destructuring/obj-prop-elem-init-fn-name-cover': [FAIL],
+  'language/expressions/assignment/destructuring/obj-prop-elem-init-fn-name-fn': [FAIL],
+  'language/expressions/assignment/destructuring/obj-prop-elem-init-fn-name-gen': [FAIL],
+  'language/expressions/assignment/fn-name-arrow': [FAIL],
+  'language/expressions/assignment/fn-name-class': [FAIL],
+  'language/expressions/assignment/fn-name-cover': [FAIL],
+  'language/expressions/assignment/fn-name-fn': [FAIL],
+  'language/expressions/assignment/fn-name-gen': [FAIL],
+  'language/expressions/assignment/fn-name-lhs-cover': [FAIL],
+  'language/expressions/assignment/fn-name-lhs-member': [FAIL],
+  'language/expressions/class/name': [FAIL],
+  'language/expressions/function/name': [FAIL],
+  'language/expressions/generators/implicit-name': [FAIL],
+  'language/expressions/generators/name': [FAIL],
+  'language/expressions/generators/name-property-descriptor': [FAIL],
+  'language/expressions/object/fn-name-accessor-get': [FAIL],
+  'language/expressions/object/fn-name-accessor-set': [FAIL],
+  'language/expressions/object/fn-name-arrow': [FAIL],
+  'language/expressions/object/fn-name-class': [FAIL],
+  'language/expressions/object/fn-name-cover': [FAIL],
+  'language/expressions/object/fn-name-fn': [FAIL],
+  'language/expressions/object/fn-name-gen': [FAIL],
+  'language/expressions/object/fn-name-lhs-cover': [FAIL],
+  'language/expressions/object/fn-name-lhs-member': [FAIL],
+  'language/expressions/object/method-definition/fn-name-accessor-get': [FAIL],
+  'language/expressions/object/method-definition/fn-name-accessor-set': [FAIL],
+  'language/expressions/object/method-definition/fn-name-arrow': [FAIL],
+  'language/expressions/object/method-definition/fn-name-class': [FAIL],
+  'language/expressions/object/method-definition/fn-name-cover': [FAIL],
+  'language/expressions/object/method-definition/fn-name-fn': [FAIL],
+  'language/expressions/object/method-definition/fn-name-gen': [FAIL],
+  'language/statements/class/definition/basics': [FAIL],
+  'language/statements/class/definition/fn-name-accessor-get': [FAIL],
+  'language/statements/class/definition/fn-name-accessor-set': [FAIL],
+  'language/statements/class/definition/fn-name-gen-method': [FAIL],
+  'language/statements/class/definition/fn-name-method': [FAIL],
+  'language/statements/const/fn-name-arrow': [FAIL],
+  'language/statements/const/fn-name-class': [FAIL],
+  'language/statements/const/fn-name-cover': [FAIL],
+  'language/statements/const/fn-name-fn': [FAIL],
+  'language/statements/const/fn-name-gen': [FAIL],
+  'language/statements/let/fn-name-arrow': [FAIL],
+  'language/statements/let/fn-name-class': [FAIL],
+  'language/statements/let/fn-name-cover': [FAIL],
+  'language/statements/let/fn-name-fn': [FAIL],
+  'language/statements/let/fn-name-gen': [FAIL],
+  'language/statements/variable/fn-name-arrow': [FAIL],
+  'language/statements/variable/fn-name-class': [FAIL],
+  'language/statements/variable/fn-name-cover': [FAIL],
+  'language/statements/variable/fn-name-fn': [FAIL],
+  'language/statements/variable/fn-name-gen': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4251
+  'language/expressions/postfix-increment/S11.3.1_A5_T1': [FAIL],
+  'language/expressions/postfix-increment/S11.3.1_A5_T2': [FAIL],
+  'language/expressions/postfix-increment/S11.3.1_A5_T3': [FAIL],
+  'language/expressions/postfix-increment/S11.3.1_A5_T4': [FAIL],
+  'language/expressions/postfix-increment/S11.3.1_A5_T5': [FAIL],
+  'language/expressions/postfix-decrement/S11.3.2_A5_*': [FAIL],
+  'language/expressions/prefix-decrement/S11.4.5_A5_*': [FAIL],
+  'language/expressions/prefix-increment/S11.4.4_A5_*': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4253
+  'language/asi/S7.9_A5.7_T1': [PASS, FAIL_OK],
+
+  # https://code.google.com/p/v8/issues/detail?id=3761
+  'language/expressions/object/method-definition/generator-name-prop-symbol': [FAIL],
+  'language/expressions/object/method-definition/name-name-prop-symbol': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=2952
+  'built-ins/RegExp/prototype/exec/u-lastindex-adv': [FAIL],
+  'built-ins/RegExp/prototype/exec/u-captured-value': [FAIL],
+  'built-ins/RegExp/prototype/exec/u-lastindex-value': [FAIL],
+  'built-ins/RegExp/prototype/test/u-captured-value': [FAIL],
+  'built-ins/RegExp/prototype/test/u-lastindex-adv': [FAIL],
+  'built-ins/RegExp/prototype/test/u-lastindex-value': [FAIL],
+  'built-ins/RegExp/prototype/unicode/this-regexp': [FAIL],
+  'built-ins/RegExp/unicode_identity_escape': [FAIL],
+  'language/literals/regexp/u-unicode-esc': [FAIL],
+  'language/literals/regexp/u-surrogate-pairs': [FAIL],
+  'language/literals/regexp/u-case-mapping': [FAIL],
+  'language/literals/regexp/u-astral': [FAIL],
+  'built-ins/RegExp/valid-flags-y': [FAIL],
+  'built-ins/RegExp/prototype/unicode/length': [FAIL],
+  'built-ins/RegExp/prototype/unicode/name': [FAIL],
+  'built-ins/RegExp/prototype/unicode/prop-desc': [FAIL],
+  'built-ins/RegExp/prototype/unicode/this-invald-obj': [FAIL],
+  'built-ins/RegExp/prototype/unicode/this-non-obj': [FAIL],
+
+   # https://code.google.com/p/v8/issues/detail?id=4602
+  'built-ins/RegExp/prototype/exec/get-sticky-coerce': [FAIL],
+  'built-ins/RegExp/prototype/exec/get-sticky-err': [FAIL],
+  'built-ins/RegExp/prototype/test/get-sticky-err': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4504
+  'built-ins/RegExp/prototype/exec/y-fail-lastindex-no-write': [PASS, FAIL],
+  'built-ins/RegExp/prototype/test/y-fail-lastindex-no-write': [PASS, FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4305
+  # SKIP rather than FAIL some tests, as they may check for an exception which
+  # happens to be thrown for some other reason (e.g,
+  # built-ins/RegExp/prototype/Symbol.match/builtin-failure-set-lastindex-err)
+  'built-ins/RegExp/prototype/Symbol.match/*': [SKIP],
+  'built-ins/Symbol/match/prop-desc': [FAIL],
+  'built-ins/String/prototype/endsWith/return-abrupt-from-searchstring-regexp-test': [FAIL],
+  'built-ins/String/prototype/includes/return-abrupt-from-searchstring-regexp-test': [FAIL],
+  'built-ins/String/prototype/startsWith/return-abrupt-from-searchstring-regexp-test': [FAIL],
+  'built-ins/String/prototype/match/cstm-matcher-get-err': [FAIL],
+  'built-ins/String/prototype/match/invoke-builtin-match': [FAIL],
+  'built-ins/String/prototype/match/cstm-matcher-invocation': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4343
+  'built-ins/RegExp/prototype/Symbol.replace/*': [SKIP],
+  'built-ins/Symbol/replace/prop-desc': [FAIL],
+  'built-ins/String/prototype/replace/cstm-replace-get-err': [FAIL],
+  'built-ins/String/prototype/replace/cstm-replace-invocation': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4344
+  'built-ins/RegExp/prototype/Symbol.search/*': [SKIP],
+  'built-ins/Symbol/search/prop-desc': [FAIL],
+  'built-ins/String/prototype/search/cstm-search-get-err': [FAIL],
+  'built-ins/String/prototype/search/invoke-builtin-search-searcher-undef': [FAIL],
+  'built-ins/String/prototype/search/cstm-search-invocation': [FAIL],
+  'built-ins/String/prototype/search/invoke-builtin-search': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4345
+  'built-ins/RegExp/prototype/Symbol.split/*': [SKIP],
+  'built-ins/Symbol/split/prop-desc': [FAIL],
+  'built-ins/String/prototype/split/cstm-split-invocation': [FAIL],
+  'built-ins/String/prototype/split/cstm-split-get-err': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4346
+  'built-ins/RegExp/prototype/flags/u': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4360
+  'intl402/Collator/10.1.1_1': [FAIL],
+  'intl402/DateTimeFormat/12.1.1_1': [FAIL],
+  'intl402/NumberFormat/11.1.1_1': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4361
+  'intl402/Collator/10.1.1_a': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4447
+  'built-ins/Function/prototype/Symbol.hasInstance/*': [SKIP],
+  'built-ins/Symbol/hasInstance/prop-desc': [FAIL],
+  'language/expressions/instanceof/symbol-hasinstance-get-err': [FAIL],
+  'language/expressions/instanceof/symbol-hasinstance-invocation': [FAIL],
+  'language/expressions/instanceof/symbol-hasinstance-to-boolean': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4476
+  'built-ins/String/prototype/toLocaleLowerCase/special_casing_conditional': [FAIL],
+  'built-ins/String/prototype/toLocaleLowerCase/supplementary_plane': [FAIL],
+  'built-ins/String/prototype/toLowerCase/special_casing_conditional': [FAIL],
+  'built-ins/String/prototype/toLowerCase/supplementary_plane': [FAIL],
+  'built-ins/String/prototype/toLocaleUpperCase/supplementary_plane': [FAIL],
+  'built-ins/String/prototype/toUpperCase/supplementary_plane': [FAIL],
+
+  # https://code.google.com/p/v8/issues/detail?id=4477
+  'intl402/String/prototype/toLocaleLowerCase/special_casing_Azeri': [FAIL],
+  'intl402/String/prototype/toLocaleLowerCase/special_casing_Lithuanian': [FAIL],
+  'intl402/String/prototype/toLocaleLowerCase/special_casing_Turkish': [FAIL],
+  'intl402/String/prototype/toLocaleUpperCase/special_casing_Azeri': [FAIL],
+  'intl402/String/prototype/toLocaleUpperCase/special_casing_Lithuanian': [FAIL],
+  'intl402/String/prototype/toLocaleUpperCase/special_casing_Turkish': [FAIL],
+
+  # https://bugs.chromium.org/p/v8/issues/detail?id=4628
+  'language/eval-code/non-definable-function-with-variable': [FAIL],
+  'language/eval-code/non-definable-function-with-function': [FAIL],
+
+  # https://bugs.chromium.org/p/v8/issues/detail?id=4592
+  'built-ins/ArrayBuffer/length-is-absent': [FAIL],
+  'built-ins/ArrayBuffer/length-is-not-number': [FAIL],
+  'built-ins/ArrayBuffer/positive-integer-length': [FAIL],
+
+  # https://bugs.chromium.org/p/v8/issues/detail?id=4630
+  'language/statements/generators/invoke-as-constructor': [FAIL],
+  'language/expressions/generators/invoke-as-constructor': [FAIL],
+  'language/expressions/object/method-definition/generator-invoke-ctor': [FAIL],
+
+  # https://bugs.chromium.org/p/v8/issues/detail?id=4633
+  'built-ins/Promise/reject-function-name': [FAIL],
+  'built-ins/Promise/resolve-function-name': [FAIL],
+  'built-ins/Promise/all/resolve-element-function-name': [FAIL],
+  'built-ins/Promise/executor-function-name': [FAIL],
+  'built-ins/Promise/all/capability-executor-not-callable': [FAIL],
+  'built-ins/Promise/reject/capability-executor-not-callable': [FAIL],
+  'built-ins/Promise/race/capability-executor-not-callable': [FAIL],
+  'built-ins/Promise/prototype/then/capability-executor-not-callable': [FAIL],
+  'built-ins/Promise/resolve/capability-executor-not-callable': [FAIL],
+  'built-ins/Promise/race/S25.4.4.3_A3.1_T2': [FAIL],
+
+  # https://bugs.chromium.org/p/v8/issues/detail?id=4634
+  'built-ins/DataView/prototype/setFloat64/index-check-before-value-conversion': [FAIL],
+  'built-ins/DataView/prototype/setFloat32/index-check-before-value-conversion': [FAIL],
+  'built-ins/DataView/prototype/setInt16/index-check-before-value-conversion': [FAIL],
+  'built-ins/DataView/prototype/setInt32/index-check-before-value-conversion': [FAIL],
+  'built-ins/DataView/prototype/setUint16/index-check-before-value-conversion': [FAIL],
+  'built-ins/DataView/prototype/setUint32/index-check-before-value-conversion': [FAIL],
+  'built-ins/DataView/prototype/setUint8/index-check-before-value-conversion': [FAIL],
+  'built-ins/DataView/prototype/setInt8/index-check-before-value-conversion': [FAIL],
+
+  # https://bugs.chromium.org/p/v8/issues/detail?id=4639
+  'built-ins/ArrayBuffer/allocation-limit': [SKIP],
+
+  # https://code.google.com/p/chromium/issues/detail?id=581577
+  'built-ins/RegExp/prototype/source/15.10.7.1-1': [FAIL],
+  'built-ins/RegExp/prototype/global/15.10.7.2-1': [FAIL],
+  'built-ins/RegExp/prototype/ignoreCase/15.10.7.3-1': [FAIL],
+  'built-ins/RegExp/prototype/multiline/15.10.7.4-1': [FAIL],
 
   ######################## NEEDS INVESTIGATION ###########################
 
   # These test failures are specific to the intl402 suite and need investigation
   # to be either marked as bugs with issues filed for them or as deliberate
   # incompatibilities if the test cases turn out to be broken or ambiguous.
-  '6.2.3': [FAIL],
-  '9.2.1_2': [FAIL],
-  '9.2.6_2': [FAIL],
-  '10.1.1_a': [FAIL],
-  '10.1.1_19_c': [PASS, FAIL, NO_VARIANTS],
-  '10.1.2.1_4': [FAIL],
-  '10.2.3_b': [PASS, FAIL],
-  '10.3_a': [FAIL],
-  '11.1.1_17': [PASS, FAIL],
-  '11.1.1_19': [PASS, FAIL],
-  '11.1.1_20_c': [FAIL],
-  '11.1.1_a': [FAIL],
-  '11.1.2.1_4': [FAIL],
-  '11.3.2_FN_2': [PASS, FAIL],
-  '11.3.2_TRF': [PASS, FAIL],
-  '11.3_a': [FAIL],
-  '12.1.1_a': [FAIL],
-  '12.1.2.1_4': [FAIL],
-  '12.3.2_FDT_7_a_iv': [FAIL],
-  '12.3.3': [FAIL],
-  '12.3_a': [FAIL],
-  '15.5.4.9_3': [PASS, FAIL],
+  # Some of these are related to v8:4361 in being visible side effects from Intl.
+  'intl402/6.2.3': [FAIL],
+  'intl402/9.2.1_2': [FAIL],
+  'intl402/9.2.6_2': [FAIL],
+  'intl402/Collator/10.1.2.1_4': [FAIL],
+  'intl402/Collator/10.1.2_a': [PASS, FAIL],
+  'intl402/Collator/10.2.3_b': [PASS, FAIL],
+  'intl402/Collator/prototype/10.3_a': [FAIL],
+  'intl402/DateTimeFormat/12.1.1': [FAIL],
+  'intl402/DateTimeFormat/12.1.1_a': [FAIL],
+  'intl402/DateTimeFormat/12.1.2': [PASS, FAIL],
+  'intl402/DateTimeFormat/12.1.2.1_4': [FAIL],
+  'intl402/DateTimeFormat/12.2.3_b': [FAIL],
+  'intl402/DateTimeFormat/prototype/12.3.3': [FAIL],
+  'intl402/DateTimeFormat/prototype/12.3_a': [FAIL],
+  'intl402/Number/prototype/toLocaleString/13.2.1_5': [PASS, FAIL],
+  'intl402/NumberFormat/11.1.1_20_c': [FAIL],
+  'intl402/NumberFormat/11.1.1_a': [FAIL],
+  'intl402/NumberFormat/11.1.1': [FAIL],
+  'intl402/NumberFormat/11.1.2': [PASS, FAIL],
+  'intl402/NumberFormat/11.1.2.1_4': [FAIL],
+  'intl402/NumberFormat/11.2.3_b': [FAIL],
+  'intl402/NumberFormat/prototype/11.3_a': [FAIL],
+  'intl402/String/prototype/localeCompare/13.1.1_7': [PASS, FAIL],
 
   ##################### DELIBERATE INCOMPATIBILITIES #####################
 
-  'S15.8.2.8_A6': [PASS, FAIL_OK],  # Math.exp (less precise with --fast-math)
+  'built-ins/Math/exp/S15.8.2.8_A6': [PASS, FAIL_OK],  # Math.exp (less precise with --fast-math)
 
   # Linux for ia32 (and therefore simulators) default to extended 80 bit
   # floating point formats, so these tests checking 64-bit FP precision fail.
   # The other platforms/arch's pass these tests.
   # We follow the other major JS engines by keeping this default.
-  'S8.5_A2.1': [PASS, FAIL_OK],
-  'S8.5_A2.2': [PASS, FAIL_OK],
+  'language/types/number/S8.5_A2.1': [PASS, FAIL_OK],
+  'language/types/number/S8.5_A2.2': [PASS, FAIL_OK],
+
+  # https://code.google.com/p/v8/issues/detail?id=4693
+  'language/block-scope/syntax/redeclaration-in-block/attempt-to-redeclare-function-declaration-with-function-declaration': [PASS, FAIL_SLOPPY],
 
   ############################ INVALID TESTS #############################
 
@@ -96,48 +468,259 @@
   # tests in PST/PDT between first Sunday in March and first Sunday in April.
   # The DST switch was moved in 2007 whereas Test262 bases the reference value
   # on 2000. Test262 Bug: https://bugs.ecmascript.org/show_bug.cgi?id=293
-  'S15.9.3.1_A5_T1': [PASS, FAIL_OK],
-  'S15.9.3.1_A5_T2': [PASS, FAIL_OK],
-  'S15.9.3.1_A5_T3': [PASS, FAIL_OK],
-  'S15.9.3.1_A5_T4': [PASS, FAIL_OK],
-  'S15.9.3.1_A5_T5': [PASS, FAIL_OK],
-  'S15.9.3.1_A5_T6': [PASS, FAIL_OK],
+  'built-ins/Date/S15.9.3.1_A5_T1': [PASS, FAIL_OK],
+  'built-ins/Date/S15.9.3.1_A5_T2': [PASS, FAIL_OK],
+  'built-ins/Date/S15.9.3.1_A5_T3': [PASS, FAIL_OK],
+  'built-ins/Date/S15.9.3.1_A5_T4': [PASS, FAIL_OK],
+  'built-ins/Date/S15.9.3.1_A5_T5': [PASS, FAIL_OK],
+  'built-ins/Date/S15.9.3.1_A5_T6': [PASS, FAIL_OK],
 
-  # ObjectKeys() no longer throws TypeError when passed a primitive value which
-  # is not null or undefined (per ES6).
-  '15.2.3.14-1-1': [FAIL_OK],
-  '15.2.3.14-1-2': [FAIL_OK],
-  '15.2.3.14-1-3': [FAIL_OK],
+  # Test makes unjustified assumptions about the number of calls to SortCompare.
+  # Test262 Bug: https://bugs.ecmascript.org/show_bug.cgi?id=596
+  'built-ins/Array/prototype/sort/bug_596_1': [PASS, FAIL_OK],
 
-  # Object.getOwnPropertyNames(O) no longer throws when passed a primitive value.
-  '15.2.3.4-1-4': [FAIL_OK],
-  '15.2.3.4-1-5': [FAIL_OK],
-  '15.2.3.4-1': [FAIL_OK],
+  # Tests do not return boolean.
+  'built-ins/Object/keys/15.2.3.14-1-1': [PASS, FAIL_OK],
+  'built-ins/Object/keys/15.2.3.14-1-2': [PASS, FAIL_OK],
+  'built-ins/Object/keys/15.2.3.14-1-3': [PASS, FAIL_OK],
+
+  # Test bug https://github.com/tc39/test262/issues/405
+  'intl402/Collator/prototype/compare/10.3.2_1_c': [PASS, FAIL_OK],
+  'intl402/Collator/prototype/compare/10.3.2_CS_b_NN': [PASS, FAIL_OK],
+  'intl402/Collator/prototype/compare/10.3.2_CS_c_NN': [PASS, FAIL_OK],
+  'intl402/Collator/prototype/compare/10.3.2_CS_d_NN': [PASS, FAIL_OK],
+  'intl402/Date/prototype/13.3.0_7': [PASS, FAIL_OK],
+
+  # Some tests are too strict, checking SameValue rather than ===
+  # https://github.com/tc39/test262/issues/435
+  'built-ins/Array/prototype/indexOf/15.4.4.14-5-9': [FAIL],
+  'built-ins/Array/prototype/lastIndexOf/15.4.4.15-5-9': [FAIL],
+
+  # https://github.com/tc39/test262/issues/436
+  'built-ins/RegExp/call_with_regexp_match_falsy': [FAIL],
 
   ############################ SKIPPED TESTS #############################
 
-  # These tests take a looong time to run in debug mode.
-  'S15.1.3.1_A2.5_T1': [PASS, ['mode == debug', SKIP]],
-  'S15.1.3.2_A2.5_T1': [PASS, ['mode == debug', SKIP]],
+  # These tests take a looong time to run.
+  'built-ins/decodeURI/S15.1.3.1_A1.10_T1': [SKIP],
+  'built-ins/decodeURI/S15.1.3.1_A1.11_T1': [SKIP],
+  'built-ins/decodeURI/S15.1.3.1_A1.11_T2': [SKIP],
+  'built-ins/decodeURI/S15.1.3.1_A1.12_T1': [SKIP],
+  'built-ins/decodeURI/S15.1.3.1_A1.12_T2': [SKIP],
+  'built-ins/decodeURI/S15.1.3.1_A2.5_T1': [SKIP],
+  'built-ins/decodeURIComponent/S15.1.3.2_A1.11_T1': [SKIP],
+  'built-ins/decodeURIComponent/S15.1.3.2_A1.12_T1': [SKIP],
+  'built-ins/decodeURIComponent/S15.1.3.2_A2.5_T1': [SKIP],
+  'built-ins/RegExp/S15.10.2.12_A3_T1': [SKIP],
+  'intl402/9.2.6_4_b': [SKIP],
+  'language/literals/regexp/S7.8.5_A1.1_T2': [SKIP],
+  'language/literals/regexp/S7.8.5_A1.4_T2': [SKIP],
+  'language/literals/regexp/S7.8.5_A2.1_T2': [SKIP],
+  'language/literals/regexp/S7.8.5_A2.4_T2': [SKIP],
+  'built-ins/Array/prototype/slice/S15.4.4.10_A3_T1': [SKIP],
+  'built-ins/Array/prototype/slice/S15.4.4.10_A3_T2': [SKIP],
 }],  # ALWAYS
 
+['system == linux', {
+  # BUG(v8:4437).
+  'intl402/Collator/10.1.1_19_c': [PASS, FAIL],
+  'intl402/Collator/9.2.5_11_g_ii_2': [PASS, FAIL],
+  'intl402/NumberFormat/11.1.1_17': [PASS, FAIL],
+  'intl402/NumberFormat/11.1.1_19': [PASS, FAIL],
+  'intl402/NumberFormat/prototype/format/11.3.2_TRF': [PASS, FAIL],
+  'intl402/NumberFormat/prototype/format/11.3.2_TRP': [PASS, FAIL],
+}],  # system == linux
+
 ['system == macos', {
-  '11.3.2_TRP': [FAIL],
-  '9.2.5_11_g_ii_2': [FAIL],
+  'intl402/11.3.2_TRP': [FAIL],
+  'intl402/9.2.5_11_g_ii_2': [FAIL],
+
+  # BUG(v8:4437).
+  'intl402/Collator/10.1.1_19_c': [SKIP],
+  'intl402/Collator/9.2.5_11_g_ii_2': [SKIP],
+  'intl402/NumberFormat/11.1.1_17': [SKIP],
+  'intl402/NumberFormat/11.1.1_19': [SKIP],
+  'intl402/NumberFormat/prototype/format/11.3.2_TRF': [SKIP],
+  'intl402/NumberFormat/prototype/format/11.3.2_TRP': [SKIP],
 }],  # system == macos
 
-['arch == arm or arch == mipsel or arch == mips or arch == arm64 or arch == mips64el', {
+['no_i18n == True and mode == debug', {
+  # BUG(v8:4437).
+  'built-ins/String/prototype/normalize/return-normalized-string': [SKIP],
+  'built-ins/String/prototype/normalize/return-normalized-string-from-coerced-form': [SKIP],
+  'built-ins/String/prototype/normalize/return-normalized-string-using-default-parameter': [SKIP],
+}],  # no_i18n == True and mode == debug
+
+
+['arch == arm or arch == mipsel or arch == mips or arch == arm64 or arch == mips64 or arch == mips64el', {
 
   # TODO(mstarzinger): Causes stack overflow on simulators due to eager
   # compilation of parenthesized function literals. Needs investigation.
-  'S13.2.1_A1_T1': [SKIP],
+  'language/statements/function/S13.2.1_A1_T1': [SKIP],
 
   # BUG(3251225): Tests that timeout with --nocrankshaft.
-  'S15.1.3.1_A2.4_T1': [SKIP],
-  'S15.1.3.1_A2.5_T1': [SKIP],
-  'S15.1.3.2_A2.4_T1': [SKIP],
-  'S15.1.3.2_A2.5_T1': [SKIP],
-  'S15.1.3.3_A2.3_T1': [SKIP],
-  'S15.1.3.4_A2.3_T1': [SKIP],
+  'built-ins/decodeURI/S15.1.3.1_A2.4_T1': [SKIP],
+  'built-ins/decodeURI/S15.1.3.1_A2.5_T1': [SKIP],
+  'built-ins/decodeURIComponent/S15.1.3.2_A2.4_T1': [SKIP],
+  'built-ins/decodeURIComponent/S15.1.3.2_A2.5_T1': [SKIP],
+  'built-ins/encodeURI/S15.1.3.3_A2.3_T1': [SKIP],
+  'built-ins/encodeURIComponent/S15.1.3.4_A2.3_T1': [SKIP],
 }],  # 'arch == arm or arch == mipsel or arch == mips or arch == arm64'
+
+['asan == True', {
+  # BUG(v8:4653): Test262 tests which rely on quit() are not compatible with
+  # asan's --omit-quit flag.
+  'built-ins/Promise/prototype/then/deferred-is-resolved-value': [SKIP],
+}],
+
+['ignition == True', {
+  'annexB/B.2.3.*': [SKIP],
+  'built-ins/Array/prototype/reduce/*': [SKIP],
+  'built-ins/Array/prototype/reduceRight/*': [SKIP],
+  'built-ins/GeneratorFunction/*': [SKIP],
+  'built-ins/GeneratorPrototype/*': [SKIP],
+  'built-ins/Map/*': [SKIP],
+  'built-ins/MapIteratorPrototype/*': [SKIP],
+  'built-ins/Promise/prototype/then/capability-executor-called-twice': [SKIP],
+  'built-ins/Promise/prototype/then/capability-executor-not-callable': [SKIP],
+  'built-ins/Promise/prototype/then/deferred-is-resolved-value': [SKIP],
+  'built-ins/Proxy/has/*': [SKIP],
+  'built-ins/Reflect/enumerate/*': [SKIP],
+  'built-ins/Set/*': [SKIP],
+  'built-ins/SetIteratorPrototype/*': [SKIP],
+  'built-ins/WeakMap/*': [SKIP],
+  'built-ins/WeakSet/*': [SKIP],
+  'language/computed-property-names/class/*': [SKIP],
+  'language/computed-property-names/to-name-side-effects/*': [SKIP],
+  'language/directive-prologue/*': [SKIP],
+  'language/expressions/arrow-function/*': [SKIP],
+  'language/expressions/assignment/destructuring/*': [SKIP],
+  'language/expressions/class/*': [SKIP],
+  'language/expressions/generators/*': [SKIP],
+  'language/expressions/object/method-definition/yield*': [SKIP],
+  'language/expressions/object/method-definition/generator*': [SKIP],
+  'language/expressions/object/prop-def-id-eval-error-2': [SKIP],
+  'language/expressions/yield/*': [SKIP],
+  'language/function-code/*': [SKIP],
+  'language/statements/class/*': [SKIP],
+  'language/statements/const/*': [SKIP],
+  'language/statements/for-in/const*': [SKIP],
+  'language/statements/for-in/let*': [SKIP],
+  'language/statements/for-of/*': [SKIP],
+  'language/statements/generators/*': [SKIP],
+  'language/statements/try/*': [SKIP],
+  'language/statements/with/*': [SKIP],
+
+  'built-ins/Array/prototype/concat/Array.prototype.concat_non-array': [SKIP],
+  'built-ins/Array/prototype/join/S15.4.4.5_A3.1_T1': [SKIP],
+  'built-ins/Array/prototype/join/S15.4.4.5_A3.1_T2': [SKIP],
+  'built-ins/Array/prototype/toString/S15.4.4.2_A1_T2': [SKIP],
+  'built-ins/Array/prototype/toString/S15.4.4.2_A1_T3': [SKIP],
+  'built-ins/Array/prototype/toString/S15.4.4.2_A1_T4': [SKIP],
+  'built-ins/Date/15.9.1.15-1': [SKIP],
+  'built-ins/Date/prototype/toISOString/15.9.5.43-0-13': [SKIP],
+  'built-ins/JSON/stringify/*': [SKIP],
+  'built-ins/Object/defineProperty/15.2.3.6-4-625gs': [SKIP],
+  'built-ins/Object/prototype/hasOwnProperty/S15.2.4.5_A12': [SKIP],
+  'built-ins/Object/prototype/isPrototypeOf/S15.2.4.6_A12': [SKIP],
+  'built-ins/Object/prototype/propertyIsEnumerable/S15.2.4.7_A12': [SKIP],
+  'built-ins/Object/prototype/toLocaleString/S15.2.4.3_A12': [SKIP],
+  'built-ins/Object/prototype/toString/15.2.4.2-1-1': [SKIP],
+  'built-ins/Object/prototype/toString/15.2.4.2-1-2': [SKIP],
+  'built-ins/Object/prototype/toString/S15.2.4.2_A12': [SKIP],
+  'built-ins/Object/prototype/valueOf/S15.2.4.4_A12': [SKIP],
+  'built-ins/Object/prototype/valueOf/S15.2.4.4_A14': [SKIP],
+  'built-ins/Object/prototype/valueOf/S15.2.4.4_A15': [SKIP],
+  'built-ins/Promise/all/ctx-ctor': [SKIP],
+  'built-ins/Promise/race/ctx-ctor': [SKIP],
+  'built-ins/Promise/reject/ctx-ctor': [SKIP],
+  'built-ins/Promise/resolve/ctx-ctor': [SKIP],
+  'built-ins/Promise/reject/S25.4.4.4_A3.1_T1': [SKIP],
+  'built-ins/String/prototype/codePointAt/this-is-undefined-throws': [SKIP],
+  'built-ins/String/prototype/concat/S15.5.4.6_A2': [SKIP],
+  'built-ins/String/prototype/endsWith/this-is-undefined-throws': [SKIP],
+  'built-ins/String/prototype/includes/this-is-undefined-throws': [SKIP],
+  'built-ins/String/prototype/repeat/this-is-undefined-throws': [SKIP],
+  'built-ins/String/prototype/startsWith/this-is-undefined-throws': [SKIP],
+  'built-ins/String/prototype/trim/15.5.4.20-1-1': [SKIP],
+  'built-ins/String/S15.5.5.1_A4_T1': [SKIP],
+  'language/block-scope/leave/nested-block-let-declaration-only-shadows-outer-parameter-value-1': [SKIP],
+  'language/block-scope/leave/nested-block-let-declaration-only-shadows-outer-parameter-value-2': [SKIP],
+  'language/block-scope/leave/verify-context-in-labelled-block': [SKIP],
+  'language/block-scope/leave/x-after-break-to-label': [SKIP],
+  'language/computed-property-names/object/accessor/getter-super': [SKIP],
+  'language/computed-property-names/object/accessor/setter-super': [SKIP],
+  'language/computed-property-names/object/method/super': [SKIP],
+  'language/default-parameters/class-definitions': [SKIP],
+  'language/default-parameters/generators': [SKIP],
+  'language/default-parameters/param-ref-uninitialized': [SKIP],
+  'language/expressions/delete/11.4.1-4.a-5': [SKIP],
+  'language/expressions/delete/11.4.1-4.a-6': [SKIP],
+  'language/expressions/object/method-definition/name-prop-name-yield-expr': [SKIP],
+  'language/expressions/object/method-definition/name-super-prop-param': [SKIP],
+  'language/expressions/object/method-definition/name-super-prop-body': [SKIP],
+  'language/expressions/object/prop-def-id-eval-error': [SKIP],
+  'language/expressions/tagged-template/call-expression-context-no-strict': [SKIP],
+  'language/expressions/tagged-template/call-expression-context-strict': [SKIP],
+  'language/expressions/template-literal/evaluation-order': [SKIP],
+  'language/expressions/this/11.1.1-1gs': [SKIP],
+  'language/identifier-resolution/S10.2.2_A1_T5': [SKIP],
+  'language/identifier-resolution/S10.2.2_A1_T6': [SKIP],
+  'language/identifier-resolution/S10.2.2_A1_T7': [SKIP],
+  'language/identifier-resolution/S10.2.2_A1_T8': [SKIP],
+  'language/identifier-resolution/S10.2.2_A1_T9': [SKIP],
+  'language/object-literal/concise-generator': [SKIP],
+  'language/object-literal/getter': [SKIP],
+  'language/object-literal/method': [SKIP],
+  'language/object-literal/setter': [SKIP],
+  'language/rest-parameters/arrow-function': [SKIP],
+  'language/rest-parameters/expected-argument-count': [SKIP],
+  'language/rest-parameters/no-alias-arguments': [SKIP],
+  'language/rest-parameters/rest-index': [SKIP],
+  'language/rest-parameters/rest-parameters-apply': [SKIP],
+  'language/rest-parameters/rest-parameters-call': [SKIP],
+  'language/rest-parameters/rest-parameters-produce-an-array': [SKIP],
+  'language/rest-parameters/with-new-target': [SKIP],
+  'language/statements/do-while/S12.6.1_A4_T5': [SKIP],
+  'language/statements/function/S13.2.2_A18_T2': [SKIP],
+  'language/statements/function/S13.2.2_A19_T1': [SKIP],
+  'language/statements/function/S13.2.2_A19_T2': [SKIP],
+  'language/statements/function/S13.2.2_A19_T3': [SKIP],
+  'language/statements/function/S13.2.2_A19_T4': [SKIP],
+  'language/statements/function/S13.2.2_A19_T5': [SKIP],
+  'language/statements/function/S13.2.2_A19_T6': [SKIP],
+  'language/statements/function/S13.2.2_A19_T7': [SKIP],
+  'language/statements/function/S13.2.2_A19_T8': [SKIP],
+  'language/statements/function/S13.2.2_A18_T1': [SKIP],
+  'language/statements/function/S13.2.2_A17_T2': [SKIP],
+  'language/statements/function/S13.2.2_A17_T3': [SKIP],
+  'language/statements/let/block-local-closure-get-before-initialization': [SKIP],
+  'language/statements/let/block-local-closure-set-before-initialization': [SKIP],
+  'language/statements/let/block-local-use-before-initialization-in-declaration-statement': [SKIP],
+  'language/statements/let/block-local-use-before-initialization-in-prior-statement': [SKIP],
+  'language/statements/let/function-local-closure-get-before-initialization': [SKIP],
+  'language/statements/let/function-local-closure-set-before-initialization': [SKIP],
+  'language/statements/let/function-local-use-before-initialization-in-declaration-statement': [SKIP],
+  'language/statements/let/function-local-use-before-initialization-in-prior-statement': [SKIP],
+  'language/statements/let/global-closure-get-before-initialization': [SKIP],
+  'language/statements/let/global-closure-set-before-initialization': [SKIP],
+  'language/statements/let/global-use-before-initialization-in-declaration-statement': [SKIP],
+  'language/statements/let/global-use-before-initialization-in-prior-statement': [SKIP],
+  'language/statements/while/S12.6.2_A4_T5': [SKIP],
+
+}],  # ignition == True
+
+['ignition == True and (arch == arm or arch == arm64)', {
+  'built-ins/decodeURI/S15.1.3.1_A1.12_T3': [SKIP],
+  'built-ins/decodeURIComponent/S15.1.3.2_A1.10_T1': [SKIP],
+  'built-ins/decodeURIComponent/S15.1.3.2_A1.11_T2': [SKIP],
+  'built-ins/decodeURIComponent/S15.1.3.2_A1.12_T2': [SKIP],
+  'built-ins/decodeURIComponent/S15.1.3.2_A1.12_T3': [SKIP],
+  'intl402/9.2.2': [SKIP],
+  'language/statements/let/fn-name-arrow': [SKIP],
+  'language/statements/let/fn-name-cover': [SKIP],
+  'language/statements/let/fn-name-fn': [SKIP],
+  'language/statements/let/fn-name-gen': [SKIP],
+}],  # ignition == True and (arch == arm or arch == arm64)
+
 ]