tc39_test.go 40 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848
  1. package goja
  2. import (
  3. "errors"
  4. "fmt"
  5. "gopkg.in/yaml.v2"
  6. "io/ioutil"
  7. "os"
  8. "path"
  9. "sort"
  10. "strings"
  11. "sync"
  12. "testing"
  13. "time"
  14. )
  15. const (
  16. tc39BASE = "testdata/test262"
  17. )
  18. var (
  19. invalidFormatError = errors.New("Invalid file format")
  20. ignorableTestError = newSymbol(stringEmpty)
  21. sabStub = MustCompile("sabStub.js", `
  22. Object.defineProperty(this, "SharedArrayBuffer", {
  23. get: function() {
  24. throw IgnorableTestError;
  25. }
  26. });`,
  27. false)
  28. )
  29. var (
  30. skipList = map[string]bool{
  31. // Obsolete tests (see https://github.com/tc39/test262/pull/2445)
  32. //TODO: remove this after upgrading the test suite past the above PR
  33. "test/language/statements/function/scope-param-rest-elem-var-open.js": true,
  34. "test/language/statements/function/scope-param-rest-elem-var-close.js": true,
  35. "test/language/statements/function/scope-param-elem-var-open.js": true,
  36. "test/language/function-code/eval-param-env-with-prop-initializer.js": true,
  37. "test/language/function-code/eval-param-env-with-computed-key.js": true,
  38. "test/language/expressions/object/scope-meth-param-rest-elem-var-open.js": true,
  39. "test/language/statements/function/scope-param-elem-var-close.js": true,
  40. "test/language/expressions/object/scope-meth-param-rest-elem-var-close.js": true,
  41. "test/language/expressions/object/scope-meth-param-elem-var-open.js": true,
  42. "test/language/expressions/object/scope-meth-param-elem-var-close.js": true,
  43. "test/language/expressions/function/scope-param-rest-elem-var-open.js": true,
  44. "test/language/expressions/function/scope-param-rest-elem-var-close.js": true,
  45. "test/language/expressions/function/scope-param-elem-var-open.js": true,
  46. "test/language/expressions/function/scope-param-elem-var-close.js": true,
  47. "test/language/expressions/arrow-function/scope-param-rest-elem-var-open.js": true,
  48. "test/language/expressions/arrow-function/scope-param-rest-elem-var-close.js": true,
  49. "test/language/expressions/arrow-function/scope-param-elem-var-close.js": true,
  50. "test/language/expressions/arrow-function/scope-param-elem-var-open.js": true,
  51. // These tests are out of date (fixed in https://github.com/tc39/test262/commit/7d998a098e5420cb4b6ee4a05eb8c386d750c596)
  52. "test/built-ins/TypedArrayConstructors/internals/DefineOwnProperty/key-is-numericindex.js": true,
  53. "test/built-ins/TypedArrayConstructors/internals/DefineOwnProperty/key-is-numericindex-desc-configurable.js": true,
  54. // Fixed in https://github.com/tc39/test262/commit/7d998a098e5420cb4b6ee4a05eb8c386d750c596
  55. "test/built-ins/TypedArrayConstructors/internals/DefineOwnProperty/detached-buffer.js": true,
  56. "test/built-ins/Date/prototype/toISOString/15.9.5.43-0-8.js": true, // timezone
  57. "test/built-ins/Date/prototype/toISOString/15.9.5.43-0-9.js": true, // timezone
  58. "test/built-ins/Date/prototype/toISOString/15.9.5.43-0-10.js": true, // timezone
  59. // \u{xxxxx}
  60. "test/annexB/built-ins/escape/escape-above-astral.js": true,
  61. "test/built-ins/RegExp/prototype/source/value-u.js": true,
  62. // SharedArrayBuffer
  63. "test/built-ins/ArrayBuffer/prototype/slice/this-is-sharedarraybuffer.js": true,
  64. // class
  65. "test/language/statements/class/subclass/builtin-objects/Symbol/symbol-valid-as-extends-value.js": true,
  66. "test/language/statements/class/subclass/builtin-objects/Symbol/new-symbol-with-super-throws.js": true,
  67. "test/language/statements/class/subclass/builtin-objects/WeakSet/super-must-be-called.js": true,
  68. "test/language/statements/class/subclass/builtin-objects/WeakSet/regular-subclassing.js": true,
  69. "test/language/statements/class/subclass/builtin-objects/WeakMap/super-must-be-called.js": true,
  70. "test/language/statements/class/subclass/builtin-objects/WeakMap/regular-subclassing.js": true,
  71. "test/language/statements/class/subclass/builtin-objects/Map/super-must-be-called.js": true,
  72. "test/language/statements/class/subclass/builtin-objects/Map/regular-subclassing.js": true,
  73. "test/language/statements/class/subclass/builtin-objects/Set/super-must-be-called.js": true,
  74. "test/language/statements/class/subclass/builtin-objects/Set/regular-subclassing.js": true,
  75. "test/language/statements/class/subclass/builtin-objects/Object/replacing-prototype.js": true,
  76. "test/language/statements/class/subclass/builtin-objects/Object/regular-subclassing.js": true,
  77. "test/built-ins/Array/prototype/concat/Array.prototype.concat_non-array.js": true,
  78. "test/language/statements/class/subclass/builtin-objects/Array/length.js": true,
  79. "test/language/statements/class/subclass/builtin-objects/TypedArray/super-must-be-called.js": true,
  80. "test/language/statements/class/subclass/builtin-objects/TypedArray/regular-subclassing.js": true,
  81. "test/language/statements/class/subclass/builtin-objects/DataView/super-must-be-called.js": true,
  82. "test/language/statements/class/subclass/builtin-objects/DataView/regular-subclassing.js": true,
  83. "test/language/statements/class/subclass/builtin-objects/String/super-must-be-called.js": true,
  84. "test/language/statements/class/subclass/builtin-objects/String/regular-subclassing.js": true,
  85. "test/language/statements/class/subclass/builtin-objects/String/length.js": true,
  86. "test/language/statements/class/subclass/builtin-objects/Date/super-must-be-called.js": true,
  87. "test/language/statements/class/subclass/builtin-objects/Date/regular-subclassing.js": true,
  88. "test/language/statements/class/subclass/builtin-objects/Number/super-must-be-called.js": true,
  89. "test/language/statements/class/subclass/builtin-objects/Number/regular-subclassing.js": true,
  90. "test/language/statements/class/subclass/builtin-objects/Function/super-must-be-called.js": true,
  91. "test/language/statements/class/subclass/builtin-objects/Function/regular-subclassing.js": true,
  92. "test/language/statements/class/subclass/builtin-objects/Function/instance-name.js": true,
  93. "test/language/statements/class/subclass/builtin-objects/Function/instance-length.js": true,
  94. "test/language/statements/class/subclass/builtin-objects/Boolean/super-must-be-called.js": true,
  95. "test/language/statements/class/subclass/builtin-objects/Boolean/regular-subclassing.js": true,
  96. "test/language/statements/class/subclass/builtin-objects/NativeError/URIError-super.js": true,
  97. "test/language/statements/class/subclass/builtin-objects/NativeError/URIError-name.js": true,
  98. "test/language/statements/class/subclass/builtin-objects/NativeError/URIError-message.js": true,
  99. "test/language/statements/class/subclass/builtin-objects/NativeError/TypeError-super.js": true,
  100. "test/language/statements/class/subclass/builtin-objects/NativeError/TypeError-name.js": true,
  101. "test/language/statements/class/subclass/builtin-objects/NativeError/TypeError-message.js": true,
  102. "test/language/statements/class/subclass/builtin-objects/NativeError/SyntaxError-super.js": true,
  103. "test/language/statements/class/subclass/builtin-objects/NativeError/SyntaxError-name.js": true,
  104. "test/language/statements/class/subclass/builtin-objects/NativeError/SyntaxError-message.js": true,
  105. "test/language/statements/class/subclass/builtin-objects/NativeError/ReferenceError-super.js": true,
  106. "test/language/statements/class/subclass/builtin-objects/NativeError/ReferenceError-name.js": true,
  107. "test/language/statements/class/subclass/builtin-objects/NativeError/ReferenceError-message.js": true,
  108. "test/language/statements/class/subclass/builtin-objects/NativeError/RangeError-super.js": true,
  109. "test/language/statements/class/subclass/builtin-objects/NativeError/RangeError-name.js": true,
  110. "test/language/statements/class/subclass/builtin-objects/NativeError/RangeError-message.js": true,
  111. "test/language/statements/class/subclass/builtin-objects/NativeError/EvalError-super.js": true,
  112. "test/language/statements/class/subclass/builtin-objects/NativeError/EvalError-name.js": true,
  113. "test/language/statements/class/subclass/builtin-objects/NativeError/EvalError-message.js": true,
  114. "test/language/statements/class/subclass/builtin-objects/Error/super-must-be-called.js": true,
  115. "test/language/statements/class/subclass/builtin-objects/Error/regular-subclassing.js": true,
  116. "test/language/statements/class/subclass/builtin-objects/Error/message-property-assignment.js": true,
  117. "test/language/statements/class/subclass/builtin-objects/Array/super-must-be-called.js": true,
  118. "test/language/statements/class/subclass/builtin-objects/Array/regular-subclassing.js": true,
  119. "test/language/statements/class/subclass/builtin-objects/Array/contructor-calls-super-single-argument.js": true,
  120. "test/language/statements/class/subclass/builtin-objects/Array/contructor-calls-super-multiple-arguments.js": true,
  121. "test/language/statements/class/subclass/builtin-objects/ArrayBuffer/super-must-be-called.js": true,
  122. "test/language/statements/class/subclass/builtin-objects/ArrayBuffer/regular-subclassing.js": true,
  123. "test/built-ins/ArrayBuffer/isView/arg-is-typedarray-subclass-instance.js": true,
  124. "test/built-ins/ArrayBuffer/isView/arg-is-dataview-subclass-instance.js": true,
  125. "test/language/statements/class/subclass/builtin-objects/RegExp/super-must-be-called.js": true,
  126. "test/language/statements/class/subclass/builtin-objects/RegExp/regular-subclassing.js": true,
  127. "test/language/statements/class/subclass/builtin-objects/RegExp/lastIndex.js": true,
  128. "TestTC39/tc39/test/language/statements/class/definition/fn-name-method.js": true,
  129. "test/language/expressions/object/method-definition/name-invoke-ctor.js": true,
  130. "test/language/expressions/object/method.js": true,
  131. "test/language/expressions/object/setter-super-prop.js": true,
  132. "test/language/expressions/object/getter-super-prop.js": true,
  133. "test/language/expressions/delete/super-property.js": true,
  134. "test/language/statements/let/dstr/obj-ptrn-id-init-fn-name-class.js": true,
  135. "test/language/statements/let/dstr/ary-ptrn-elem-id-init-fn-name-class.js": true,
  136. "test/language/statements/for/dstr/var-obj-ptrn-id-init-fn-name-class.js": true,
  137. "test/language/statements/for/dstr/var-ary-ptrn-elem-id-init-fn-name-class.js": true,
  138. "test/language/statements/for/dstr/let-ary-ptrn-elem-id-init-fn-name-class.js": true,
  139. "test/language/statements/for/dstr/let-obj-ptrn-id-init-fn-name-class.js": true,
  140. "test/language/statements/const/dstr/ary-ptrn-elem-id-init-fn-name-class.js": true,
  141. "test/language/statements/for/dstr/const-obj-ptrn-id-init-fn-name-class.js": true,
  142. "test/language/statements/const/dstr/obj-ptrn-id-init-fn-name-class.js": true,
  143. "test/language/statements/for/dstr/const-ary-ptrn-elem-id-init-fn-name-class.js": true,
  144. "test/language/statements/variable/dstr/obj-ptrn-id-init-fn-name-class.js": true,
  145. "test/language/statements/variable/dstr/ary-ptrn-elem-id-init-fn-name-class.js": true,
  146. "test/language/expressions/object/method-definition/name-name-prop-symbol.js": true,
  147. "test/language/expressions/function/dstr/dflt-obj-ptrn-id-init-fn-name-class.js": true,
  148. "test/language/expressions/function/dstr/dflt-ary-ptrn-elem-id-init-fn-name-class.js": true,
  149. "test/language/expressions/function/dstr/ary-ptrn-elem-id-init-fn-name-class.js": true,
  150. "test/language/expressions/function/dstr/obj-ptrn-id-init-fn-name-class.js": true,
  151. "test/language/statements/function/dstr/dflt-ary-ptrn-elem-id-init-fn-name-class.js": true,
  152. "test/language/statements/function/dstr/obj-ptrn-id-init-fn-name-class.js": true,
  153. "test/language/statements/function/dstr/ary-ptrn-elem-id-init-fn-name-class.js": true,
  154. "test/language/statements/function/dstr/dflt-obj-ptrn-id-init-fn-name-class.js": true,
  155. "test/language/statements/class/scope-static-setter-paramsbody-var-open.js": true,
  156. "test/language/statements/class/scope-static-setter-paramsbody-var-close.js": true,
  157. "test/language/statements/class/scope-static-meth-paramsbody-var-open.js": true,
  158. "test/language/statements/class/scope-static-meth-paramsbody-var-close.js": true,
  159. "test/language/statements/class/scope-setter-paramsbody-var-open.js": true,
  160. "test/language/statements/class/scope-setter-paramsbody-var-close.js": true,
  161. "test/language/statements/class/scope-meth-paramsbody-var-open.js": true,
  162. "test/language/statements/class/scope-meth-paramsbody-var-close.js": true,
  163. "test/language/expressions/class/scope-static-setter-paramsbody-var-open.js": true,
  164. "test/language/expressions/class/scope-static-setter-paramsbody-var-close.js": true,
  165. "test/language/expressions/class/scope-static-meth-paramsbody-var-open.js": true,
  166. "test/language/expressions/class/scope-static-meth-paramsbody-var-close.js": true,
  167. "test/language/expressions/class/scope-setter-paramsbody-var-open.js": true,
  168. "test/language/expressions/class/scope-setter-paramsbody-var-close.js": true,
  169. "test/language/expressions/class/scope-meth-paramsbody-var-open.js": true,
  170. "test/language/expressions/class/scope-meth-paramsbody-var-close.js": true,
  171. "test/language/expressions/arrow-function/scope-paramsbody-var-open.js": true,
  172. "test/language/expressions/arrow-function/scope-paramsbody-var-close.js": true,
  173. "test/language/expressions/arrow-function/scope-body-lex-distinct.js": true,
  174. "test/language/statements/for-of/dstr/var-ary-ptrn-elem-id-init-fn-name-class.js": true,
  175. "test/language/statements/for-of/dstr/var-obj-ptrn-id-init-fn-name-class.js": true,
  176. "test/language/statements/for-of/dstr/const-obj-ptrn-id-init-fn-name-class.js": true,
  177. "test/language/statements/for-of/dstr/let-obj-ptrn-id-init-fn-name-class.js": true,
  178. "test/language/statements/for-of/dstr/const-ary-ptrn-elem-id-init-fn-name-class.js": true,
  179. "test/language/statements/for-of/dstr/let-ary-ptrn-elem-id-init-fn-name-class.js": true,
  180. "test/language/statements/try/dstr/obj-ptrn-id-init-fn-name-class.js": true,
  181. "test/language/statements/try/dstr/ary-ptrn-elem-id-init-fn-name-class.js": true,
  182. // arrow-function
  183. "test/built-ins/Object/prototype/toString/proxy-function.js": true,
  184. "test/built-ins/Array/prototype/pop/throws-with-string-receiver.js": true,
  185. "test/built-ins/Array/prototype/push/throws-with-string-receiver.js": true,
  186. "test/built-ins/Array/prototype/shift/throws-with-string-receiver.js": true,
  187. "test/built-ins/Array/prototype/unshift/throws-with-string-receiver.js": true,
  188. "test/built-ins/Date/prototype/toString/non-date-receiver.js": true,
  189. "test/built-ins/Number/prototype/toExponential/range.js": true,
  190. "test/built-ins/Number/prototype/toFixed/range.js": true,
  191. "test/built-ins/Number/prototype/toPrecision/range.js": true,
  192. "test/built-ins/TypedArray/prototype/sort/stability.js": true,
  193. "test/built-ins/RegExp/named-groups/functional-replace-global.js": true,
  194. "test/built-ins/RegExp/named-groups/functional-replace-non-global.js": true,
  195. "test/built-ins/Array/prototype/sort/stability-513-elements.js": true,
  196. "test/built-ins/Array/prototype/sort/stability-5-elements.js": true,
  197. "test/built-ins/Array/prototype/sort/stability-2048-elements.js": true,
  198. "test/built-ins/Array/prototype/sort/stability-11-elements.js": true,
  199. "test/language/statements/variable/fn-name-arrow.js": true,
  200. "test/language/statements/let/fn-name-arrow.js": true,
  201. "test/language/statements/const/fn-name-arrow.js": true,
  202. "test/built-ins/Proxy/getPrototypeOf/instanceof-target-not-extensible-not-same-proto-throws.js": true,
  203. "test/language/statements/let/dstr/obj-ptrn-id-init-fn-name-arrow.js": true,
  204. "test/language/statements/let/dstr/ary-ptrn-elem-id-init-fn-name-arrow.js": true,
  205. "test/language/statements/for/dstr/var-obj-ptrn-id-init-fn-name-arrow.js": true,
  206. "test/language/statements/for/dstr/var-ary-ptrn-elem-id-init-fn-name-arrow.js": true,
  207. "test/language/statements/for/dstr/let-ary-ptrn-elem-id-init-fn-name-arrow.js": true,
  208. "test/language/statements/for/dstr/let-obj-ptrn-id-init-fn-name-arrow.js": true,
  209. "test/language/statements/const/dstr/ary-ptrn-elem-id-init-fn-name-arrow.js": true,
  210. "test/language/statements/for/dstr/const-obj-ptrn-id-init-fn-name-arrow.js": true,
  211. "test/language/statements/const/dstr/obj-ptrn-id-init-fn-name-arrow.js": true,
  212. "test/language/statements/for/dstr/const-ary-ptrn-elem-id-init-fn-name-arrow.js": true,
  213. "test/language/statements/variable/dstr/obj-ptrn-id-init-fn-name-arrow.js": true,
  214. "test/language/statements/variable/dstr/ary-ptrn-elem-id-init-fn-name-arrow.js": true,
  215. "test/language/expressions/assignment/dstr/obj-prop-elem-init-fn-name-arrow.js": true,
  216. "test/language/expressions/assignment/dstr/obj-id-init-fn-name-arrow.js": true,
  217. "test/language/expressions/assignment/dstr/obj-rest-order.js": true,
  218. "test/language/expressions/assignment/dstr/array-elem-init-fn-name-arrow.js": true,
  219. "test/language/expressions/function/dstr/obj-ptrn-id-init-fn-name-arrow.js": true,
  220. "test/language/expressions/function/dstr/dflt-obj-ptrn-id-init-fn-name-arrow.js": true,
  221. "test/language/expressions/function/dstr/dflt-ary-ptrn-elem-id-init-fn-name-arrow.js": true,
  222. "test/language/expressions/function/dstr/ary-ptrn-elem-id-init-fn-name-arrow.js": true,
  223. "test/language/statements/function/dstr/dflt-ary-ptrn-elem-id-init-fn-name-arrow.js": true,
  224. "test/language/statements/function/dstr/obj-ptrn-id-init-fn-name-arrow.js": true,
  225. "test/language/statements/function/dstr/ary-ptrn-elem-id-init-fn-name-arrow.js": true,
  226. "test/language/statements/function/dstr/dflt-obj-ptrn-id-init-fn-name-arrow.js": true,
  227. "test/language/statements/for-of/dstr/var-obj-ptrn-id-init-fn-name-arrow.js": true,
  228. "test/language/statements/for-of/dstr/var-ary-ptrn-elem-id-init-fn-name-arrow.js": true,
  229. "test/language/statements/for-of/dstr/obj-prop-elem-init-fn-name-arrow.js": true,
  230. "test/language/statements/for-of/dstr/obj-rest-order.js": true,
  231. "test/language/statements/for-of/dstr/obj-id-init-fn-name-arrow.js": true,
  232. "test/language/statements/for-of/dstr/let-ary-ptrn-elem-id-init-fn-name-arrow.js": true,
  233. "test/language/statements/for-of/dstr/const-obj-ptrn-id-init-fn-name-arrow.js": true,
  234. "test/language/statements/for-of/dstr/const-ary-ptrn-elem-id-init-fn-name-arrow.js": true,
  235. "test/language/statements/for-of/dstr/let-obj-ptrn-id-init-fn-name-arrow.js": true,
  236. "test/language/statements/for-of/dstr/array-elem-init-fn-name-arrow.js": true,
  237. "test/language/expressions/call/spread-obj-spread-order.js": true,
  238. "test/language/statements/try/dstr/obj-ptrn-id-init-fn-name-arrow.js": true,
  239. "test/language/statements/try/dstr/ary-ptrn-elem-id-init-fn-name-arrow.js": true,
  240. // template strings
  241. "test/built-ins/String/raw/zero-literal-segments.js": true,
  242. "test/built-ins/String/raw/template-substitutions-are-appended-on-same-index.js": true,
  243. "test/built-ins/String/raw/special-characters.js": true,
  244. "test/built-ins/String/raw/return-the-string-value-from-template.js": true,
  245. "test/built-ins/TypedArray/prototype/fill/fill-values-conversion-operations-consistent-nan.js": true,
  246. "test/built-ins/Array/prototype/splice/create-species-length-exceeding-integer-limit.js": true,
  247. "test/built-ins/Array/prototype/slice/length-exceeding-integer-limit-proxied-array.js": true,
  248. "test/built-ins/TypedArrayConstructors/internals/DefineOwnProperty/conversion-operation-consistent-nan.js": true,
  249. // restricted unicode regexp syntax
  250. "test/built-ins/RegExp/unicode_restricted_quantifiable_assertion.js": true,
  251. "test/built-ins/RegExp/unicode_restricted_octal_escape.js": true,
  252. "test/built-ins/RegExp/unicode_restricted_incomple_quantifier.js": true,
  253. "test/built-ins/RegExp/unicode_restricted_incomplete_quantifier.js": true,
  254. "test/built-ins/RegExp/unicode_restricted_identity_escape_x.js": true,
  255. "test/built-ins/RegExp/unicode_restricted_identity_escape_u.js": true,
  256. "test/built-ins/RegExp/unicode_restricted_identity_escape_c.js": true,
  257. "test/built-ins/RegExp/unicode_restricted_identity_escape_alpha.js": true,
  258. "test/built-ins/RegExp/unicode_restricted_identity_escape.js": true,
  259. "test/built-ins/RegExp/unicode_restricted_brackets.js": true,
  260. "test/built-ins/RegExp/unicode_restricted_character_class_escape.js": true,
  261. "test/annexB/built-ins/RegExp/prototype/compile/pattern-string-invalid-u.js": true,
  262. // regexp named groups
  263. "test/built-ins/RegExp/prototype/Symbol.replace/named-groups-fn.js": true,
  264. "test/built-ins/RegExp/prototype/Symbol.replace/result-coerce-groups-err.js": true,
  265. "test/built-ins/RegExp/prototype/Symbol.replace/result-coerce-groups-prop-err.js": true,
  266. "test/built-ins/RegExp/prototype/Symbol.replace/result-coerce-groups-prop.js": true,
  267. "test/built-ins/RegExp/prototype/Symbol.replace/result-coerce-groups.js": true,
  268. "test/built-ins/RegExp/prototype/Symbol.replace/result-get-groups-err.js": true,
  269. "test/built-ins/RegExp/prototype/Symbol.replace/result-get-groups-prop-err.js": true,
  270. // Because goja parser works in UTF-8 it is not possible to pass strings containing invalid UTF-16 code points.
  271. // This is mitigated by escaping them as \uXXXX, however because of this the RegExp source becomes
  272. // `\uXXXX` instead of `<the actual UTF-16 code point of XXXX>`.
  273. // The resulting RegExp will work exactly the same, but it causes these two tests to fail.
  274. "test/annexB/built-ins/RegExp/RegExp-leading-escape-BMP.js": true,
  275. "test/annexB/built-ins/RegExp/RegExp-trailing-escape-BMP.js": true,
  276. // Promise
  277. "test/built-ins/Symbol/species/builtin-getter-name.js": true,
  278. // x ** y
  279. "test/built-ins/Array/prototype/pop/clamps-to-integer-limit.js": true,
  280. "test/built-ins/Array/prototype/pop/length-near-integer-limit.js": true,
  281. "test/built-ins/Array/prototype/push/clamps-to-integer-limit.js": true,
  282. "test/built-ins/Array/prototype/push/length-near-integer-limit.js": true,
  283. "test/built-ins/Array/prototype/push/throws-if-integer-limit-exceeded.js": true,
  284. "test/built-ins/Array/prototype/reverse/length-exceeding-integer-limit-with-object.js": true,
  285. "test/built-ins/Array/prototype/reverse/length-exceeding-integer-limit-with-proxy.js": true,
  286. "test/built-ins/Array/prototype/slice/length-exceeding-integer-limit.js": true,
  287. "test/built-ins/Array/prototype/splice/clamps-length-to-integer-limit.js": true,
  288. "test/built-ins/Array/prototype/splice/length-and-deleteCount-exceeding-integer-limit.js": true,
  289. "test/built-ins/Array/prototype/splice/length-exceeding-integer-limit-shrink-array.js": true,
  290. "test/built-ins/Array/prototype/splice/length-near-integer-limit-grow-array.js": true,
  291. "test/built-ins/Array/prototype/splice/throws-if-integer-limit-exceeded.js": true,
  292. "test/built-ins/Array/prototype/unshift/clamps-to-integer-limit.js": true,
  293. "test/built-ins/Array/prototype/unshift/length-near-integer-limit.js": true,
  294. "test/built-ins/Array/prototype/unshift/throws-if-integer-limit-exceeded.js": true,
  295. "test/built-ins/String/prototype/split/separator-undef-limit-custom.js": true,
  296. // generators
  297. "test/annexB/built-ins/RegExp/RegExp-control-escape-russian-letter.js": true,
  298. }
  299. featuresBlackList = []string{
  300. "arrow-function",
  301. "async-iteration",
  302. "BigInt",
  303. "class",
  304. "generators",
  305. "String.prototype.replaceAll",
  306. "super",
  307. }
  308. es6WhiteList = map[string]bool{}
  309. es6IdWhiteList = []string{
  310. "8.1.2.1",
  311. "9.5",
  312. "12.1",
  313. "12.2.1",
  314. "12.2.2",
  315. "12.2.5",
  316. "12.2.6.1",
  317. "12.2.6.8",
  318. "12.4",
  319. "12.5",
  320. "12.6",
  321. "12.7",
  322. "12.8",
  323. "12.9",
  324. "12.10",
  325. "13.1",
  326. "13.2",
  327. "13.3",
  328. "13.4",
  329. "13.5",
  330. "13.6",
  331. "13.7",
  332. "13.8",
  333. "13.9",
  334. "13.10",
  335. "13.11",
  336. "13.12",
  337. "13.13",
  338. "13.14",
  339. "13.15",
  340. "14.3.8",
  341. "18",
  342. "19",
  343. "20",
  344. "21",
  345. "22",
  346. "23",
  347. "24",
  348. "25.1",
  349. "26",
  350. "B.2.1",
  351. "B.2.2",
  352. }
  353. esIdPrefixWhiteList = []string{
  354. "sec-addition-*",
  355. "sec-array",
  356. "sec-%typedarray%",
  357. "sec-%typedarray%-of",
  358. "sec-@@iterator",
  359. "sec-@@tostringtag",
  360. "sec-string",
  361. "sec-date",
  362. "sec-json",
  363. "sec-number",
  364. "sec-math",
  365. "sec-arraybuffer-length",
  366. "sec-arraybuffer",
  367. "sec-regexp",
  368. "sec-string.prototype.trimLeft",
  369. "sec-string.prototype.trimRight",
  370. "sec-object.getownpropertydescriptor",
  371. "sec-object.getownpropertydescriptors",
  372. "sec-object.entries",
  373. "sec-object.values",
  374. "sec-object-initializer",
  375. "sec-proxy-*",
  376. "sec-for-statement-*",
  377. "sec-for-in-and-for-of-statements",
  378. "sec-for-in-and-for-of-statements-*",
  379. "sec-do-while-statement",
  380. "sec-if-statement",
  381. "sec-while-statement",
  382. "sec-with-statement*",
  383. "sec-switch-*",
  384. "sec-try-*",
  385. "sec-runtime-semantics-catchclauseevaluation",
  386. "sec-strict-mode-of-ecmascript",
  387. "sec-let-and-const-declarations*",
  388. "sec-arguments-exotic-objects-defineownproperty-p-desc",
  389. "sec-other-properties-of-the-global-object-globalthis",
  390. "sec-variable-statement-runtime-semantics-evaluation",
  391. "sec-function-calls-runtime-semantics-evaluation",
  392. "sec-function-definitions",
  393. "sec-function-definitions-runtime-semantics-evaluation",
  394. "sec-function-definitions-runtime-semantics-instantiatefunctionobject",
  395. "sec-function-definitions-runtime-semantics-iteratorbindinginitialization",
  396. "sec-function-definitions-static-semantics-early-errors",
  397. "sec-functiondeclarationinstantiation",
  398. "sec-functiondeclarations-in-ifstatement-statement-clauses",
  399. "sec-evaldeclarationinstantiation",
  400. "sec-integer-indexed-exotic-objects-defineownproperty-p-desc",
  401. "sec-destructuring-binding-patterns",
  402. "sec-runtime-semantics-keyeddestructuringassignmentevaluation",
  403. }
  404. )
  405. type tc39Test struct {
  406. name string
  407. f func(t *testing.T)
  408. }
  409. type tc39BenchmarkItem struct {
  410. name string
  411. duration time.Duration
  412. }
  413. type tc39BenchmarkData []tc39BenchmarkItem
  414. type tc39TestCtx struct {
  415. base string
  416. t *testing.T
  417. prgCache map[string]*Program
  418. prgCacheLock sync.Mutex
  419. enableBench bool
  420. benchmark tc39BenchmarkData
  421. benchLock sync.Mutex
  422. testQueue []tc39Test
  423. }
  424. type TC39MetaNegative struct {
  425. Phase, Type string
  426. }
  427. type tc39Meta struct {
  428. Negative TC39MetaNegative
  429. Includes []string
  430. Flags []string
  431. Features []string
  432. Es5id string
  433. Es6id string
  434. Esid string
  435. }
  436. func (m *tc39Meta) hasFlag(flag string) bool {
  437. for _, f := range m.Flags {
  438. if f == flag {
  439. return true
  440. }
  441. }
  442. return false
  443. }
  444. func parseTC39File(name string) (*tc39Meta, string, error) {
  445. f, err := os.Open(name)
  446. if err != nil {
  447. return nil, "", err
  448. }
  449. defer f.Close()
  450. b, err := ioutil.ReadAll(f)
  451. if err != nil {
  452. return nil, "", err
  453. }
  454. str := string(b)
  455. metaStart := strings.Index(str, "/*---")
  456. if metaStart == -1 {
  457. return nil, "", invalidFormatError
  458. } else {
  459. metaStart += 5
  460. }
  461. metaEnd := strings.Index(str, "---*/")
  462. if metaEnd == -1 || metaEnd <= metaStart {
  463. return nil, "", invalidFormatError
  464. }
  465. var meta tc39Meta
  466. err = yaml.Unmarshal([]byte(str[metaStart:metaEnd]), &meta)
  467. if err != nil {
  468. return nil, "", err
  469. }
  470. if meta.Negative.Type != "" && meta.Negative.Phase == "" {
  471. return nil, "", errors.New("negative type is set, but phase isn't")
  472. }
  473. return &meta, str, nil
  474. }
  475. func (*tc39TestCtx) detachArrayBuffer(call FunctionCall) Value {
  476. if obj, ok := call.Argument(0).(*Object); ok {
  477. if buf, ok := obj.self.(*arrayBufferObject); ok {
  478. buf.detach()
  479. return _undefined
  480. }
  481. }
  482. panic(typeError("detachArrayBuffer() is called with incompatible argument"))
  483. }
  484. func (*tc39TestCtx) throwIgnorableTestError(FunctionCall) Value {
  485. panic(ignorableTestError)
  486. }
  487. func (ctx *tc39TestCtx) runTC39Test(name, src string, meta *tc39Meta, t testing.TB) {
  488. defer func() {
  489. if x := recover(); x != nil {
  490. panic(fmt.Sprintf("panic while running %s: %v", name, x))
  491. }
  492. }()
  493. vm := New()
  494. _262 := vm.NewObject()
  495. _262.Set("detachArrayBuffer", ctx.detachArrayBuffer)
  496. _262.Set("createRealm", ctx.throwIgnorableTestError)
  497. vm.Set("$262", _262)
  498. vm.Set("IgnorableTestError", ignorableTestError)
  499. vm.Set("print", t.Log)
  500. vm.RunProgram(sabStub)
  501. err, early := ctx.runTC39Script(name, src, meta.Includes, vm)
  502. if err != nil {
  503. if meta.Negative.Type == "" {
  504. if err, ok := err.(*Exception); ok {
  505. if err.Value() == ignorableTestError {
  506. t.Skip("Test threw IgnorableTestError")
  507. }
  508. }
  509. t.Fatalf("%s: %v", name, err)
  510. } else {
  511. if (meta.Negative.Phase == "early" || meta.Negative.Phase == "parse") && !early || meta.Negative.Phase == "runtime" && early {
  512. t.Fatalf("%s: error %v happened at the wrong phase (expected %s)", name, err, meta.Negative.Phase)
  513. }
  514. var errType string
  515. switch err := err.(type) {
  516. case *Exception:
  517. if o, ok := err.Value().(*Object); ok {
  518. if c := o.Get("constructor"); c != nil {
  519. if c, ok := c.(*Object); ok {
  520. errType = c.Get("name").String()
  521. } else {
  522. t.Fatalf("%s: error constructor is not an object (%v)", name, o)
  523. }
  524. } else {
  525. t.Fatalf("%s: error does not have a constructor (%v)", name, o)
  526. }
  527. } else {
  528. t.Fatalf("%s: error is not an object (%v)", name, err.Value())
  529. }
  530. case *CompilerSyntaxError:
  531. errType = "SyntaxError"
  532. case *CompilerReferenceError:
  533. errType = "ReferenceError"
  534. default:
  535. t.Fatalf("%s: error is not a JS error: %v", name, err)
  536. }
  537. if errType != meta.Negative.Type {
  538. vm.vm.prg.dumpCode(t.Logf)
  539. t.Fatalf("%s: unexpected error type (%s), expected (%s)", name, errType, meta.Negative.Type)
  540. }
  541. }
  542. } else {
  543. if meta.Negative.Type != "" {
  544. vm.vm.prg.dumpCode(t.Logf)
  545. t.Fatalf("%s: Expected error: %v", name, err)
  546. }
  547. }
  548. if vm.vm.sp != 0 {
  549. t.Fatalf("sp: %d", vm.vm.sp)
  550. }
  551. if l := len(vm.vm.iterStack); l > 0 {
  552. t.Fatalf("iter stack is not empty: %d", l)
  553. }
  554. }
  555. func (ctx *tc39TestCtx) runTC39File(name string, t testing.TB) {
  556. if skipList[name] {
  557. t.Skip("Excluded")
  558. }
  559. p := path.Join(ctx.base, name)
  560. meta, src, err := parseTC39File(p)
  561. if err != nil {
  562. //t.Fatalf("Could not parse %s: %v", name, err)
  563. t.Errorf("Could not parse %s: %v", name, err)
  564. return
  565. }
  566. if meta.Es5id == "" {
  567. skip := true
  568. //t.Logf("%s: Not ES5, skipped", name)
  569. if es6WhiteList[name] {
  570. skip = false
  571. } else {
  572. if meta.Es6id != "" {
  573. for _, prefix := range es6IdWhiteList {
  574. if strings.HasPrefix(meta.Es6id, prefix) &&
  575. (len(meta.Es6id) == len(prefix) || meta.Es6id[len(prefix)] == '.') {
  576. skip = false
  577. break
  578. }
  579. }
  580. }
  581. }
  582. if skip {
  583. if meta.Esid != "" {
  584. for _, prefix := range esIdPrefixWhiteList {
  585. if strings.HasSuffix(prefix, "*") {
  586. if strings.HasPrefix(meta.Esid, prefix[:len(prefix)-1]) {
  587. skip = false
  588. break
  589. }
  590. } else {
  591. if strings.HasPrefix(meta.Esid, prefix) &&
  592. (len(meta.Esid) == len(prefix) || meta.Esid[len(prefix)] == '.') {
  593. skip = false
  594. break
  595. }
  596. }
  597. }
  598. }
  599. }
  600. if skip {
  601. t.Skip("Not ES5")
  602. }
  603. for _, feature := range meta.Features {
  604. for _, bl := range featuresBlackList {
  605. if feature == bl {
  606. t.Skip("Blacklisted feature")
  607. }
  608. }
  609. }
  610. }
  611. var startTime time.Time
  612. if ctx.enableBench {
  613. startTime = time.Now()
  614. }
  615. hasRaw := meta.hasFlag("raw")
  616. if hasRaw || !meta.hasFlag("onlyStrict") {
  617. //log.Printf("Running normal test: %s", name)
  618. t.Logf("Running normal test: %s", name)
  619. ctx.runTC39Test(name, src, meta, t)
  620. }
  621. if !hasRaw && !meta.hasFlag("noStrict") {
  622. //log.Printf("Running strict test: %s", name)
  623. t.Logf("Running strict test: %s", name)
  624. ctx.runTC39Test(name, "'use strict';\n"+src, meta, t)
  625. }
  626. if ctx.enableBench {
  627. ctx.benchLock.Lock()
  628. ctx.benchmark = append(ctx.benchmark, tc39BenchmarkItem{
  629. name: name,
  630. duration: time.Since(startTime),
  631. })
  632. ctx.benchLock.Unlock()
  633. }
  634. }
  635. func (ctx *tc39TestCtx) init() {
  636. ctx.prgCache = make(map[string]*Program)
  637. }
  638. func (ctx *tc39TestCtx) compile(base, name string) (*Program, error) {
  639. ctx.prgCacheLock.Lock()
  640. defer ctx.prgCacheLock.Unlock()
  641. prg := ctx.prgCache[name]
  642. if prg == nil {
  643. fname := path.Join(base, name)
  644. f, err := os.Open(fname)
  645. if err != nil {
  646. return nil, err
  647. }
  648. defer f.Close()
  649. b, err := ioutil.ReadAll(f)
  650. if err != nil {
  651. return nil, err
  652. }
  653. str := string(b)
  654. prg, err = Compile(name, str, false)
  655. if err != nil {
  656. return nil, err
  657. }
  658. ctx.prgCache[name] = prg
  659. }
  660. return prg, nil
  661. }
  662. func (ctx *tc39TestCtx) runFile(base, name string, vm *Runtime) error {
  663. prg, err := ctx.compile(base, name)
  664. if err != nil {
  665. return err
  666. }
  667. _, err = vm.RunProgram(prg)
  668. return err
  669. }
  670. func (ctx *tc39TestCtx) runTC39Script(name, src string, includes []string, vm *Runtime) (err error, early bool) {
  671. early = true
  672. err = ctx.runFile(ctx.base, path.Join("harness", "assert.js"), vm)
  673. if err != nil {
  674. return
  675. }
  676. err = ctx.runFile(ctx.base, path.Join("harness", "sta.js"), vm)
  677. if err != nil {
  678. return
  679. }
  680. for _, include := range includes {
  681. err = ctx.runFile(ctx.base, path.Join("harness", include), vm)
  682. if err != nil {
  683. return
  684. }
  685. }
  686. var p *Program
  687. p, err = Compile(name, src, false)
  688. if err != nil {
  689. return
  690. }
  691. early = false
  692. _, err = vm.RunProgram(p)
  693. return
  694. }
  695. func (ctx *tc39TestCtx) runTC39Tests(name string) {
  696. files, err := ioutil.ReadDir(path.Join(ctx.base, name))
  697. if err != nil {
  698. ctx.t.Fatal(err)
  699. }
  700. for _, file := range files {
  701. if file.Name()[0] == '.' {
  702. continue
  703. }
  704. if file.IsDir() {
  705. ctx.runTC39Tests(path.Join(name, file.Name()))
  706. } else {
  707. fileName := file.Name()
  708. if strings.HasSuffix(fileName, ".js") && !strings.HasSuffix(fileName, "_FIXTURE.js") {
  709. name := path.Join(name, fileName)
  710. ctx.runTest(name, func(t *testing.T) {
  711. ctx.runTC39File(name, t)
  712. })
  713. }
  714. }
  715. }
  716. }
  717. func TestTC39(t *testing.T) {
  718. if testing.Short() {
  719. t.Skip()
  720. }
  721. if _, err := os.Stat(tc39BASE); err != nil {
  722. t.Skipf("If you want to run tc39 tests, download them from https://github.com/tc39/test262 and put into %s. The current working commit is ddfe24afe3043388827aa220ef623b8540958bbd. (%v)", tc39BASE, err)
  723. }
  724. ctx := &tc39TestCtx{
  725. base: tc39BASE,
  726. }
  727. ctx.init()
  728. //ctx.enableBench = true
  729. t.Run("tc39", func(t *testing.T) {
  730. ctx.t = t
  731. //ctx.runTC39File("test/language/types/number/8.5.1.js", t)
  732. //ctx.runTC39Tests("test/language")
  733. ctx.runTC39Tests("test/language/expressions")
  734. ctx.runTC39Tests("test/language/arguments-object")
  735. ctx.runTC39Tests("test/language/asi")
  736. ctx.runTC39Tests("test/language/directive-prologue")
  737. ctx.runTC39Tests("test/language/function-code")
  738. ctx.runTC39Tests("test/language/eval-code")
  739. ctx.runTC39Tests("test/language/global-code")
  740. ctx.runTC39Tests("test/language/identifier-resolution")
  741. ctx.runTC39Tests("test/language/identifiers")
  742. //ctx.runTC39Tests("test/language/literals") // octal sequences in strict mode
  743. ctx.runTC39Tests("test/language/punctuators")
  744. ctx.runTC39Tests("test/language/reserved-words")
  745. ctx.runTC39Tests("test/language/source-text")
  746. ctx.runTC39Tests("test/language/statements")
  747. ctx.runTC39Tests("test/language/types")
  748. ctx.runTC39Tests("test/language/white-space")
  749. ctx.runTC39Tests("test/built-ins")
  750. ctx.runTC39Tests("test/annexB/built-ins/String/prototype/substr")
  751. ctx.runTC39Tests("test/annexB/built-ins/String/prototype/trimLeft")
  752. ctx.runTC39Tests("test/annexB/built-ins/String/prototype/trimRight")
  753. ctx.runTC39Tests("test/annexB/built-ins/escape")
  754. ctx.runTC39Tests("test/annexB/built-ins/unescape")
  755. ctx.runTC39Tests("test/annexB/built-ins/RegExp")
  756. ctx.flush()
  757. })
  758. if ctx.enableBench {
  759. sort.Slice(ctx.benchmark, func(i, j int) bool {
  760. return ctx.benchmark[i].duration > ctx.benchmark[j].duration
  761. })
  762. bench := ctx.benchmark
  763. if len(bench) > 50 {
  764. bench = bench[:50]
  765. }
  766. for _, item := range bench {
  767. fmt.Printf("%s\t%d\n", item.name, item.duration/time.Millisecond)
  768. }
  769. }
  770. }