Skip to content

Commit

Permalink
Use concurrency in GitHub Actions + remove cancelling (#77)
Browse files Browse the repository at this point in the history
* Use concurrency + remove cancelling

* Combined ubuntu-focal-external with ubuntu-focal-external-rocm

* Update workflow names and README

* Update ubuntu-focal name

* More tweaks to the name

* Change names in formatting workflow
  • Loading branch information
jrmadsen committed Jun 29, 2022
1 parent 22bcc2e commit 9b800c0
Show file tree
Hide file tree
Showing 10 changed files with 165 additions and 169 deletions.
20 changes: 0 additions & 20 deletions .github/workflows/cancelling.yml

This file was deleted.

4 changes: 4 additions & 0 deletions .github/workflows/cpack-opensuse.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,10 @@ on:
branches: [releases/**]
tags: []

concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

env:
GIT_DISCOVERY_ACROSS_FILESYSTEM: 1

Expand Down
4 changes: 4 additions & 0 deletions .github/workflows/cpack-ubuntu.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,10 @@ on:
branches: [releases/**]
tags: []

concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

env:
GIT_DISCOVERY_ACROSS_FILESYSTEM: 1

Expand Down
12 changes: 7 additions & 5 deletions .github/workflows/formatting.yml
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
# This workflow will install Python dependencies, run tests and lint with a variety of Python versions
# For more information see: https://help.github.com/actions/language-and-framework-guides/using-python-with-github-actions

name: formatting

Expand All @@ -9,8 +7,12 @@ on:
pull_request:
branches: [ main, develop ]

concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

jobs:
python-formatting:
python:
runs-on: ubuntu-20.04
strategy:
matrix:
Expand All @@ -31,7 +33,7 @@ jobs:
run: |
black --diff --check .
cmake-format:
cmake:
runs-on: ubuntu-20.04

steps:
Expand All @@ -54,7 +56,7 @@ jobs:
exit 1
fi
clang-format:
source:
runs-on: ubuntu-20.04

steps:
Expand Down
6 changes: 5 additions & 1 deletion .github/workflows/opensuse.yml
Original file line number Diff line number Diff line change
@@ -1,11 +1,15 @@
name: opensuse
name: OpenSUSE 15.2, 15.3 (Python)

on:
push:
branches: [ main, develop ]
pull_request:
branches: [ main, develop ]

concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

env:
BUILD_TYPE: Release
OMNITRACE_VERBOSE: 1
Expand Down
6 changes: 5 additions & 1 deletion .github/workflows/ubuntu-bionic.yml
Original file line number Diff line number Diff line change
@@ -1,11 +1,15 @@
name: ubuntu-bionic
name: Ubuntu 18.04 (GCC, MPICH, Python)

on:
push:
branches: [ main, develop ]
pull_request:
branches: [ main, develop ]

concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

env:
BUILD_TYPE: Release
ELFUTILS_DOWNLOAD_VERSION: 0.183
Expand Down
136 changes: 0 additions & 136 deletions .github/workflows/ubuntu-focal-external-rocm.yml

This file was deleted.

132 changes: 131 additions & 1 deletion .github/workflows/ubuntu-focal-external.yml
Original file line number Diff line number Diff line change
@@ -1,11 +1,15 @@
name: ubuntu-focal-external
name: Ubuntu 20.04 (GCC, Python, ROCm)

on:
push:
branches: [ main, develop ]
pull_request:
branches: [ main, develop ]

concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

env:
OMNITRACE_VERBOSE: 1
OMNITRACE_CI: ON
Expand Down Expand Up @@ -163,3 +167,129 @@ jobs:
path: |
build/omnitrace-tests-output/**/*.txt
build/omnitrace-tests-output/**/*-instr*.json
ubuntu-focal-external-rocm:
runs-on: ubuntu-20.04
container:
image: jrmadsen/omnitrace-ci:ubuntu-20.04
strategy:
matrix:
compiler: ['g++']
rocm_version: ['4.3', '4.5', 'debian']

env:
BUILD_TYPE: MinSizeRel
OMNITRACE_OUTPUT_PATH: omnitrace-tests-output
OMNITRACE_OUTPUT_PREFIX: "%argt%/"

steps:
- uses: actions/checkout@v2

- name: Install Packages
timeout-minutes: 5
run:
apt-get update &&
apt-get install -y software-properties-common wget gnupg2 &&
wget -q -O - https://repo.radeon.com/rocm/rocm.gpg.key | apt-key add - &&
echo "deb [arch=amd64] https://repo.radeon.com/rocm/apt/${{ matrix.rocm_version }}/ ubuntu main" | tee /etc/apt/sources.list.d/rocm.list &&
apt-get update &&
apt-get install -y build-essential m4 autoconf libtool python3-pip clang libomp-dev ${{ matrix.compiler }} libudev-dev libnuma-dev rocm-dev rocm-utils roctracer-dev rocprofiler-dev hip-base hsa-amd-aqlprofile hsa-rocr-dev hsakmt-roct-dev libpapi-dev libopenmpi-dev curl &&
python3 -m pip install --upgrade pip &&
python3 -m pip install 'cmake==3.16.3' &&
for i in 6 7 8 9; do /opt/conda/envs/py3.${i}/bin/python -m pip install numpy perfetto dataclasses; done

- name: Configure Env
run:
echo "CC=$(echo '${{ matrix.compiler }}' | sed 's/+/c/g')" >> $GITHUB_ENV &&
echo "CXX=${{ matrix.compiler }}" >> $GITHUB_ENV &&
echo "CMAKE_PREFIX_PATH=/opt/dyninst:/opt/elfutils:${CMAKE_PREFIX_PATH}" >> $GITHUB_ENV &&
echo "/opt/omnitrace/bin:/opt/dyninst/bin:/opt/elfutils/bin:${HOME}/.local/bin" >> $GITHUB_PATH &&
echo "LD_LIBRARY_PATH=/opt/omnitrace/lib:/opt/dyninst/lib:/opt/elfutils/lib:${LD_LIBRARY_PATH}" >> $GITHUB_ENV

- name: Configure CMake
timeout-minutes: 10
run:
git config --global --add safe.directory ${PWD} &&
cmake --version &&
cmake -B build
-DCMAKE_C_COMPILER=${CC}
-DCMAKE_CXX_COMPILER=${CXX}
-DCMAKE_BUILD_TYPE=${{ env.BUILD_TYPE }}
-DCMAKE_INSTALL_PREFIX=/opt/omnitrace
-DOMNITRACE_BUILD_TESTING=OFF
-DOMNITRACE_BUILD_DEVELOPER=ON
-DOMNITRACE_BUILD_EXTRA_OPTIMIZATIONS=OFF
-DOMNITRACE_BUILD_LTO=OFF
-DOMNITRACE_USE_MPI=OFF
-DOMNITRACE_USE_MPI_HEADERS=ON
-DOMNITRACE_USE_HIP=ON
-DOMNITRACE_MAX_THREADS=64
-DOMNITRACE_USE_SANITIZER=OFF
-DOMNITRACE_USE_PAPI=OFF
-DOMNITRACE_INSTALL_PERFETTO_TOOLS=ON

- name: Build
timeout-minutes: 45
run:
cmake --build build --target all --parallel 2 -- VERBOSE=1

- name: Install
run:
cmake --build build --target install --parallel 2

- name: Test
timeout-minutes: 45
run:
cd build &&
ldd ./omnitrace &&
./omnitrace --help &&
ctest -V -N -O omnitrace-ctest-${{ github.job }}-commands.log &&
ctest -V --output-log omnitrace-ctest-${{ github.job }}.log --stop-on-failure

- name: Test Install
timeout-minutes: 10
run: |
set -v
traced --background
export OMNITRACE_DEBUG=ON
export OMNITRACE_PERFETTO_BACKEND=system
which omnitrace-avail
ldd $(which omnitrace-avail)
omnitrace-avail --help
omnitrace-avail -a
which omnitrace-critical-trace
ldd $(which omnitrace-critical-trace)
which omnitrace
ldd $(which omnitrace)
omnitrace --help
omnitrace -e -v 1 -o ls.inst --simulate -- ls
omnitrace -e -v 1 --simulate -- ls
omnitrace -e -v 1 -o ls.inst -- ls
perfetto --out ls-perfetto-trace.proto --txt -c omnitrace.cfg
./ls.inst
omnitrace -e -v 1 -- ls
du -m ls-perfetto-trace.proto
- name: Test User API
timeout-minutes: 10
run: |
set -v
./scripts/test-find-package.sh --install-dir /opt/omnitrace
- name: CTest Artifacts
if: success() || failure()
uses: actions/upload-artifact@v2
with:
name: ctest-${{ github.job }}-log
path: |
build/*.log
- name: Data Artifacts
if: success() || failure()
uses: actions/upload-artifact@v2
with:
name: data-${{ github.job }}-files
path: |
omnitrace-tests-output/**/*.txt
build/omnitrace-tests-output/**/*.txt
build/omnitrace-tests-output/**/*-instr*.json
Loading

0 comments on commit 9b800c0

Please sign in to comment.