diff options
author | Edward Thomson <ethomson@edwardthomson.com> | 2019-01-28 12:41:22 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-01-28 12:41:22 +0000 |
commit | cf14215deda8fa8ec0da7567e15f0acb8035d162 (patch) | |
tree | 86856dd8d6d160db5b00d394f781c28f967b6a05 | |
parent | e9a34864784db3eeb6613ca80f33bed3371d65d5 (diff) | |
parent | 52a97eed430bdf1d6383afb2ebfd09b1a5b96e9e (diff) | |
download | libgit2-cf14215deda8fa8ec0da7567e15f0acb8035d162.tar.gz |
Merge pull request #4964 from libgit2/ethomson/ci_nightly
ci: add an individual coverity pipeline
-rw-r--r-- | README.md | 2 | ||||
-rw-r--r-- | azure-pipelines/coverity.yml | 36 | ||||
-rw-r--r-- | azure-pipelines/nightly.yml | 19 | ||||
-rwxr-xr-x | ci/coverity-build.sh (renamed from ci/coverity.sh) | 24 | ||||
-rwxr-xr-x | ci/coverity-publish.sh | 33 |
5 files changed, 70 insertions, 44 deletions
@@ -6,7 +6,7 @@ libgit2 - the Git linkable library | **master** branch CI builds | [![Azure Pipelines Build Status](https://dev.azure.com/libgit2/libgit2/_apis/build/status/libgit2?branchName=master)](https://dev.azure.com/libgit2/libgit2/_build/latest?definitionId=7&branchName=master) | | **v0.27 branch** CI builds | [![Azure Pipelines Build Status](https://dev.azure.com/libgit2/libgit2/_apis/build/status/libgit2?branchName=maint/v0.27)](https://dev.azure.com/libgit2/libgit2/_build/latest?definitionId=7&branchName=maint/v0.27) | | **v0.26 branch** CI builds | [![Azure Pipelines Build Status](https://dev.azure.com/libgit2/libgit2/_apis/build/status/libgit2?branchName=maint/v0.26)](https://dev.azure.com/libgit2/libgit2/_build/latest?definitionId=7&branchName=maint/v0.26) | -| **Nightly** builds | [![Azure Pipelines Build Status](https://libgit2.visualstudio.com/libgit2/_apis/build/status/libgit2-nightly?branchName=master)](https://libgit2.visualstudio.com/libgit2/_build/latest?definitionId=9&branchName=master) [![Coverity Scan Build Status](https://scan.coverity.com/projects/639/badge.svg)](https://scan.coverity.com/projects/639) | +| **Nightly** builds | [![Azure Pipelines Build Status](https://libgit2.visualstudio.com/libgit2/_apis/build/status/libgit2?branchName=master&label=Full+Build)](https://libgit2.visualstudio.com/libgit2/_build/latest?definitionId=9&branchName=master) [![Build Status](https://dev.azure.com/libgit2/libgit2/_apis/build/status/coverity?branchName=master&label=Coverity+Build)](https://dev.azure.com/libgit2/libgit2/_build/latest?definitionId=21?branchName=master) [![Coverity Scan Build Status](https://scan.coverity.com/projects/639/badge.svg)](https://scan.coverity.com/projects/639) | `libgit2` is a portable, pure C implementation of the Git core methods provided as a linkable library with a solid API, allowing to build Git diff --git a/azure-pipelines/coverity.yml b/azure-pipelines/coverity.yml new file mode 100644 index 000000000..d8d34229e --- /dev/null +++ b/azure-pipelines/coverity.yml @@ -0,0 +1,36 @@ +resources: +- repo: self + +jobs: +- job: coverity + displayName: 'Coverity' + pool: + vmImage: 'Ubuntu 16.04' + steps: + - task: Docker@0 + displayName: Build + inputs: + action: 'Run an image' + imageName: 'libgit2/trusty-openssl:latest' + volumes: | + $(Build.SourcesDirectory):/src + $(Build.BinariesDirectory):/build + envVars: | + COVERITY_TOKEN=$(COVERITY_TOKEN) + workDir: '/build' + containerCommand: '/src/ci/coverity-build.sh' + detached: false + - task: Docker@0 + displayName: Publish + inputs: + action: 'Run an image' + imageName: 'libgit2/trusty-openssl:latest' + volumes: | + $(Build.SourcesDirectory):/src + $(Build.BinariesDirectory):/build + envVars: | + COVERITY_TOKEN=$(COVERITY_TOKEN) + workDir: '/build' + containerCommand: '/src/ci/coverity-publish.sh' + detached: false + continueOnError: true diff --git a/azure-pipelines/nightly.yml b/azure-pipelines/nightly.yml index de7da9677..1d34a14df 100644 --- a/azure-pipelines/nightly.yml +++ b/azure-pipelines/nightly.yml @@ -186,22 +186,3 @@ jobs: CMAKE_OPTIONS=-DUSE_HTTPS=OpenSSL RUN_INVASIVE_TESTS=true SKIP_PROXY_TESTS=true - -- job: coverity - displayName: 'Coverity' - pool: - vmImage: 'Ubuntu 16.04' - steps: - - task: Docker@0 - displayName: Build - inputs: - action: 'Run an image' - imageName: 'libgit2/trusty-openssl:latest' - volumes: | - $(Build.SourcesDirectory):/src - $(Build.BinariesDirectory):/build - envVars: | - COVERITY_TOKEN=$(COVERITY_TOKEN) - workDir: '/build' - containerCommand: '/src/ci/coverity.sh' - detached: false diff --git a/ci/coverity.sh b/ci/coverity-build.sh index a97fae8c8..f8264fa83 100755 --- a/ci/coverity.sh +++ b/ci/coverity-build.sh @@ -39,27 +39,3 @@ COVERITY_UNSUPPORTED=1 \ $COV_BUILD --dir cov-int \ cmake --build . -# Upload results -tar czf libgit2.tgz cov-int -SHA=$(cd ${SOURCE_DIR} && git rev-parse --short HEAD) - -HTML="$(curl \ - --silent \ - --write-out "\n%{http_code}" \ - --form token="$COVERITY_TOKEN" \ - --form email=libgit2@gmail.com \ - --form file=@libgit2.tgz \ - --form version="$SHA" \ - --form description="libgit2 build" \ - https://scan.coverity.com/builds?project=libgit2)" -# Body is everything up to the last line -BODY="$(echo "$HTML" | head -n-1)" -# Status code is the last line -STATUS_CODE="$(echo "$HTML" | tail -n1)" - -echo "${BODY}" - -if [ "${STATUS_CODE}" != "200" -a "${STATUS_CODE}" != "201" ]; then - echo "Received error code ${STATUS_CODE} from Coverity" - exit 1 -fi diff --git a/ci/coverity-publish.sh b/ci/coverity-publish.sh new file mode 100755 index 000000000..2341b13fb --- /dev/null +++ b/ci/coverity-publish.sh @@ -0,0 +1,33 @@ +#!/bin/bash + +set -e + +# Results check +[ ! -d "cov-int" ] && echo "Coverity directory not found" && exit 1 + +# Upload results +tar czf libgit2.tgz cov-int + +SOURCE_DIR=${SOURCE_DIR:-$( cd "$( dirname "${BASH_SOURCE[0]}" )" && dirname $( pwd ) )} +SHA=$(cd ${SOURCE_DIR} && git rev-parse --short HEAD) + +HTML="$(curl \ + --silent \ + --write-out "\n%{http_code}" \ + --form token="$COVERITY_TOKEN" \ + --form email=libgit2@gmail.com \ + --form file=@libgit2.tgz \ + --form version="$SHA" \ + --form description="libgit2 build" \ + https://scan.coverity.com/builds?project=libgit2)" + +# Body is everything up to the last line +BODY="$(echo "$HTML" | head -n-1)" + +# Status code is the last line +STATUS_CODE="$(echo "$HTML" | tail -n1)" + +if [ "${STATUS_CODE}" != "200" -a "${STATUS_CODE}" != "201" ]; then + echo "Received error code ${STATUS_CODE} from Coverity" + exit 1 +fi |