Run Stdlib tests on CI (#1196)

This commit is contained in:
Marcin Kostrzewa 2020-10-06 17:45:02 +02:00 committed by GitHub
parent 2a6dbf0eda
commit 42dcc1a003
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 38 additions and 136 deletions

15
.github/settings.yml vendored
View File

@ -214,12 +214,9 @@ branches:
# Require branches to be up to date before merging. # Require branches to be up to date before merging.
strict: true strict: true
contexts: contexts:
- "Test Engine (macOS-latest)" - "Build and Test (macOS-latest)"
- "Test Engine (ubuntu-latest)" - "Build and Test (ubuntu-latest)"
- "Test Engine (windows-latest)" - "Build and Test (windows-latest)"
- "Build Engine (macOS-latest)"
- "Build Engine (ubuntu-latest)"
- "Build Engine (windows-latest)"
- "Docs Check" - "Docs Check"
- "Rust Check" - "Rust Check"
- "Rust Lint" - "Rust Lint"
@ -242,9 +239,9 @@ branches:
# Require branches to be up to date before merging. # Require branches to be up to date before merging.
strict: true strict: true
contexts: contexts:
- "Test Engine (macOS-latest)" - "Build and Test (macOS-latest)"
- "Test Engine (ubuntu-latest)" - "Build and Test (ubuntu-latest)"
- "Test Engine (windows-latest)" - "Build and Test (windows-latest)"
- "Docs Check" - "Docs Check"
- "Build Engine" - "Build Engine"
- "Rust Check" - "Rust Check"

View File

@ -28,9 +28,8 @@ env:
README.md README.md
jobs: jobs:
# This job is responsible for testing the codebase test_and_publish:
test: name: Build and Test
name: Test Engine
runs-on: ${{ matrix.os }} runs-on: ${{ matrix.os }}
timeout-minutes: 45 timeout-minutes: 45
strategy: strategy:
@ -107,7 +106,7 @@ jobs:
restore-keys: | restore-keys: |
${{ runner.os }}-maven- ${{ runner.os }}-maven-
# Build # Compile
- name: Bootstrap Enso project - name: Bootstrap Enso project
run: | run: |
sleep 1 sleep 1
@ -123,7 +122,7 @@ jobs:
run: | run: |
echo '::set-env name=CI_TEST_TIMEFACTOR::2' echo '::set-env name=CI_TEST_TIMEFACTOR::2'
echo '::set-env name=CI_TEST_FLAKY_ENABLE::true' echo '::set-env name=CI_TEST_FLAKY_ENABLE::true'
- name: Prebuild Base Java Extensions - name: Build Base Java Extensions
shell: bash shell: bash
run: | run: |
cd std-bits cd std-bits
@ -132,6 +131,9 @@ jobs:
run: | run: |
sleep 1 sleep 1
sbt --no-colors launcher/buildNativeImage sbt --no-colors launcher/buildNativeImage
# Prevents launcher/test from re-building the Native Image during
# test run. It is built before starting the tests to conserve system
# memory
echo '::set-env name=LAUNCHER_NATIVE_IMAGE_TEST_SKIP_BUILD::true' echo '::set-env name=LAUNCHER_NATIVE_IMAGE_TEST_SKIP_BUILD::true'
- name: Test Enso - name: Test Enso
run: | run: |
@ -149,115 +151,9 @@ jobs:
run: | run: |
sleep 1 sleep 1
sbt --no-colors searcher/Benchmark/compile sbt --no-colors searcher/Benchmark/compile
- name: Build the Uberjar
run: |
sleep 1
sbt --no-colors runner/assembly
- name: Test the Uberjar
run: ./runner.jar --run tools/ci/Test.enso
- name: Test the Repl in the Uberjar
shell: bash
run:
cat tools/ci/artifact-test/repl/ReplTest.in | ./runner.jar --repl |
diff -q tools/ci/artifact-test/repl/ReplTest.out - && echo "Test
successful"
# This job is responsible for building the artifacts # Build Distribution
build: - name: Build the Runner & Runtime Uberjars
name: Build Engine
runs-on: ${{ matrix.os }}
timeout-minutes: 45
strategy:
matrix:
os: [macOS-latest, ubuntu-latest, windows-latest]
fail-fast: false
steps:
- name: Checkout (PR)
uses: actions/checkout@v2
if: github.event_name == 'pull_request'
with:
ref: ${{ github.event.pull_request.head.sha }}
- name: Checkout (Branch)
uses: actions/checkout@v2
if: github.event_name != 'pull_request'
- name: Enable Developer Command Prompt (Windows)
uses: ilammy/msvc-dev-cmd@v1.3.0
- name: Disable TCP/UDP Offloading (macOS)
if: runner.os == 'macOS'
shell: bash
run: |
sudo sysctl -w net.link.generic.system.hwcksum_tx=0
sudo sysctl -w net.link.generic.system.hwcksum_rx=0
- name: Disable TCP/UDP Offloading (Linux)
if: runner.os == 'Linux'
shell: bash
run: sudo ethtool -K eth0 tx off rx off
- name: Disable TCP/UDP Offloading (Windows)
if: runner.os == 'Windows'
shell: powershell
run: >
Disable-NetAdapterChecksumOffload -Name * -TcpIPv4 -UdpIPv4 -TcpIPv6
-UdpIPv6
- name: Install Rust
uses: actions-rs/toolchain@v1
with:
toolchain: ${{ env.rustToolchain }}
override: true
- name: Setup conda
uses: s-weigand/setup-conda@v1
with:
update-conda: true
conda-channels: anaconda, conda-forge
- name: Setup Conda Environment on Windows
if: runner.os == 'Windows'
run: |
conda create --name enso
conda init powershell
- name: Activate Conda Environment on Windows
if: runner.os == 'Windows'
run: conda activate enso
- name: Install FlatBuffers Compiler
run: conda install flatbuffers=1.12.0
- name: Setup GraalVM Environment
uses: ayltai/setup-graalvm@v1
with:
graalvm-version: ${{ env.graalVersion }}
java-version: ${{ env.javaVersion }}
native-image: true
- name: Set Up SBT
run: |
curl --retry 4 --retry-connrefused -fsSL -o sbt.tgz https://github.com/sbt/sbt/releases/download/v${{env.sbtVersion}}/sbt-${{env.sbtVersion}}.tgz
tar -xzf sbt.tgz
echo ::add-path::$GITHUB_WORKSPACE/sbt/bin/
# Caches
- name: Cache SBT
uses: actions/cache@v2
with:
path: |
~/.sbt
~/.ivy2/cache
~/.cache
key: ${{ runner.os }}-sbt-${{ hashFiles('**build.sbt') }}
restore-keys: ${{ runner.os }}-sbt-
- name: Cache Local Maven Repository
uses: actions/cache@v2
with:
path: ~/.m2/repository
key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }}
restore-keys: |
${{ runner.os }}-maven-
# Build Artifacts
- name: Bootstrap the Project
run: |
sleep 1
sbt --no-colors bootstrap
- name: Build the Runtime Uberjar
run: |
sleep 1
sbt --no-colors runtime/assembly
- name: Build the Runner Uberjar
run: | run: |
sleep 1 sleep 1
sbt --no-colors runner/assembly sbt --no-colors runner/assembly
@ -265,10 +161,6 @@ jobs:
run: | run: |
sleep 1 sleep 1
sbt --no-colors project-manager/assembly sbt --no-colors project-manager/assembly
- name: Build the Launcher Native Image
run: |
sleep 1
sbt --no-colors launcher/buildNativeImage
- name: Build the Manifest - name: Build the Manifest
run: | run: |
cp distribution/manifest.template.yaml manifest.yaml cp distribution/manifest.template.yaml manifest.yaml
@ -339,12 +231,6 @@ jobs:
run: | run: |
cp enso.exe ${{ env.LAUNCHER_DIST_DIR }}/bin/ cp enso.exe ${{ env.LAUNCHER_DIST_DIR }}/bin/
- name: Build Base Java Extensions
shell: bash
run: |
cd std-bits
mvn --no-transfer-progress package
# The way artifacts are uploaded currently does not preserve the # The way artifacts are uploaded currently does not preserve the
# executable bits for Unix. However putting artifacts into a ZIP would # executable bits for Unix. However putting artifacts into a ZIP would
# create a twice nested ZIP file. For now, users downloading artifacts # create a twice nested ZIP file. For now, users downloading artifacts
@ -365,6 +251,19 @@ jobs:
cp -r distribution/bin $ENGINE_DIST_DIR/bin cp -r distribution/bin $ENGINE_DIST_DIR/bin
cp manifest.yaml $ENGINE_DIST_DIR cp manifest.yaml $ENGINE_DIST_DIR
# Test Distribution
- name: Test Engine Distribution (Unix)
shell: bash
if: runner.os != 'Windows'
run: |
$ENGINE_DIST_DIR/bin/enso --run test/Test
- name: Test Engine Distribution (Windows)
shell: bash
if: runner.os == 'Windows'
run: |
$ENGINE_DIST_DIR/bin/enso.bat --run test/Test
# Publish # Publish
- name: Publish the Engine Distribution Artifact - name: Publish the Engine Distribution Artifact
uses: actions/upload-artifact@v1.0.0 uses: actions/upload-artifact@v1.0.0

