Merge pull request #35 from usdot-jpo-ode/release_q3 #22
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: jpo-cvdp | |
on: | |
push: | |
jobs: | |
jpo-cvdp: | |
runs-on: ubuntu-latest | |
container: | |
image: ubuntu:jammy-20230126 | |
env: | |
REDACTION_PROPERTIES_PATH: "/__w/jpo-cvdp/jpo-cvdp/config/fieldsToRedact.txt" # This env vairable is used to run ppm test | |
BUILD_WRAPPER_OUT_DIR: "$GITHUB_WORKSPACE/bw-output" # This env variable is needed to run SonarSource/sonarcloud-github-c-cpp@v1 | |
options: "--user root" | |
steps: | |
- name: checkout code | |
uses: actions/checkout@v2 # This action to checkout the code | |
- name: Install Deps | |
run: | | |
apt update | |
apt-get -y install sudo wget curl gnupg lsb-release gcovr unzip | |
sudo apt-get -y install software-properties-common | |
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add - | |
sudo add-apt-repository -y "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | |
sudo curl -L "https://github.com/docker/compose/releases/download/1.24.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose | |
chmod +x /usr/local/bin/docker-compose | |
sudo apt-get -y update | |
sudo apt-get -y install docker-ce | |
- name: set up Cmake | |
uses: jwlawson/actions-setup-cmake@v1.13 # this action is used to setup and install Cmake with required versions | |
with: | |
cmake-version: '3.16' | |
- name: install g++ | |
run: | | |
sudo apt-get -y install build-essential | |
sudo apt -y install cmake g++ libprotobuf-dev protobuf-compiler | |
sudo apt -y install apt-transport-https ca-certificates curl software-properties-common | |
export CXX="g++" | |
- name: install librdkafka # This is to install librdkafka package | |
run: | | |
git clone --depth 1 https://github.com/confluentinc/librdkafka.git librdkafka | |
cd librdkafka | |
cmake -H. -B_cmake_build | |
cmake --build _cmake_build | |
cmake --build _cmake_build --target install | |
- name: Install sonar-scanner and build-wrapper | |
uses: SonarSource/sonarcloud-github-c-cpp@v1 # This Action Installs sonar cloud and build wrapper to run sonar scan analysis | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v2 | |
- name: Build | |
uses: docker/build-push-action@v3 | |
- name: Build and Generate test coverage | |
run: | | |
cd $GITHUB_WORKSPACE | |
chmod 755 -R /__w/jpo-cvdp/jpo-cvdp | |
cat /usr/include/asm-generic/signal.h | |
cat /usr/include/x86_64-linux-gnu/asm/signal.h | |
export LD_LIBRARY_PATH=/usr/local/lib | |
build-wrapper-linux-x86-64 --out-dir $GITHUB_WORKSPACE/bw-output ./build.sh | |
mkdir coverage | |
cd coverage | |
gcov $GITHUB_WORKSPACE/cv-lib/src/*.cpp --object-directory /__w/jpo-cvdp/jpo-cvdp/build/cv-lib/CMakeFiles/CVLib.dir/src/ | |
gcov $GITHUB_WORKSPACE/src/*.cpp --object-directory /__w/jpo-cvdp/jpo-cvdp/build/CMakeFiles/ppm_tests.dir/src/ | |
- name: Archive code coverage results | |
uses: actions/upload-artifact@v3 # This action is used to capture the test artifacts and exits if no files are found | |
with: | |
name: jpo-cvdp | |
path: /__w/jpo-cvdp/jpo-cvdp/coverage/ | |
if-no-files-found: error | |
- name: Archive buildwrapper output | |
uses: actions/upload-artifact@v3 # This action is used to capture the builwrapper output files used by sonarscan. | |
with: | |
name: jpo-cvdp | |
path: /home/runner/work/jpo-cvdp/jpo-cvdp/bw-output | |
- name: Setup SonarScanner | |
uses: warchant/setup-sonar-scanner@v4 # This action is used to setup sonar scanner with required versions. | |
with: | |
version: 4.8.0.2856 | |
- name: Generate sonar properties file | |
run: | | |
cat <<EOF > /tmp/sonar-scanner.properties | |
sonar.host.url=https://sonarcloud.io | |
sonar.projectName=jpo-cvdp | |
sonar.projectVersion=1.0 | |
sonar.projectKey=usdot-jpo-ode_jpo-cvdp | |
sonar.organization=usdot-jpo-ode | |
sonar.sources=. | |
sonar.exclusions=src/ppm.cpp | |
sonar.cfamily.build-wrapper-output=bw-output | |
sonar.cfamily.gcov.reportsPath=/__w/jpo-cvdp/jpo-cvdp/coverage/ | |
sonar.sonar.projectBaseDir=/home/runner/work/jpo-cvdp/jpo-cvdp/ | |
sonar.exclusions=**/*.java | |
sonar.coverage.exclusions=**/*.java | |
# Set Git as SCM sensor | |
sonar.scm.disabled=true | |
#sonar.scm.enabled=false | |
sonar.scm.provider=git | |
sonar.sourceEncoding=UTF-8 | |
EOF | |
- name: Run SonarScanner | |
uses: usdot-fhwa-stol/actions/sonar-scanner@main # This action runs the analysis using generated sonar gcov files and publish reports to respective sonarcloud project. | |
with: | |
sonar-properties-path: /tmp/sonar-scanner.properties | |
sonar-token: ${{ secrets.SONAR_TOKEN }} | |
working-dir: $GITHUB_WORKSPACE |