mirror of
https://github.com/enso-org/enso.git
synced 2025-01-03 19:21:54 +03:00
Run Stdlib tests on CI (#1196)
This commit is contained in:
parent
2a6dbf0eda
commit
42dcc1a003
15
.github/settings.yml
vendored
15
.github/settings.yml
vendored
@ -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"
|
||||||
|
145
.github/workflows/scala.yml
vendored
145
.github/workflows/scala.yml
vendored
@ -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
|
||||||
|
@ -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."
|
||||||
|
Loading…
Reference in New Issue
Block a user