Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add tc39/test262 tests in k6 #1747

Merged
merged 26 commits into from
Dec 14, 2020
Merged
Show file tree
Hide file tree
Changes from 20 commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
1d2ac19
PoC tc39/test262 tests in k6
mstoykov Nov 30, 2020
dd14b50
Enable tc39/test262 sec-array
mstoykov Nov 30, 2020
f8a4b6d
Add inline comments that tc39 code is based on dop251 work
mstoykov Nov 30, 2020
6ab66b9
refactor and appease the linter
mstoykov Dec 1, 2020
a74227a
tc39/testdata make the directory structure match the name of the test
mstoykov Dec 1, 2020
c5ab1f0
tc39/test262: Enable some parallel execution
mstoykov Dec 1, 2020
4039c37
Revert "tc39/test262: Enable some parallel execution"
mstoykov Dec 1, 2020
3d03c8b
tc39/test262: Skip Intl and annexB/language
mstoykov Dec 1, 2020
38d5fc0
Enable more tests
mstoykov Dec 1, 2020
0cd1e2f
tc39/test262: small optimization
mstoykov Dec 2, 2020
7b15248
half tests by just running in strict mode
mstoykov Dec 2, 2020
9c557fa
tc39/test262: Run only one of non/strict versions of each test
mstoykov Dec 2, 2020
268565d
update breaking changes after last change
mstoykov Dec 2, 2020
01a67f0
Block by path some tests
mstoykov Dec 2, 2020
45d341e
change breaking test errors based on previous commit :facepalm:
mstoykov Dec 2, 2020
7eb2ee8
Disable async/promise tests by path
mstoykov Dec 2, 2020
e883572
Disable more tests through their path
mstoykov Dec 2, 2020
11aae1b
don't run any async tests and update breaking changes
mstoykov Dec 2, 2020
0de5490
Update js/tc39/README.md
mstoykov Dec 9, 2020
98c189f
Move the checkout in a script for easier maitnability
mstoykov Dec 10, 2020
bb1d4e1
Add tc39 github workflow
mstoykov Dec 10, 2020
72a1bb8
Add /js/tc39/TestTC39 to .gitignore
mstoykov Dec 10, 2020
91efee8
Update js/tc39/Readme.md
mstoykov Dec 10, 2020
0d03288
fix the tc39 workflow
mstoykov Dec 10, 2020
0e0e97e
random not js change
mstoykov Dec 10, 2020
cf54873
Run on every master or tag push
mstoykov Dec 10, 2020
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 16 additions & 0 deletions .github/workflows/all.yml
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,22 @@ jobs:
fi
go test "${args[@]}" -timeout 800s ./...

tc39:
runs-on: ubuntu-latest
steps:
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do we want to run this on every commit? We might be OK with just running them on each release (version tag), especially if they're flaky, and we should probably exclude it from the requirements for a successful build.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  1. there are currently no requirements (I think)
  2. they aren't really flaky ... just they sometimes take too much time - predomenantly when I increase them or decide to try to enable parallel execution ... OR maybe they take too much memory 🤷‍♂️
  3. In the end we might move them to not being run on eveyr commit :D, but currently they are in development :P

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We can move this to its own job, and have it run only when files in js were changed with https://docs.github.com/en/free-pro-team@latest/actions/reference/workflow-syntax-for-github-actions#onpushpull_requestpaths

That said, if it takes less than 10 minutes, this is probably good enough...

- name: Checkout code
uses: actions/checkout@v2
- name: Install Go
uses: actions/setup-go@v2
with:
go-version: 1.15.x
- name: Run tests
run: |
set -x
cd js/tc39
sh checkout.sh
go test -timeout 1h

test-cov:
strategy:
matrix:
Expand Down
33 changes: 33 additions & 0 deletions js/tc39/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
# This a WIP
The point of this repo is to test k6 goja+babel+core.js combo against the tc39 test suite.

Ways to use it:
1. run ./checkout.sh to checkout the last commit sha of [test262](https://github.com/tc39/test262)
that was tested with
2. Run `go test &> out.log`

if there are failures there will be a JSON with what failed.
The full list of failing tests is in `breaking_test_errors.json` in order to regenerate it (in case
of changes) it needs to become an empty JSON object `{}` and then the test should be rerun and the
new json should be put there.

TODO:
1. ~Enable more test currently only es5 and es6 tests are enabled but babel supports some ES2016 and
ES2017~
2. disable tests that we know won't work and .. don't care
3. Make this faster and better
4. ~Move it to inside k6~


This is obviously a modified version of [the code in the goja
repo](https://github.com/dop251/goja/blob/master/tc39_test.go)


# Reasons for recording breaking_test_errors.json

Unfortunately k6 doesn't pass all the test that are currently defined as "interesting" and probably
won't even more. Goja decided to just not run the ones that it knows it fails currently, but this
means that if they stop failing, someone needs to go re-enable these tests. This also means that, if the
previous breakage was something a user can work around in a certain way, it now might be something
else that the user can't workaround or have another problem. For this reasons I decided that
actually recording what breaks and checking that it doesn't change is a better idea.
1,005 changes: 1,005 additions & 0 deletions js/tc39/breaking_test_errors.json

Large diffs are not rendered by default.

9 changes: 9 additions & 0 deletions js/tc39/checkout.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
#!/bin/sh
sha=72154b17fc99a26e79b2586960f059360d4ce43d # this is just the commit it was last tested with
mkdir -p ./TestTC39/test262
cd ./TestTC39/test262
imiric marked this conversation as resolved.
Show resolved Hide resolved
git init
git remote add origin https://github.com/tc39/test262.git
git fetch origin --depth=1 "${sha}"
git reset --hard "${sha}"
cd -
16 changes: 16 additions & 0 deletions js/tc39/tc39_norace_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
// +build !race
// Heavily influenced by the fantastic work by @dop251 for https://github.com/dop251/goja

package tc39

import "testing"

func (ctx *tc39TestCtx) runTest(name string, f func(t *testing.T)) {
ctx.t.Run(name, func(t *testing.T) {
// t.Parallel()
f(t)
})
}

func (ctx *tc39TestCtx) flush() {
}
32 changes: 32 additions & 0 deletions js/tc39/tc39_race_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
// +build race
// Heavily influenced by the fantastic work by @dop251 for https://github.com/dop251/goja

package tc39

import (
"testing"
)

const (
tc39MaxTestGroupSize = 1000 // to prevent race detector complaining about too many goroutines
)

func (ctx *tc39TestCtx) runTest(name string, f func(t *testing.T)) {
ctx.testQueue = append(ctx.testQueue, tc39Test{name: name, f: f})
if len(ctx.testQueue) >= tc39MaxTestGroupSize {
ctx.flush()
}
}

func (ctx *tc39TestCtx) flush() {
ctx.t.Run("tc39", func(t *testing.T) {
for _, tc := range ctx.testQueue {
tc := tc
t.Run(tc.name, func(t *testing.T) {
t.Parallel()
tc.f(t)
})
}
})
ctx.testQueue = ctx.testQueue[:0]
}
Loading