diff options
author | umarcor <unai.martinezcorral@ehu.eus> | 2021-06-19 11:20:12 +0200 |
---|---|---|
committer | umarcor <unai.martinezcorral@ehu.eus> | 2021-06-19 22:04:33 +0200 |
commit | 2033a3769eb75b7b8685385a8f0fe6597986d2fe (patch) | |
tree | 65df4bd54ec6fb17e31692a2a3665b7c9dc0a3c5 | |
parent | ee05ac37d1a78c899f9d48dcd45ee22e5a00f892 (diff) | |
download | ghdl-2033a3769eb75b7b8685385a8f0fe6597986d2fe.tar.gz ghdl-2033a3769eb75b7b8685385a8f0fe6597986d2fe.tar.bz2 ghdl-2033a3769eb75b7b8685385a8f0fe6597986d2fe.zip |
testsuite/pyunit/dom: replace AllVHDLSources.sh with AllSources.py
-rw-r--r-- | .github/workflows/Test.yml | 52 | ||||
-rw-r--r-- | testsuite/pyunit/dom/AllSources.py | 23 | ||||
-rwxr-xr-x | testsuite/pyunit/dom/AllVHDLSources.sh | 31 |
3 files changed, 24 insertions, 82 deletions
diff --git a/.github/workflows/Test.yml b/.github/workflows/Test.yml index e99314ba9..d36abf28b 100644 --- a/.github/workflows/Test.yml +++ b/.github/workflows/Test.yml @@ -314,62 +314,12 @@ jobs: run: GHDL=ghdl ./testsuite/testsuite.sh ${{ matrix.suite }} # -# pyGHDL DOM Test -# - - DOM-test: - needs: win-build - runs-on: windows-latest - strategy: - fail-fast: false - max-parallel: 8 - matrix: - include: [ - {icon: '🟦', installs: 'MINGW32', arch: i686, pkg: 'mcode' }, - #{icon: '🟦', installs: "MINGW32", arch: i686, pkg: "llvm" }, ! Not yet functional - #{icon: '🟪', installs: "MINGW64", arch: x86_64, pkg: "mcode" }, ! mcode is not yet supported on win64 - {icon: '🟪', installs: 'MINGW64', arch: x86_64, pkg: 'llvm' }, - ] - name: '${{ matrix.icon }} DOM · ${{ matrix.installs }} · ${{ matrix.pkg }} · ${{ matrix.suite }}' - defaults: - run: - shell: msys2 {0} - steps: - - - name: '${{ matrix.icon }} Setup MSYS2' - uses: msys2/setup-msys2@v2 - with: - msystem: ${{ matrix.installs }} - update: true - install: > - mingw-w64-${{ matrix.arch }}-python-pip - mingw-w64-${{ matrix.arch }}-python-setuptools - - - name: '⚙️ git config' - run: git config --global core.autocrlf input - shell: bash - - - name: '🧰 Checkout' - uses: actions/checkout@v2 - - - name: '📥 Download artifact: package' - uses: actions/download-artifact@v2 - - - name: '🚧 Install package and Python dependencies' - run: | - pacman --noconfirm -U artifact/mingw-w64-${{ matrix.arch }}-ghdl-${{ matrix.pkg }}-*.zst - pip3 install . - - - name: Test the DOM and pretty print all VHDL sources - run: ./testsuite/pyunit/dom/AllVHDLSources.sh - -# # Release # Release: if: github.event_name != 'pull_request' && (github.ref == 'refs/heads/master' || contains(github.ref, 'refs/tags/')) - needs: [ doc, lin, osx, win-test, DOM-test ] + needs: [ doc, lin, osx, win-test ] runs-on: ubuntu-latest name: '📦 Release' steps: diff --git a/testsuite/pyunit/dom/AllSources.py b/testsuite/pyunit/dom/AllSources.py new file mode 100644 index 000000000..645394742 --- /dev/null +++ b/testsuite/pyunit/dom/AllSources.py @@ -0,0 +1,23 @@ +from sys import executable +from subprocess import check_call, STDOUT +from pathlib import Path +from glob import glob +from pytest import mark + +if __name__ == "__main__": + print("ERROR: you called a testcase declaration file as an executable module.") + print("Use: 'python -m unitest <testcase module>'") + exit(1) + + +@mark.parametrize( + "file", + glob(str(Path(__file__).resolve().parent.parent.parent.parent / '**' / '*.vhdl'), recursive=True) +) +@mark.xfail +def test_AllVHDLSources(file): + check_call([ + executable, + str(Path(__file__).resolve().parent.parent.parent.parent / 'pyGHDL' / 'cli' / 'DOM.py'), + file + ], stderr=STDOUT) diff --git a/testsuite/pyunit/dom/AllVHDLSources.sh b/testsuite/pyunit/dom/AllVHDLSources.sh deleted file mode 100755 index 251b34163..000000000 --- a/testsuite/pyunit/dom/AllVHDLSources.sh +++ /dev/null @@ -1,31 +0,0 @@ -#!/usr/bin/env bash - -cd $(dirname "$0")/../../.. - -gstart () { - printf "\e[36m> $@\e[0m\n" -} -gend () { - printf "$@\n" -} - -if [ -n "$CI" ]; then - gstart () { - printf '::group::' - printf "$@\n" - SECONDS=0 - } - - gend () { - duration=$SECONDS - echo '::endgroup::' - printf "$@\n" - } -fi - -for item in $(find ./ -type f -name "*.vhdl"); do - gstart "$item" - ./pyGHDL/cli/DOM.py $item \ - && gend '\e[32mpass\e[0m' \ - || gend '\e[31mfail\e[0m' -done |