Skip to content

Commit

Permalink
[azure-pipeline] test integration
Browse files Browse the repository at this point in the history
  • Loading branch information
Raffaello committed May 12, 2020
1 parent bc01dfa commit 2555207
Show file tree
Hide file tree
Showing 11 changed files with 119 additions and 147 deletions.
1 change: 1 addition & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ include(CPack)
option(BUILD_SHARED_LIBS "build shared libs with C inteface" ON)
option(BUILD_EXAMPLES "build examples" ON)
include(CTest)
option(ENABLE_CODECOVERAGE "compile Debug with code coverage" OFF)
option(BUILD_SNAPSHOT "build snapshot test" OFF)
include(CMakeDependentOption)
CMAKE_DEPENDENT_OPTION(TEST_DUMP_SNAPSHOT "build test to dump the expected output instead of verifing it" OFF
Expand Down
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
# SDL2 VGA Terminal

[![Codacy Badge](https://api.codacy.com/project/badge/Grade/83e178fb7d9343b78be651f2797fe3f8)](https://app.codacy.com/manual/Raffaello/sdl2-vga-terminal?utm_source=github.com&utm_medium=referral&utm_content=Raffaello/sdl2-vga-terminal&utm_campaign=Badge_Grade_Settings)
[![codecov](https://codecov.io/gh/Raffaello/sdl2-vga-terminal/branch/master/graph/badge.svg)](https://codecov.io/gh/Raffaello/sdl2-vga-terminal)

| Monolithic CI | Note |
|:-------------:|-----:|
Expand Down
21 changes: 17 additions & 4 deletions appveyor.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ configuration:

environment:
VCPKG_SCRIPT: scripts/buildsystems/vcpkg.cmake
ENABLE_CODE_COVERAGE: OFF

matrix:
allow_failures:
Expand Down Expand Up @@ -46,17 +47,29 @@ for:
environment:
WS: /Users/appveyor/projects
TRIPLET: $PLATFORM-osx
ENABLE_CODE_COVERAGE: ON
cache:
#- $WS/vcpkg
- $WS/vcpkg/installed
init:
- sh: if [ $PLATFORM = "x86" ]; then exit 1; fi
- sh: brew install p7zip
- sh: brew install p7zip lcov
- sh: cd $WS && git clone https://github.com/Microsoft/vcpkg.git
- sh: cd $APPVEYOR_BUILD_FOLDER
# /Library/Developer/CommandLineTools/usr/bin/llvm-cov
#- sh: sudo find / -name llvm-cov 2> /dev/null
#- sh: llvm-cov --help
test_script:
- sh: ctest -V

#- sh: find . -name *.gcda
#- sh: echo '#!/bin/bash' > g.sh
#- sh: echo 'exec /Library/Developer/CommandLineTools/usr/bin/llvm-cov gcov "$@"' >> g.sh
#- sh: chmod +x g.sh
#- sh: ./g.sh -f -b -u $(find . -name *.gcda)
#- sh: lcov --directory . --base-directory . --gcov-tool ./g.sh --capture -o cov.info
#- sh: lcov --remove cov.info '/Applications/*' --output-file coverage.info
#- sh: lcov --list coverage.info
#- sh: bash <(curl -s https://codecov.io/bash) -f coverage.info -t b8f07100-6985-49f7-aa4c-14e36f29ac80

skip_commits:
files:
Expand Down Expand Up @@ -90,8 +103,8 @@ before_build:
build_script:
- mkdir out
- cd out
- cmd: cmake -G "Ninja" -DCMAKE_BUILD_TYPE=%CONFIGURATION% -DWITH_SDL2_STATIC=OFF -DBUILD_SNAPSHOT=OFF -DCMAKE_TOOLCHAIN_FILE=c:/tools/vcpkg/%VCPKG_SCRIPT% ..
- sh : cmake -DCMAKE_BUILD_TYPE=$CONFIGURATION -DWITH_SDL2_STATIC=ON -DBUILD_SNAPSHOT=OFF -DCMAKE_TOOLCHAIN_FILE=$WS/vcpkg/$VCPKG_SCRIPT ..
- cmd: cmake -G "Ninja" -DCMAKE_BUILD_TYPE=%CONFIGURATION% -DWITH_SDL2_STATIC=OFF -DBUILD_SNAPSHOT=OFF -DCMAKE_TOOLCHAIN_FILE=c:/tools/vcpkg/%VCPKG_SCRIPT% ..
- sh : cmake -DCMAKE_BUILD_TYPE=$CONFIGURATION -DWITH_SDL2_STATIC=ON -DBUILD_SNAPSHOT=OFF -DENABLE_CODE_COVERAGE=$ENABLE_CODE_COVERAGE -DCMAKE_TOOLCHAIN_FILE=$WS/vcpkg/$VCPKG_SCRIPT ..
- cmake --build .

test_script:
Expand Down
39 changes: 26 additions & 13 deletions azure-pipelines/analyzer.yml
Original file line number Diff line number Diff line change
Expand Up @@ -35,10 +35,9 @@ stages:
- job: vcpkg
strategy:
matrix:
Win 64 bits:
imageName: ${{ variables.windows_image }}
TRIPLET: x64-windows
ARCH: 64
osx:
imageName: ${{ variables.mac_image }}
TRIPLET: x64-osx
pool:
vmImage: $(imageName)
steps:
Expand All @@ -48,20 +47,34 @@ stages:
triplet: $(TRIPLET)
arch: $(ARCH)


- stage: Analyzer
variables:
BUILD_EXAMPLES: OFF
BUILD_SHARED_LIBS: ON
ENABLE_CODE_COVERAGE: ON
jobs:
# - template: 'templates/sonarcloud-job.yml'
# parameters:
# imageName: ${{ variables.windows_image }}
# jobName: SonarCloud_win
# jobDisplayName: SonarCloud (WIN)
# vcpkg_key_cache: $(CACHE_VCPKG_KEY)
# triplet: x64-windows
# arch: 64
# build_type: Debug
# sonar_wrapper_url: 'https://sonarcloud.io/static/cpp/build-wrapper-win-x86.zip'
# build_wrapper: 'build-wrapper-win-x86\build-wrapper-win-x86-64.exe'
# build_wrapper_path: build/build-wrapper-win-x86
# cmake_ignore_path: $(CMAKE_IGNORE_PATH_WIN)
- template: 'templates/sonarcloud-job.yml'
parameters:
imageName: ${{ variables.windows_image }}
jobName: SonarCloud_win
jobDisplayName: SonarCloud (WIN)
imageName: ${{ variables.mac_image }}
jobName: SonarCloud_macos
jobDisplayName: SonarCloud (macOS)
vcpkg_key_cache: $(CACHE_VCPKG_KEY)
triplet: x64-windows
arch: 64
triplet: x64-osx
build_type: Debug
sonar_wrapper_url: 'https://sonarcloud.io/static/cpp/build-wrapper-win-x86.zip'
build_wrapper: 'build-wrapper-win-x86\build-wrapper-win-x86-64.exe'
build_wrapper_path: build/build-wrapper-win-x86
cmake_ignore_path: $(CMAKE_IGNORE_PATH_WIN)
sonar_wrapper_url: 'https://sonarcloud.io/static/cpp/build-wrapper-macosx-x86.zip'
build_wrapper: 'build-wrapper-macosx-x86/build-wrapper-macosx-x86'
build_wrapper_path: build/build-wrapper-macosx-x86
13 changes: 12 additions & 1 deletion azure-pipelines/templates/ci-steps.yml
Original file line number Diff line number Diff line change
Expand Up @@ -64,9 +64,20 @@ steps:
arch: ${{ parameters.arch }}
#build_wrapper:
- ${{ if eq(parameters.test, true) }}:
- script: ctest -C ${{ parameters.build_type }} -V
- script: ctest -C ${{ parameters.build_type }} -v -V -T Test
displayName: cmake test (ctest)
workingDirectory: build
- task: PublishTestResults@2
inputs:
testResultsFormat: 'cTest' # Options: JUnit, NUnit, VSTest, xUnit, cTest
testResultsFiles: '**/Test.xml'
searchFolder: build # Optional
#mergeTestResults: false # Optional
#failTaskOnFailedTests: false # Optional
#testRunTitle: # Optional
#buildPlatform: # Optional
#buildConfiguration: # Optional
#publishRunAttachments: true # Optional

- ${{ if eq(parameters.install, true) }}:
- script: cmake --build . --target install
Expand Down
31 changes: 28 additions & 3 deletions azure-pipelines/templates/sonarcloud-job.yml
Original file line number Diff line number Diff line change
Expand Up @@ -128,12 +128,37 @@ jobs:
build_wrapper: "${{ parameters.build_wrapper }} --out-dir bw-output"

- ${{ if eq(parameters.test, true) }}:
- script: ctest -C ${{ parameters.build_type }} -V
displayName: cmake test (ctest)
- script: ctest -C ${{ parameters.build_type }}
displayName: ctest
workingDirectory: build
- bash: llvm-cov gcov -f -b -u $(find . -name *.gcda)
# /usr/local/Cellar/llvm/10.0.0_3/bin/llvm-cov
- bash: |
echo '#!/bin/bash' > g.sh
echo 'exec /usr/local/Cellar/llvm/10.0.0_3/bin/llvm-cov gcov "$@"' >> g.sh
chmod +x g.sh
cat g.sh
displayName: llvm-cov gcov wrapper
workingDirectory: build
condition: ne(variables['Agent.OS'], 'Windows_NT')
#- bash: sudo find / -name llvm-cov 2> /dev/null
# displayName: llvm-cov DEBUG
# condition: ne(variables['Agent.OS'], 'Windows_NT')
- bash: |
echo $OSTYPE
test $OSTYPE = "darwin19" && brew install lcov || apt-get install -y lcov
#brew install lcov
#echo "finding..."
#find . -name *.gcda
#echo "...."
./g.sh -f -b -u $(find . -name *.gcda)
lcov --directory . --base-directory . --gcov-tool ./g.sh --capture -o cov.info
lcov --remove cov.info '/Applications/*' --output-file coverage.info
lcov --list coverage.info
bash <(curl -s https://codecov.io/bash) -f coverage.info -t b8f07100-6985-49f7-aa4c-14e36f29ac80
displayName: collect coverage data
workingDirectory: build
condition: ne(variables['Agent.OS'], 'Windows_NT')
- task: SonarCloudAnalyze@1
- task: SonarCloudPublish@1
inputs:
Expand Down
1 change: 1 addition & 0 deletions azure-pipelines/variables/build_switches.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,3 +4,4 @@ variables:
BUILD_SHARED_LIBS: ON
BUILD_EXAMPLES: ON
BUILD_SNAPSHOT: OFF
ENABLE_CODE_COVERAGE: OFF
2 changes: 1 addition & 1 deletion azure-pipelines/variables/global.yml
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
variables:
CACHE_VCPKG_KEY: v4 | vcpkg-root
VCPKG_CMAKE: "$(Build.SourcesDirectory)/vcpkg/scripts/buildsystems/vcpkg.cmake"
CMAKE_ARGS: -DWITH_SDL2_STATIC=$(SDL2_STATIC) -DBUILD_TESTING=$(BUILD_TESTING) -DBUILD_SHARED_LIBS=$(BUILD_SHARED_LIBS) -DBUILD_EXAMPLES=$(BUILD_EXAMPLES) -DBUILD_SNAPSHOT=$(BUILD_SNAPSHOT)
CMAKE_ARGS: -DWITH_SDL2_STATIC=$(SDL2_STATIC) -DBUILD_TESTING=$(BUILD_TESTING) -DBUILD_SHARED_LIBS=$(BUILD_SHARED_LIBS) -DBUILD_EXAMPLES=$(BUILD_EXAMPLES) -DBUILD_SNAPSHOT=$(BUILD_SNAPSHOT) -DENABLE_CODE_COVERAGE=$(ENABLE_CODE_COVERAGE)
CMAKE_IGNORE_PATH_WIN: "C:/MinGW/bin;C:/Strawberry/c/bin;C:/Program Files (x86)/LLVM/bin;C:/ProgramData/chocolatey/bin"
90 changes: 0 additions & 90 deletions azure-pipelines/win-gcc.yml

This file was deleted.

65 changes: 31 additions & 34 deletions sdl2-vga-terminal/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -153,28 +153,35 @@ endif()
if(CMAKE_CXX_COMPILER_ID MATCHES "^MSVC")
# @see https://docs.microsoft.com/en-us/cpp/build/reference/compiler-options-listed-by-category?view=vs-2019

target_compile_options(vga-terminal-static PUBLIC /W4 /WX
target_compile_options(vga-terminal-static PRIVATE /W4 #/WX
$<$<CONFIG:DEBUG>:/Od /GR /GS /Gs /guard:cf /RTC1c /D_ALLOW_RTCc_IN_STL>
$<$<CONFIG:RELEASE>:/O2 /Ot /GA /GL /Gw>
)
#if (BUILD_SHARED_LIBS)
# target_compile_options(vga-terminal PRIVATE /W4 /WX
# $<$<CONFIG:DEBUG>:/Od /GR /GS /Gs /guard:cf /RTC1c /D_ALLOW_RTCc_IN_STL>
# $<$<CONFIG:RELEASE>:/O2 /Ot /GA /GL /Gw>
# )
#endif()
if (BUILD_SHARED_LIBS)
target_compile_options(vga-terminal PRIVATE /W4 #/WX
$<$<CONFIG:DEBUG>:/Od /GR /GS /Gs /guard:cf /RTC1c /D_ALLOW_RTCc_IN_STL>
$<$<CONFIG:RELEASE>:/O2 /Ot /GA /GL /Gw>
)
endif()
elseif(CMAKE_CXX_COMPILER_ID MATCHES "^GNU")
target_compile_options(vga-terminal-static PUBLIC -Wall -Wextra -pedantic -fPIC
target_compile_options(vga-terminal-static PRIVATE -Wall -Wextra -pedantic -fPIC
$<$<CONFIG:DEBUG>:
-O0;-D_GLIBCXX_DEBUG;-D_GLIBCXX_ASSERTIONS;-fexceptions;
-W; -Wshadow; -Wunused-variable;
-Wunused-parameter; -Wunused-function; -Wunused; -Wno-system-headers;
-Wno-deprecated; -Woverloaded-virtual; -Wwrite-strings; -fprofile-arcs; -ftest-coverage;
-Wno-deprecated; -Woverloaded-virtual; -Wwrite-strings;
>
#$<$<CONFIG:RELEASE>:-O2;-fexceptions;-fstack-clash-protection;-D_FORTIFY_SOURCE=2>
$<$<CONFIG:RELEASE>:-O2;-fexceptions;-D_FORTIFY_SOURCE=2>
) #-Werror)
target_link_options(vga-terminal-static INTERFACE $<$<CONFIG:DEBUG>:-fprofile-arcs; -ftest-coverage; --coverage;>)

if (ENABLE_CODE_COVERAGE)
target_compile_options(vga-terminal-static PRIVATE
$<$<CONFIG:DEBUG>: -fprofile-arcs; -ftest-coverage;>
)
target_link_options(vga-terminal-static PRIVATE $<$<CONFIG:DEBUG>:-fprofile-arcs; -ftest-coverage; --coverage;>)
endif()

#if (BUILD_SHARED_LIBS)
# target_compile_options(vga-terminal INTERAFCE
# $<$<CONFIG:DEBUG>:
Expand All @@ -190,36 +197,26 @@ elseif(CMAKE_CXX_COMPILER_ID MATCHES "^GNU")

elseif(CMAKE_CXX_COMPILER_ID MATCHES "^(Apple)?Clang")
target_compile_options(vga-terminal-static PRIVATE -WCL4 -Wabstract-vbase-init -Wassign-enum
-Watomic-implicit-seq-cst -Watomic-properties -Wbad-function-cast -Wbinary-literal
-fPIC
$<$<CONFIG:DEBUG>:
-g;
>
$<$<CONFIG:RELEASE>:
-O2;
>
) #-Weverything #-Werror


### This if Clang is shipped with VS2019 CE
-Watomic-implicit-seq-cst -Watomic-properties -Wbad-function-cast -Wbinary-literal
)

if (WIN32)
set(LINK_SUBSYS_WIN /subsystem:windows)
message(STATUS ${LINK_SUBSYS_WIN})
target_link_options(vga-terminal-static INTERFACE ${LINK_SUBSYS_WIN})
target_link_options(vga-terminal-static PUBLIC ${LINK_SUBSYS_WIN})
elseif(UNIX)
#target_compile_options(vga-terminal-static PUBLIC -fprofile-instr-generate -fcoverage-mapping)
target_compile_options(vga-terminal-static INTERFACE
$<$<CONFIG:DEBUG>:
#-flto; -fsanitize=address; -fsanitize=thread; -fsanitize=memory; -fsanitize=undefined; -fsanitize=dataflow;
#-fsanitize=cfi; -fsanitize=safe-stack;
#-fprofile-instr-generate; -fcoverage-mapping;
-c -ftest-coverage;
>
$<$<CONFIG:RELEASE>:
>
target_compile_options(vga-terminal-static PRIVATE -fPIC
$<$<CONFIG:DEBUG>: -g;>
$<$<CONFIG:RELEASE>:-O2;>
)

if(ENABLE_CODE_COVERAGE)
target_compile_options(vga-terminal-static PRIVATE
$<$<CONFIG:DEBUG>:-c;-fprofile-arcs; -ftest-coverage;>
)
target_link_options(vga-terminal-static PUBLIC $<$<CONFIG:DEBUG>: -ftest-coverage;-fprofile-arcs; --coverage;>)
#target_link_options(vga-terminal-static PUBLIC $<$<CONFIG:DEBUG>: -fprofile-instr-generate; -fcoverage-mapping;>)
target_link_options(vga-terminal-static INTERFACE $<$<CONFIG:DEBUG>: -ftest-coverage; --coverage;>)
endif()
else()
message(ERROR "Unknown OS")
endif()
Expand Down
2 changes: 1 addition & 1 deletion sonar-project.properties
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,4 @@ sonar.cfamily.build-wrapper-output=build/bw-output
sonar.cfamily.threads=2
sonar.cfamily.cache.enabled=false
sonar.cfamily.gcov.reportsPath=build
sonar.cfamily.llvm-cov.reportPath=
#sonar.cfamily.llvm-cov.reportPath=build

0 comments on commit 2555207

Please sign in to comment.