View File

@ -10,9 +10,15 @@ spec = describe "Process" <|
Exit_Success -> Test.Success Exit_Success -> Test.Success
Exit_Failure code -> Test.fail ("Process failed with code " + code) Exit_Failure code -> Test.fail ("Process failed with code " + code)
it "should return exit code" <| it "should return exit code" <|
case Process.run_command "bash" ["-c", "exit 42"] of case Platform.os of
Exit_Success -> Test.fail "Process exit code mismatch." Platform.Windows ->
Exit_Failure code -> code.should_equal 42 case Process.run_command "PowerShell" ["-Command", "exit 42"] of
Exit_Success -> Test.fail "Process exist code mismatch"
Exit_Failure code -> code.should_equal 42
_ ->
case Process.run_command "bash" ["-c", "exit 42"] of
Exit_Success -> Test.fail "Process exit code mismatch."
Exit_Failure code -> code.should_equal 42
it "should return stdout" <| it "should return stdout" <|
case Platform.os of case Platform.os of
Platform.Linux -> Platform.Linux ->
@ -75,7 +81,7 @@ spec = describe "Process" <|
builder = Process.Process_Builder "PowerShell" ["-Command", "[System.Console]::ReadLine()"] "sample" builder = Process.Process_Builder "PowerShell" ["-Command", "[System.Console]::ReadLine()"] "sample"
result = Process.create builder result = Process.create builder
result.exit_code.to_number . should_equal 0 result.exit_code.to_number . should_equal 0
result.stdout . should_equal "sample" result.stdout . should_equal 'sample\r\n'
result.stderr . should_equal "" result.stderr . should_equal ""
Platform.Unknown -> Platform.Unknown ->
Test.fail "Unsupported platform." Test.fail "Unsupported platform."