projects
/
tinc
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Replace getrandom() with getentropy()
[tinc]
/
.github
/
workflows
/
test.yml
diff --git
a/.github/workflows/test.yml
b/.github/workflows/test.yml
index
27f364b
..
ec70fa5
100644
(file)
--- a/
.github/workflows/test.yml
+++ b/
.github/workflows/test.yml
@@
-42,6
+42,7
@@
jobs:
- name: Run tests with libgcrypt
run: sudo -u build CI=1 HOST=${{ matrix.arch }} sh .ci/test/run.sh gcrypt
- name: Run tests with libgcrypt
run: sudo -u build CI=1 HOST=${{ matrix.arch }} sh .ci/test/run.sh gcrypt
+ if: always()
- name: Upload test results
uses: actions/upload-artifact@v2
- name: Upload test results
uses: actions/upload-artifact@v2
@@
-65,33
+66,25
@@
jobs:
tar -C ~ --strip-components=1 --wildcards -xf ./shellcheck-*.tar.xz 'shellcheck-*/shellcheck'
curl -o ~/shfmt -L "https://github.com/mvdan/sh/releases/download/v$SHFMT/shfmt_v${SHFMT}_linux_amd64"
chmod 755 ~/shfmt ~/shellcheck
tar -C ~ --strip-components=1 --wildcards -xf ./shellcheck-*.tar.xz 'shellcheck-*/shellcheck'
curl -o ~/shfmt -L "https://github.com/mvdan/sh/releases/download/v$SHFMT/shfmt_v${SHFMT}_linux_amd64"
chmod 755 ~/shfmt ~/shellcheck
- pip3 install --user compiledb
+ python3 -m venv /tmp/venv
+ . /tmp/venv/bin/activate
+ pip3 install black pylint mypy
env:
CLANG: 11
SHELLCHECK: 0.7.2
SHFMT: 3.3.0
- name: Install deps
env:
CLANG: 11
SHELLCHECK: 0.7.2
SHFMT: 3.3.0
- name: Install deps
- run: sudo sh .ci/deps.sh
-
- - name: Run clang-tidy
- run: sh .ci/tidy/run.sh
- if: always()
-
- - name: Check code formatting
- run: "! astyle --exclude=build -r --options=.astylerc --dry-run --formatted '*.c' '*.h' | grep '^Formatted'"
- if: always()
-
- - name: Check scripts formatting
- run: find -type f -regextype egrep -regex '.+\.(sh|sh\.in|test)$' -exec ~/shfmt -d -i 2 -s '{}' +
- if: always()
+ run: sudo SKIP_OPENSSL3=1 sh .ci/deps.sh
- - name: Run static analysis on scripts
- run: find -type f -regextype egrep -regex '.+\.sh(\.in)?$' -exec shellcheck -x '{}' +
+ - name: Lint/typecheck/check formatting on C/shell/Python code
+ run: |
+ . /tmp/venv/bin/activate
+ PATH=$PATH:$HOME ./lint.py
if: always()
if: always()
- - name: Run
static analysis on tests
- run:
find -type f -name '*.test' -execdir shellcheck -x '{}' +
+ - name: Run
clang-tidy
+ run:
sh .ci/tidy/run.sh
if: always()
- name: Check warnings (gcc)
if: always()
- name: Check warnings (gcc)
@@
-128,14
+121,20
@@
jobs:
- name: Run tests with OpenSSL 3
run: bash .ci/sanitizers/run.sh openssl3
- name: Run tests with OpenSSL 3
run: bash .ci/sanitizers/run.sh openssl3
+ if: always()
- name: Sanitize tests with default settings
run: bash .ci/sanitizers/run.sh default
- name: Sanitize tests with default settings
run: bash .ci/sanitizers/run.sh default
+ if: always()
- name: Sanitize tests without legacy protocol
run: bash .ci/sanitizers/run.sh nolegacy
if: always()
- name: Sanitize tests without legacy protocol
run: bash .ci/sanitizers/run.sh nolegacy
if: always()
+ - name: Run tests with libgcrypt
+ run: bash .ci/sanitizers/run.sh gcrypt
+ if: always()
+
- name: Upload test results
uses: actions/upload-artifact@v2
with:
- name: Upload test results
uses: actions/upload-artifact@v2
with:
@@
-182,6
+181,7
@@
jobs:
- name: Run tests with default settings
run: sudo -u build CI=1 sh .ci/test/run.sh default
- name: Run tests with default settings
run: sudo -u build CI=1 sh .ci/test/run.sh default
+ if: always()
- name: Run tests without legacy protocol
run: sudo -u build CI=1 sh .ci/test/run.sh nolegacy
- name: Run tests without legacy protocol
run: sudo -u build CI=1 sh .ci/test/run.sh nolegacy
@@
-189,6
+189,7
@@
jobs:
- name: Run tests with libgcrypt
run: sudo -u build CI=1 sh .ci/test/run.sh gcrypt
- name: Run tests with libgcrypt
run: sudo -u build CI=1 sh .ci/test/run.sh gcrypt
+ if: always()
- name: Upload test results
uses: actions/upload-artifact@v2
- name: Upload test results
uses: actions/upload-artifact@v2
@@
-200,6
+201,7
@@
jobs:
- name: Build package
run: sh .ci/package/build.sh
if: github.ref == 'refs/heads/1.1' || startsWith(github.ref, 'refs/tags/release-')
- name: Build package
run: sh .ci/package/build.sh
if: github.ref == 'refs/heads/1.1' || startsWith(github.ref, 'refs/tags/release-')
+ continue-on-error: true
- name: Upload package
uses: actions/upload-artifact@v2
- name: Upload package
uses: actions/upload-artifact@v2
@@
-208,10
+210,12
@@
jobs:
path: |
*.deb
~/rpmbuild/RPMS/*/*.rpm
path: |
*.deb
~/rpmbuild/RPMS/*/*.rpm
+ continue-on-error: true
pkg-publish:
if: always() && (github.ref == 'refs/heads/1.1' || startsWith(github.ref, 'refs/tags/release-'))
runs-on: ubuntu-latest
pkg-publish:
if: always() && (github.ref == 'refs/heads/1.1' || startsWith(github.ref, 'refs/tags/release-'))
runs-on: ubuntu-latest
+ continue-on-error: true
needs:
- linux
- mingw
needs:
- linux
- mingw
@@
-264,6
+268,7
@@
jobs:
- name: Run tests with libgcrypt
run: sh .ci/test/run.sh gcrypt
- name: Run tests with libgcrypt
run: sh .ci/test/run.sh gcrypt
+ if: always()
- name: Upload test results
uses: actions/upload-artifact@v2
- name: Upload test results
uses: actions/upload-artifact@v2
@@
-310,12
+315,14
@@
jobs:
shell: msys2 {0}
run: sh .ci/package/build.sh
if: github.ref == 'refs/heads/1.1' || startsWith(github.ref, 'refs/tags/release-')
shell: msys2 {0}
run: sh .ci/package/build.sh
if: github.ref == 'refs/heads/1.1' || startsWith(github.ref, 'refs/tags/release-')
+ continue-on-error: true
- name: Upload package
uses: actions/upload-artifact@v2
with:
name: pkg-windows
path: .ci/package/win/tinc-*.exe
- name: Upload package
uses: actions/upload-artifact@v2
with:
name: pkg-windows
path: .ci/package/win/tinc-*.exe
+ continue-on-error: true
- name: Run tests without legacy protocol
shell: msys2 {0}
- name: Run tests without legacy protocol
shell: msys2 {0}
@@
-325,6
+332,7
@@
jobs:
- name: Run tests with libgcrypt
shell: msys2 {0}
run: sh .ci/test/run.sh gcrypt
- name: Run tests with libgcrypt
shell: msys2 {0}
run: sh .ci/test/run.sh gcrypt
+ if: always()
- name: Upload test results
uses: actions/upload-artifact@v2
- name: Upload test results
uses: actions/upload-artifact@v2
@@
-340,9
+348,14
@@
jobs:
strategy:
fail-fast: false
matrix:
strategy:
fail-fast: false
matrix:
- arch:
- - amd64
- - amd64_x86
+ target:
+ - { build: amd64, host: amd64, test: test }
+ - { build: amd64, host: x86, test: test }
+ - { build: amd64, host: arm64, test: notest }
+
+ env:
+ HOST_ARCH: ${{ matrix.target.host }}
+ BUILD_ARCH: ${{ matrix.target.build }}
steps:
- name: Install meson
steps:
- name: Install meson
@@
-354,14
+367,14
@@
jobs:
- name: Activate dev environment
uses: ilammy/msvc-dev-cmd@v1
with:
- name: Activate dev environment
uses: ilammy/msvc-dev-cmd@v1
with:
- arch: ${{ matrix.
arch
}}
+ arch: ${{ matrix.
target.build == matrix.target.host && matrix.target.host || format('{0}_{1}', matrix.target.build, matrix.target.host)
}}
- name: Build (nolegacy)
run: .ci\windows\build.cmd nolegacy
- name: Test (nolegacy)
run: .ci\windows\test.cmd nolegacy
- name: Build (nolegacy)
run: .ci\windows\build.cmd nolegacy
- name: Test (nolegacy)
run: .ci\windows\test.cmd nolegacy
- if: always()
+ if: always()
&& matrix.target.test == 'test'
- name: Build (OpenSSL)
run: .ci\windows\build.cmd openssl
- name: Build (OpenSSL)
run: .ci\windows\build.cmd openssl
@@
-369,4
+382,4
@@
jobs:
- name: Test (OpenSSL)
run: .ci\windows\test.cmd openssl
- name: Test (OpenSSL)
run: .ci\windows\test.cmd openssl
- if: always()
+ if: always()
&& matrix.target.test == 'test'