diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 312ca11..0172dbc 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -11,7 +11,6 @@ jobs: strategy: fail-fast: false matrix: - test_lang: [c, cpp] target: - os: linux cpu: amd64 @@ -23,7 +22,7 @@ jobs: cpu: amd64 #- os: windows #cpu: i386 - branch: [version-1-2, version-1-4] + branch: [version-1-2, version-1-4, version-1-6, devel] include: - target: os: linux @@ -42,14 +41,12 @@ jobs: run: shell: ${{ matrix.shell }} - name: '${{ matrix.target.os }}-${{ matrix.target.cpu }}-${{ matrix.test_lang }} (Nim ${{ matrix.branch }})' + name: '${{ matrix.target.os }}-${{ matrix.target.cpu }} (Nim ${{ matrix.branch }})' runs-on: ${{ matrix.builder }} continue-on-error: ${{ matrix.branch == 'version-1-6' || matrix.branch == 'devel' }} steps: - - name: Checkout nim-stew + - name: Checkout uses: actions/checkout@v2 - with: - submodules: false - name: Install build dependencies (Linux i386) if: runner.os == 'Linux' && matrix.target.cpu == 'i386' @@ -150,9 +147,16 @@ jobs: bash build_nim.sh nim csources dist/nimble NimBinaries echo '${{ github.workspace }}/nim/bin' >> $GITHUB_PATH - - name: Run nim-stew tests + - name: Run tests run: | - env TEST_LANG="${{ matrix.test_lang }}" nimble test + if [[ "${{ matrix.target.os }}" == "windows" ]]; then + # https://github.com/status-im/nimbus-eth2/issues/3121 + export NIMFLAGS="-d:nimRawSetjmp" + fi + nim --version + nimble --version + env TEST_LANG=c nimble test + env TEST_LANG=cpp nimble test - name: Setup VCC (Windows-i386) if: runner.os == 'Windows' && matrix.target.cpu == 'i386' @@ -169,4 +173,5 @@ jobs: - name: Test using VCC if: runner.os == 'Windows' run: | - env TEST_LANG="${{ matrix.test_lang }}" nimble testvcc + env TEST_LANG=c nimble testvcc + env TEST_LANG=cpp nimble testvcc diff --git a/.github/workflows/daily.yml b/.github/workflows/daily.yml deleted file mode 100644 index e6bd2ed..0000000 --- a/.github/workflows/daily.yml +++ /dev/null @@ -1,171 +0,0 @@ -name: Daily -on: - schedule: - - cron: "30 7 * * *" - workflow_dispatch: - -jobs: - build: - strategy: - fail-fast: false - matrix: - test_lang: [c, cpp] - target: - - os: linux - cpu: amd64 - - os: linux - cpu: i386 - - os: macos - cpu: amd64 - - os: windows - cpu: amd64 - #- os: windows - #cpu: i386 - branch: [version-1-2, version-1-4, version-1-6, devel] - include: - - target: - os: linux - builder: ubuntu-18.04 - shell: bash - - target: - os: macos - builder: macos-10.15 - shell: bash - - target: - os: windows - builder: windows-2019 - shell: msys2 {0} - - defaults: - run: - shell: ${{ matrix.shell }} - - name: '${{ matrix.target.os }}-${{ matrix.target.cpu }}-${{ matrix.test_lang }} (Nim ${{ matrix.branch }})' - runs-on: ${{ matrix.builder }} - continue-on-error: ${{ matrix.branch == 'version-1-6' || matrix.branch == 'devel' }} - steps: - - name: Checkout nim-stew - uses: actions/checkout@v2 - with: - ref: master - submodules: false - - - name: Install build dependencies (Linux i386) - if: runner.os == 'Linux' && matrix.target.cpu == 'i386' - run: | - sudo dpkg --add-architecture i386 - sudo apt-fast update -qq - sudo DEBIAN_FRONTEND='noninteractive' apt-fast install \ - --no-install-recommends -yq gcc-multilib g++-multilib \ - libssl-dev:i386 - mkdir -p external/bin - cat << EOF > external/bin/gcc - #!/bin/bash - exec $(which gcc) -m32 "\$@" - EOF - cat << EOF > external/bin/g++ - #!/bin/bash - exec $(which g++) -m32 "\$@" - EOF - chmod 755 external/bin/gcc external/bin/g++ - echo '${{ github.workspace }}/external/bin' >> $GITHUB_PATH - - - name: MSYS2 (Windows i386) - if: runner.os == 'Windows' && matrix.target.cpu == 'i386' - uses: msys2/setup-msys2@v2 - with: - path-type: inherit - msystem: MINGW32 - install: >- - base-devel - git - mingw-w64-i686-toolchain - - - name: MSYS2 (Windows amd64) - if: runner.os == 'Windows' && matrix.target.cpu == 'amd64' - uses: msys2/setup-msys2@v2 - with: - path-type: inherit - install: >- - base-devel - git - mingw-w64-x86_64-toolchain - - - name: Restore Nim DLLs dependencies (Windows) from cache - if: runner.os == 'Windows' - id: windows-dlls-cache - uses: actions/cache@v2 - with: - path: external/dlls-${{ matrix.target.cpu }} - key: 'dlls-${{ matrix.target.cpu }}' - - - name: Install DLLs dependencies (Windows) - if: > - steps.windows-dlls-cache.outputs.cache-hit != 'true' && - runner.os == 'Windows' - run: | - mkdir -p external - curl -L "https://nim-lang.org/download/windeps.zip" -o external/windeps.zip - 7z x -y external/windeps.zip -oexternal/dlls-${{ matrix.target.cpu }} - - - name: Path to cached dependencies (Windows) - if: > - runner.os == 'Windows' - run: | - echo "${{ github.workspace }}/external/dlls-${{ matrix.target.cpu }}" >> $GITHUB_PATH - - - name: Derive environment variables - run: | - if [[ '${{ matrix.target.cpu }}' == 'amd64' ]]; then - PLATFORM=x64 - else - PLATFORM=x86 - fi - echo "PLATFORM=$PLATFORM" >> $GITHUB_ENV - - ncpu= - MAKE_CMD="make" - case '${{ runner.os }}' in - 'Linux') - ncpu=$(nproc) - ;; - 'macOS') - ncpu=$(sysctl -n hw.ncpu) - ;; - 'Windows') - ncpu=$NUMBER_OF_PROCESSORS - MAKE_CMD="mingw32-make" - ;; - esac - [[ -z "$ncpu" || $ncpu -le 0 ]] && ncpu=1 - echo "ncpu=$ncpu" >> $GITHUB_ENV - echo "MAKE_CMD=${MAKE_CMD}" >> $GITHUB_ENV - - - name: Build Nim and Nimble - run: | - curl -O -L -s -S https://raw.githubusercontent.com/status-im/nimbus-build-system/master/scripts/build_nim.sh - env MAKE="${MAKE_CMD} -j${ncpu}" ARCH_OVERRIDE=${PLATFORM} NIM_COMMIT=${{ matrix.branch }} \ - QUICK_AND_DIRTY_COMPILER=1 QUICK_AND_DIRTY_NIMBLE=1 CC=gcc \ - bash build_nim.sh nim csources dist/nimble NimBinaries - echo '${{ github.workspace }}/nim/bin' >> $GITHUB_PATH - - - name: Run nim-stew tests - run: | - env TEST_LANG="${{ matrix.test_lang }}" nimble test - - - name: Setup VCC (Windows-i386) - if: runner.os == 'Windows' && matrix.target.cpu == 'i386' - uses: ilammy/msvc-dev-cmd@v1.5.0 - with: - arch: amd64_x86 - - - name: Setup VCC (Windows-amd64) - if: runner.os == 'Windows' && matrix.target.cpu == 'amd64' - uses: ilammy/msvc-dev-cmd@v1.5.0 - with: - arch: x64 - - - name: Test using VCC - if: runner.os == 'Windows' - run: | - env TEST_LANG="${{ matrix.test_lang }}" nimble testvcc diff --git a/stew.nimble b/stew.nimble index b18f801..d2fdbe2 100644 --- a/stew.nimble +++ b/stew.nimble @@ -10,13 +10,9 @@ skipDirs = @["tests"] requires "nim >= 1.2.0" ### Helper functions -proc test(env, path: string) = +proc test(args, path: string) = # Compilation language is controlled by TEST_LANG - var lang = "c" - if existsEnv"TEST_LANG": - lang = getEnv"TEST_LANG" - - exec "nim " & lang & " " & env & + exec "nim " & getEnv("TEST_LANG", "c") & " " & getEnv("NIMFLAGS") & " " & args & " -r --hints:off --skipParentCfg --styleCheck:usages --styleCheck:error " & path task test, "Run all tests":