-
Notifications
You must be signed in to change notification settings - Fork 11
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
Improve CI #281
base: main
Are you sure you want to change the base?
Improve CI #281
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -89,31 +89,21 @@ jobs: | |
rm $GITHUB_WORKSPACE/test/wasm-spec/core/call_indirect.wast | ||
$RUNNER --engine="$GITHUB_WORKSPACE/out/clang/x86/walrus" | ||
$RUNNER --jit --engine="$GITHUB_WORKSPACE/out/clang/x64/walrus" | ||
$RUNNER --jit --engine="$GITHUB_WORKSPACE/out/pure/x86/walrus" basic-tests wasm-test-core jit | ||
$RUNNER --no-reg-alloc --engine="$GITHUB_WORKSPACE/out/clang/x64/walrus" | ||
$RUNNER --engine="$GITHUB_WORKSPACE/out/pure/x64/walrus" basic-tests wasm-test-core jit | ||
$RUNNER --jit --engine="$GITHUB_WORKSPACE/out/pure/x86/walrus" basic-tests wasm-test-core jit | ||
$RUNNER --no-reg-alloc --engine="$GITHUB_WORKSPACE/out/pure/x86/walrus" basic-tests wasm-test-core jit | ||
Comment on lines
-92
to
+95
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The number of build options increased a lot and seems quite complex. |
||
|
||
build-test-on-x86: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
submodules: true | ||
- name: Install Packages | ||
run: | | ||
sudo apt update | ||
sudo apt install -y ninja-build gcc-multilib g++-multilib | ||
- name: Build x86 | ||
env: | ||
BUILD_OPTIONS: -DWALRUS_ARCH=x86 -DWALRUS_HOST=linux -DWALRUS_MODE=debug -DWALRUS_OUTPUT=shell -GNinja | ||
run: | | ||
cmake -H. -Bout/linux/x86 $BUILD_OPTIONS | ||
ninja -Cout/linux/x86 | ||
- name: Run Tests | ||
run: | | ||
$RUNNER --engine="$GITHUB_WORKSPACE/out/linux/x86/walrus" | ||
$RUNNER --jit --engine="$GITHUB_WORKSPACE/out/linux/x86/walrus" | ||
|
||
build-test-on-x64: | ||
build-test-on-x86_x64: | ||
strategy: | ||
matrix: | ||
arch: | ||
- x86 | ||
- x64 | ||
switch: | ||
- --jit | ||
- --no-reg-alloc | ||
- "" | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
|
@@ -123,16 +113,15 @@ jobs: | |
run: | | ||
sudo apt update | ||
sudo apt install -y ninja-build gcc-multilib g++-multilib | ||
- name: Build x64 | ||
- name: Build ${{ matrix.arch }} | ||
env: | ||
BUILD_OPTIONS: -DWALRUS_ARCH=x64 -DWALRUS_HOST=linux -DWALRUS_MODE=debug -DWALRUS_OUTPUT=shell -GNinja | ||
BUILD_OPTIONS: -DWALRUS_ARCH=${{ matrix.arch }} -DWALRUS_HOST=linux -DWALRUS_MODE=debug -DWALRUS_OUTPUT=shell -GNinja | ||
run: | | ||
cmake -H. -Bout/linux/x64 $BUILD_OPTIONS | ||
ninja -Cout/linux/x64 | ||
cmake -H. -Bout/linux/${{ matrix.arch }} $BUILD_OPTIONS | ||
ninja -Cout/linux/${{ matrix.arch }} | ||
- name: Run Tests | ||
run: | | ||
$RUNNER --engine="$GITHUB_WORKSPACE/out/linux/x64/walrus" | ||
$RUNNER --jit --engine="$GITHUB_WORKSPACE/out/linux/x64/walrus" | ||
$RUNNER ${{ matrix.switch }} --engine="$GITHUB_WORKSPACE/out/linux/${{ matrix.arch }}/walrus" | ||
|
||
build-on-x64-with-perf: | ||
runs-on: ubuntu-latest | ||
|
@@ -151,17 +140,30 @@ jobs: | |
cmake -H. -Bout/linux/x64 $BUILD_OPTIONS | ||
ninja -Cout/linux/x64 | ||
|
||
build-test-on-armv7: | ||
build-test-on-armv7_aarch64: | ||
strategy: | ||
matrix: | ||
arch: | ||
- run_on_arch: armv7 | ||
walrus: arm | ||
distro: ubuntu_latest | ||
- run_on_arch: aarch64 | ||
walrus: aarch64 | ||
distro: ubuntu22.04 | ||
switch: | ||
- --jit | ||
- --no-reg-alloc | ||
- "" | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
submodules: true | ||
- name: Build in arm32 container | ||
- name: Build in container | ||
uses: uraimo/[email protected] | ||
with: | ||
arch: armv7 | ||
distro: ubuntu_latest | ||
arch: ${{ matrix.arch.run_on_arch }} | ||
distro: ${{ matrix.arch.distro }} | ||
|
||
# Install deps into the container. With the token, the container will be cached | ||
# The image is cached publically like a package | ||
|
@@ -171,46 +173,15 @@ jobs: | |
apt-get update | ||
apt-get install -y cmake build-essential ninja-build pkg-config python3 clang git | ||
run: | | ||
CC=clang CXX=clang++ cmake -H. -Bout/debug -DWALRUS_ARCH=arm -DWALRUS_HOST=linux -DWALRUS_MODE=debug -DWALRUS_OUTPUT=shell -GNinja | ||
CC=clang CXX=clang++ cmake -H. -Bout/pure -DWALRUS_ARCH=arm -DWALRUS_HOST=linux -DWALRUS_MODE=debug -DWALRUS_OUTPUT=shell -DWALRUS_WASI=OFF -GNinja | ||
CC=clang CXX=clang++ cmake -H. -Bout/debug -DWALRUS_ARCH=${{ matrix.arch.walrus }} -DWALRUS_HOST=linux -DWALRUS_MODE=debug -DWALRUS_OUTPUT=shell -GNinja | ||
CC=clang CXX=clang++ cmake -H. -Bout/pure -DWALRUS_ARCH=${{ matrix.arch.walrus }} -DWALRUS_HOST=linux -DWALRUS_MODE=debug -DWALRUS_OUTPUT=shell -DWALRUS_WASI=OFF -GNinja | ||
ninja -Cout/debug | ||
ninja -Cout/pure | ||
# remove 2 test files due to stack overflow occurred by recursion calls in debug mode build by clang | ||
rm ./test/wasm-spec/core/call.wast | ||
rm ./test/wasm-spec/core/call_indirect.wast | ||
python3 ./tools/run-tests.py --engine="./out/debug/walrus" | ||
python3 ./tools/run-tests.py --jit --engine="./out/debug/walrus" | ||
python3 ./tools/run-tests.py --engine="./out/pure/walrus" basic-tests wasm-test-core jit | ||
python3 ./tools/run-tests.py --jit --engine="./out/pure/walrus" basic-tests wasm-test-core jit | ||
|
||
build-test-on-aarch64: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
submodules: true | ||
- name: Build in arm64 container | ||
uses: uraimo/[email protected] | ||
with: | ||
arch: aarch64 | ||
distro: ubuntu22.04 | ||
|
||
# Install deps into the container. With the token, the container will be cached | ||
# The image is cached publically like a package | ||
githubToken: ${{ github.token }} | ||
|
||
install: | | ||
apt-get update | ||
apt-get install -y cmake build-essential ninja-build pkg-config python3 clang git | ||
run: | | ||
CC=clang CXX=clang++ cmake -H. -Bout/release -DWALRUS_ARCH=aarch64 -DWALRUS_HOST=linux -DWALRUS_MODE=release -DWALRUS_OUTPUT=shell -GNinja | ||
CC=clang CXX=clang++ cmake -H. -Bout/pure -DWALRUS_ARCH=aarch64 -DWALRUS_HOST=linux -DWALRUS_MODE=release -DWALRUS_OUTPUT=shell -DWALRUS_WASI=OFF -GNinja | ||
ninja -Cout/release | ||
ninja -Cout/pure | ||
python3 ./tools/run-tests.py --engine="./out/release/walrus" | ||
python3 ./tools/run-tests.py --jit --engine="./out/release/walrus" | ||
python3 ./tools/run-tests.py --engine="./out/pure/walrus" basic-tests wasm-test-core jit | ||
python3 ./tools/run-tests.py --jit --engine="./out/pure/walrus" basic-tests wasm-test-core jit | ||
python3 ./tools/run-tests.py ${{ matrix.switch }} --engine="./out/debug/walrus" | ||
python3 ./tools/run-tests.py ${{ matrix.switch }} --engine="./out/pure/walrus" basic-tests wasm-test-core jit | ||
|
||
test-on-windows-x86-x64: | ||
runs-on: windows-2022 | ||
|
@@ -272,7 +243,12 @@ jobs: | |
run: | | ||
$RUNNER --engine="$GITHUB_WORKSPACE/out/extended/walrus" wasm-test-extended | ||
|
||
build-test-performance: | ||
build-test-performance-x64_x86: | ||
strategy: | ||
matrix: | ||
arch: | ||
- x64 | ||
- x86 | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
|
@@ -285,15 +261,15 @@ jobs: | |
sudo pip install pandas | ||
sudo pip install py-markdown-table | ||
sudo pip install tqdm | ||
- name: Build x64 | ||
- name: Build ${{ matrix.arch }} | ||
env: | ||
BUILD_OPTIONS: -DWALRUS_ARCH=x64 -DWALRUS_HOST=linux -DWALRUS_MODE=release -DWALRUS_OUTPUT=shell -GNinja | ||
BUILD_OPTIONS: -DWALRUS_ARCH=${{ matrix.arch }} -DWALRUS_HOST=linux -DWALRUS_MODE=release -DWALRUS_OUTPUT=shell -GNinja | ||
run: | | ||
cmake -H. -Bout/linux/x64 $BUILD_OPTIONS | ||
ninja -Cout/linux/x64 | ||
cmake -H. -Bout/linux/${{ matrix.arch }} $BUILD_OPTIONS | ||
ninja -Cout/linux/${{ matrix.arch }} | ||
- name: Run Tests | ||
run: | | ||
test/wasmBenchmarker/benchmark.py --engines $GITHUB_WORKSPACE/out/linux/x64/walrus --iterations 2 --verbose --summary --results i j2i n2i j n2j | ||
test/wasmBenchmarker/benchmark.py --engines $GITHUB_WORKSPACE/out/linux/${{ matrix.arch }}/walrus --iterations 2 --verbose --summary --results i j2i n2i j n2j | ||
|
||
built-test-wasm-c-api: | ||
runs-on: ubuntu-latest | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -47,6 +47,7 @@ | |
DEFAULT_RUNNERS = [] | ||
JIT_EXCLUDE_FILES = [] | ||
jit = False | ||
jit_no_reg_alloc = False | ||
|
||
|
||
class runner(object): | ||
|
@@ -64,12 +65,18 @@ def __call__(self, fn): | |
def _run_wast_tests(engine, files, is_fail): | ||
fails = 0 | ||
for file in files: | ||
if jit: | ||
filename = os.path.basename(file) | ||
if jit or jit_no_reg_alloc: | ||
filename = os.path.basename(file) | ||
if filename in JIT_EXCLUDE_FILES: | ||
continue | ||
|
||
proc = Popen([engine, "--mapdirs", "./test/wasi", "/var", file], stdout=PIPE) if not jit else Popen([engine, "--mapdirs", "./test/wasi", "/var", "--jit", file], stdout=PIPE) | ||
openParams = [engine, "--mapdirs", "./test/wasi", "/var", file] | ||
if jit: | ||
openParams = [engine, "--mapdirs", "./test/wasi", "/var", "--jit", file] | ||
elif jit_no_reg_alloc: | ||
openParams = [engine, "--mapdirs", "./test/wasi", "/var", "--jit", "--jit-no-reg-alloc", file] | ||
|
||
proc = Popen(openParams, stdout=PIPE) | ||
out, _ = proc.communicate() | ||
|
||
if is_fail and proc.returncode or not is_fail and not proc.returncode: | ||
|
@@ -178,10 +185,18 @@ def main(): | |
parser.add_argument('suite', metavar='SUITE', nargs='*', default=sorted(DEFAULT_RUNNERS), | ||
help='test suite to run (%s; default: %s)' % (', '.join(sorted(RUNNERS.keys())), ' '.join(sorted(DEFAULT_RUNNERS)))) | ||
parser.add_argument('--jit', action='store_true', help='test with JIT') | ||
parser.add_argument('--no-reg-alloc', action='store_true', help='test with JIT without register allocation') | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
|
||
args = parser.parse_args() | ||
global jit | ||
jit = args.jit | ||
if jit: | ||
|
||
global jit_no_reg_alloc | ||
jit_no_reg_alloc = args.no_reg_alloc | ||
|
||
if jit and jit_no_reg_alloc: | ||
parser.error('jit and no-reg-alloc cannot be used together') | ||
|
||
if jit or jit_no_reg_alloc: | ||
exclude_list_file = join(PROJECT_SOURCE_DIR, 'tools', 'jit_exclude_list.txt') | ||
with open(exclude_list_file) as f: | ||
global JIT_EXCLUDE_FILES | ||
|
@@ -195,7 +210,12 @@ def main(): | |
success, fail = [], [] | ||
|
||
for suite in args.suite: | ||
print(COLOR_PURPLE + f'running test suite{ " with jit" if jit else ""}: ' + suite + COLOR_RESET) | ||
text = "" | ||
if jit: | ||
text = " with jit" | ||
elif jit_no_reg_alloc: | ||
text = " with jit without register allocation" | ||
print(COLOR_PURPLE + f'running test suite{text}: ' + suite + COLOR_RESET) | ||
try: | ||
RUNNERS[suite](args.engine) | ||
success += [suite] | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
--no-reg-alloc
also enables--jit
?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes