diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml new file mode 100644 index 0000000..f3bde6c --- /dev/null +++ b/.github/workflows/ci.yml @@ -0,0 +1,186 @@ +name: nim-json-serialization CI +on: [push, pull_request] + +jobs: + build: + strategy: + fail-fast: false + max-parallel: 20 + matrix: + branch: [master] + target: + - os: linux + cpu: amd64 + TEST_LANG: c + - os: linux + cpu: amd64 + TEST_LANG: cpp + - os: linux + cpu: i386 + TEST_LANG: c + - os: linux + cpu: i386 + TEST_LANG: cpp + - os: macos + cpu: amd64 + TEST_LANG: c + - os: macos + cpu: amd64 + TEST_LANG: cpp + - os: windows + cpu: amd64 + TEST_LANG: c + - os: windows + cpu: amd64 + TEST_LANG: cpp + - os: windows + cpu: i386 + TEST_LANG: c + - os: windows + cpu: i386 + TEST_LANG: cpp + include: + - target: + os: linux + builder: ubuntu-18.04 + - target: + os: macos + builder: macos-10.15 + - target: + os: windows + builder: windows-2019 + + name: '${{ matrix.target.os }}-${{ matrix.target.cpu }}-${{ matrix.target.TEST_LANG }} (${{ matrix.branch }})' + runs-on: ${{ matrix.builder }} + steps: + - name: Checkout nim-json-serialization + uses: actions/checkout@v2 + with: + path: nim-json-serialization + 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: Restore MinGW-W64 (Windows) from cache + if: runner.os == 'Windows' + id: windows-mingw-cache + uses: actions/cache@v2 + with: + path: external/mingw-${{ matrix.target.cpu }} + key: 'mingw-${{ matrix.target.cpu }}' + + - 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 MinGW64 dependency (Windows) + if: > + steps.windows-mingw-cache.outputs.cache-hit != 'true' && + runner.os == 'Windows' + shell: bash + run: | + mkdir -p external + if [[ '${{ matrix.target.cpu }}' == 'amd64' ]]; then + MINGW_URL="https://sourceforge.net/projects/mingw-w64/files/Toolchains targetting Win64/Personal Builds/mingw-builds/8.1.0/threads-posix/seh/x86_64-8.1.0-release-posix-seh-rt_v6-rev0.7z" + ARCH=64 + else + MINGW_URL="https://sourceforge.net/projects/mingw-w64/files/Toolchains targetting Win32/Personal Builds/mingw-builds/8.1.0/threads-posix/dwarf/i686-8.1.0-release-posix-dwarf-rt_v6-rev0.7z" + ARCH=32 + fi + curl -L "$MINGW_URL" -o "external/mingw-${{ matrix.target.cpu }}.7z" + 7z x -y "external/mingw-${{ matrix.target.cpu }}.7z" -oexternal/ + mv external/mingw$ARCH external/mingw-${{ matrix.target.cpu }} + + - name: Install DLLs dependencies (Windows) + if: > + steps.windows-dlls-cache.outputs.cache-hit != 'true' && + runner.os == 'Windows' + shell: bash + 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' + shell: bash + run: | + echo '${{ github.workspace }}'"/external/mingw-${{ matrix.target.cpu }}/bin" >> $GITHUB_PATH + echo '${{ github.workspace }}'"/external/dlls-${{ matrix.target.cpu }}" >> $GITHUB_PATH + + - name: Get latest nimbus-build-system commit hash + id: versions + shell: bash + run: | + getHash() { + git ls-remote "https://github.com/$1" "${2:-HEAD}" | cut -f 1 + } + nbsHash=$(getHash status-im/nimbus-build-system) + echo "::set-output name=nimbus_build_system::$nbsHash" + + - name: Restore prebuilt Nim from cache + id: nim-cache + uses: actions/cache@v2 + with: + path: nim + key: 'nim-${{ matrix.target.os }}-${{ matrix.target.cpu }}-${{ steps.versions.outputs.nimbus_build_system }}' + + - name: Build Nim and associated tools + if: steps.nim-cache.outputs.cache-hit != 'true' + shell: bash + run: | + curl -O -L -s -S https://raw.githubusercontent.com/status-im/nimbus-build-system/master/scripts/build_nim.sh + if [[ '${{ matrix.target.cpu }}' == 'amd64' ]]; then + PLATFORM=x64 + else + PLATFORM=x86 + fi + if [[ '${{ matrix.target.os }}' == 'windows' ]]; then + MAKE_CMD="mingw32-make" + else + MAKE_CMD="make" + fi + env MAKE="$MAKE_CMD -j2" ARCH_OVERRIDE=$PLATFORM CC=gcc bash build_nim.sh nim csources dist/nimble NimBinaries + + # clean up to save cache space + cd nim + rm koch + rm -rf nimcache + rm -rf csources + rm -rf tests + rm -rf dist + rm -rf .git + + - name: Setup environment + shell: bash + run: echo '${{ github.workspace }}/nim/bin' >> $GITHUB_PATH + + - name: Run nim-json-serialization tests + shell: bash + working-directory: nim-json-serialization + run: | + nimble install -y --depsOnly + env TEST_LANG="${{ matrix.target.TEST_LANG }}" nimble test diff --git a/.gitignore b/.gitignore index 4f3532c..ff45144 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1,2 @@ nimcache - +*.exe diff --git a/README.md b/README.md index b174b6b..46a93eb 100644 --- a/README.md +++ b/README.md @@ -5,6 +5,7 @@ [![License: Apache](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0) [![License: MIT](https://img.shields.io/badge/License-MIT-blue.svg)](https://opensource.org/licenses/MIT) ![Stability: experimental](https://img.shields.io/badge/stability-experimental-orange.svg) +![Github action](https://github.com/status-im/nim-json-serialization/workflows/nim-json-serialization%20CI/badge.svg) Flexible JSON serialization not relying on run-time type information. diff --git a/json_serialization.nimble b/json_serialization.nimble index 0897163..eae7c9c 100644 --- a/json_serialization.nimble +++ b/json_serialization.nimble @@ -11,7 +11,17 @@ requires "nim >= 0.17.0", "serialization", "stew" -task test, "Run all tests": - exec "nim c -r --threads:off tests/test_all" - exec "nim c -r --threads:on tests/test_all" +proc test(env, path: string) = + # Compilation language is controlled by TEST_LANG + var lang = "c" + if existsEnv"TEST_LANG": + lang = getEnv"TEST_LANG" + if not dirExists "build": + mkDir "build" + exec "nim " & lang & " " & env & + " -r --hints:off --warnings:off " & path + +task test, "Run all tests": + test "--threads:off", "tests/test_all" + test "--threads:on", "tests/test_all" diff --git a/tests/cases/comments.json b/tests/cases/comments.json new file mode 100644 index 0000000..ea14d2f --- /dev/null +++ b/tests/cases/comments.json @@ -0,0 +1,8 @@ +/* comments */ +{ + "tasks": [ + { + "label": "nim-beacon-chain build" + } + ] +} diff --git a/tests/test_serialization.nim b/tests/test_serialization.nim index e267782..55fe0a7 100644 --- a/tests/test_serialization.nim +++ b/tests/test_serialization.nim @@ -269,5 +269,4 @@ suite "toJson tests": check decoded["tasks"][0]["label"] == newJString("nim-beacon-chain build") except SerializationError as err: checkpoint err.formatMsg("./cases/comments.json") - fail - + check false