Try Hunter-based Github Actions
parent
5f19c8890b
commit
b15c111805
|
@ -8,12 +8,12 @@ on:
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
job:
|
job:
|
||||||
name: ${{ matrix.os }}-${{ matrix.cxx }}-build-and-test
|
name: ${{ matrix.name }}-build-and-test
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
name: [ubuntu-gcc, macos-clang, windows-msvc, ubuntu-clang]
|
name: [ubuntu-gcc, macos-clang, windows-msvc, ubuntu-clang, ubuntu-gcc-hunter, macos-clang-hunter, windows-msvc-hunter]
|
||||||
# For Windows msvc, for Linux and macOS let's use the clang compiler, use gcc for Linux.
|
# For Windows msvc, for Linux and macOS let's use the clang compiler, use gcc for Linux.
|
||||||
include:
|
include:
|
||||||
- name: windows-msvc
|
- name: windows-msvc
|
||||||
|
@ -32,6 +32,15 @@ jobs:
|
||||||
os: ubuntu-latest
|
os: ubuntu-latest
|
||||||
cxx: g++
|
cxx: g++
|
||||||
cc: gcc
|
cc: gcc
|
||||||
|
- name: ubuntu-gcc-hunter
|
||||||
|
os: ubuntu-latest
|
||||||
|
toolchain: ninja-gcc-cxx17-fpic
|
||||||
|
- name: macos-clang-hunter
|
||||||
|
os: macos-latest
|
||||||
|
toolchain: ninja-clang-cxx17-fpic
|
||||||
|
- name: windows-msvc-hunter
|
||||||
|
os: windows-latest
|
||||||
|
toolchain: ninja-vs-win64-cxx17
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
|
@ -40,14 +49,29 @@ jobs:
|
||||||
|
|
||||||
- uses: ilammy/msvc-dev-cmd@v1
|
- uses: ilammy/msvc-dev-cmd@v1
|
||||||
|
|
||||||
- uses: lukka/set-shell-env@v1
|
- name: Set Compiler Environment
|
||||||
|
if: "!endsWith(matrix.name, 'hunter')"
|
||||||
|
uses: lukka/set-shell-env@v1
|
||||||
with:
|
with:
|
||||||
CXX: ${{ matrix.cxx }}
|
CXX: ${{ matrix.cxx }}
|
||||||
CC: ${{ matrix.cc }}
|
CC: ${{ matrix.cc }}
|
||||||
|
|
||||||
|
- name: Set Compiler Environment for Hunter on Windows
|
||||||
|
if: startsWith(matrix.name, 'windows') && endsWith(matrix.name, 'hunter')
|
||||||
|
uses: lukka/set-shell-env@v1
|
||||||
|
with:
|
||||||
|
VS160COMNTOOLS: C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\Common7\Tools
|
||||||
|
|
||||||
|
- name: Checkout Hunter toolchains
|
||||||
|
if: endsWith(matrix.name, 'hunter')
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
repository: cpp-pm/polly
|
||||||
|
path: cmake/polly
|
||||||
|
|
||||||
- name: Cache DX SDK
|
- name: Cache DX SDK
|
||||||
id: dxcache
|
id: dxcache
|
||||||
if: matrix.name == 'windows-msvc'
|
if: contains(matrix.name, 'windows')
|
||||||
uses: actions/cache@v2
|
uses: actions/cache@v2
|
||||||
with:
|
with:
|
||||||
path: '${{ github.workspace }}/DX_SDK'
|
path: '${{ github.workspace }}/DX_SDK'
|
||||||
|
@ -56,16 +80,21 @@ jobs:
|
||||||
${{ runner.os }}-DX_SDK
|
${{ runner.os }}-DX_SDK
|
||||||
|
|
||||||
- name: Download DXSetup
|
- name: Download DXSetup
|
||||||
if: matrix.name == 'windows-msvc' && steps.dxcache.outputs.cache-hit != 'true'
|
if: contains(matrix.name, 'windows') && steps.dxcache.outputs.cache-hit != 'true'
|
||||||
run: |
|
run: |
|
||||||
curl -s -o DXSDK_Jun10.exe --location https://download.microsoft.com/download/A/E/7/AE743F1F-632B-4809-87A9-AA1BB3458E31/DXSDK_Jun10.exe
|
curl -s -o DXSDK_Jun10.exe --location https://download.microsoft.com/download/A/E/7/AE743F1F-632B-4809-87A9-AA1BB3458E31/DXSDK_Jun10.exe
|
||||||
cmd.exe /c start /wait .\DXSDK_Jun10.exe /U /O /F /S /P "${{ github.workspace }}\DX_SDK"
|
cmd.exe /c start /wait .\DXSDK_Jun10.exe /U /O /F /S /P "${{ github.workspace }}\DX_SDK"
|
||||||
|
|
||||||
- name: Set Windows specific CMake arguments
|
- name: Set Windows specific CMake arguments
|
||||||
if: matrix.name == 'windows-msvc'
|
if: contains(matrix.name, 'windows')
|
||||||
id: windows_extra_cmake_args
|
id: windows_extra_cmake_args
|
||||||
run: echo "::set-output name=args::'-DASSIMP_BUILD_ASSIMP_TOOLS=1 -DASSIMP_BUILD_ASSIMP_VIEW=1'"
|
run: echo "::set-output name=args::-DASSIMP_BUILD_ASSIMP_TOOLS=1 -DASSIMP_BUILD_ASSIMP_VIEW=1"
|
||||||
|
|
||||||
|
- name: Set Hunter specific CMake arguments
|
||||||
|
if: contains(matrix.name, 'hunter')
|
||||||
|
id: hunter_extra_cmake_args
|
||||||
|
run: echo "::set-output name=args::-DBUILD_SHARED_LIBS=OFF -DASSIMP_HUNTER_ENABLED=ON -DCMAKE_TOOLCHAIN_FILE=${{ github.workspace }}/cmake/polly/${{ matrix.toolchain }}.cmake"
|
||||||
|
|
||||||
- name: configure and build
|
- name: configure and build
|
||||||
uses: lukka/run-cmake@v2
|
uses: lukka/run-cmake@v2
|
||||||
env:
|
env:
|
||||||
|
@ -74,12 +103,17 @@ jobs:
|
||||||
with:
|
with:
|
||||||
cmakeListsOrSettingsJson: CMakeListsTxtAdvanced
|
cmakeListsOrSettingsJson: CMakeListsTxtAdvanced
|
||||||
cmakeListsTxtPath: '${{ github.workspace }}/CMakeLists.txt'
|
cmakeListsTxtPath: '${{ github.workspace }}/CMakeLists.txt'
|
||||||
cmakeAppendedArgs: '-GNinja -DCMAKE_BUILD_TYPE=Release ${{ steps.windows_extra_cmake_args.outputs.args }}'
|
cmakeAppendedArgs: '-GNinja -DCMAKE_BUILD_TYPE=Release ${{ steps.windows_extra_cmake_args.outputs.args }} ${{ steps.hunter_extra_cmake_args.outputs.args }}'
|
||||||
buildWithCMakeArgs: '-- -v'
|
buildWithCMakeArgs: '-- -v'
|
||||||
buildDirectory: '${{ github.workspace }}/build/'
|
buildDirectory: '${{ github.workspace }}/build/'
|
||||||
|
|
||||||
|
- name: Exclude certain tests in Hunter specific builds
|
||||||
|
if: contains(matrix.name, 'hunter')
|
||||||
|
id: hunter_extra_test_args
|
||||||
|
run: echo "::set-output name=args::--gtest_filter=-utOpenGEXImportExport.Importissue1340_EmptyCameraObject:utColladaZaeImportExport.importBlenFromFileTest"
|
||||||
|
|
||||||
- name: test
|
- name: test
|
||||||
run: cd build/bin && ./unit
|
run: cd build/bin && ./unit ${{ steps.hunter_extra_test_args.outputs.args }}
|
||||||
shell: bash
|
shell: bash
|
||||||
|
|
||||||
- uses: actions/upload-artifact@v2
|
- uses: actions/upload-artifact@v2
|
||||||
|
|
26
Dockerfile
26
Dockerfile
|
@ -1,26 +0,0 @@
|
||||||
FROM ubuntu:20.04
|
|
||||||
|
|
||||||
ARG TOOLCHAIN_NAME=gcc-9-cxx17-fpic
|
|
||||||
ARG BUILD_TYPE=RelWithDebInfo
|
|
||||||
|
|
||||||
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
||||||
cmake \
|
|
||||||
gcc-9 \
|
|
||||||
g++-9 \
|
|
||||||
ca-certificates \
|
|
||||||
make
|
|
||||||
|
|
||||||
WORKDIR /root/assimp
|
|
||||||
COPY ./cmake ./cmake
|
|
||||||
COPY ./cmake-modules ./cmake-modules
|
|
||||||
COPY ./code ./code
|
|
||||||
COPY ./include ./include
|
|
||||||
COPY ./samples ./samples
|
|
||||||
COPY ./test ./test
|
|
||||||
COPY ./tools ./tools
|
|
||||||
COPY ./*.in ./
|
|
||||||
COPY CMakeLists.txt ./
|
|
||||||
|
|
||||||
RUN cmake -DBUILD_SHARED_LIBS=OFF -DASSIMP_BUILD_ASSIMP_TOOLS=ON -DASSIMP_BUILD_SAMPLES=OFF -DASSIMP_BUILD_TESTS=ON -DASSIMP_INSTALL_PDB=OFF -DASSIMP_IGNORE_GIT_HASH=ON -DASSIMP_HUNTER_ENABLED=ON -H. -B_builds/${TOOLCHAIN_NAME}-${BUILD_TYPE} -DCMAKE_TOOLCHAIN_FILE=./cmake/polly/${TOOLCHAIN_NAME}.cmake -DCMAKE_BUILD_TYPE=${BUILD_TYPE}
|
|
||||||
|
|
||||||
RUN make -C _builds/${TOOLCHAIN_NAME}-${BUILD_TYPE} -j 4
|
|
|
@ -1,4 +1,4 @@
|
||||||
# Copyright (c) 2013-2018, Ruslan Baratov
|
# Copyright (c) 2013-2019, Ruslan Baratov
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
# Redistribution and use in source and binary forms, with or without
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -60,7 +60,7 @@ option(HUNTER_STATUS_PRINT "Print working status" ON)
|
||||||
option(HUNTER_STATUS_DEBUG "Print a lot info" OFF)
|
option(HUNTER_STATUS_DEBUG "Print a lot info" OFF)
|
||||||
option(HUNTER_TLS_VERIFY "Enable/disable TLS certificate checking on downloads" ON)
|
option(HUNTER_TLS_VERIFY "Enable/disable TLS certificate checking on downloads" ON)
|
||||||
|
|
||||||
set(HUNTER_WIKI "https://github.com/ruslo/hunter/wiki")
|
set(HUNTER_ERROR_PAGE "https://docs.hunter.sh/en/latest/reference/errors")
|
||||||
|
|
||||||
function(hunter_gate_status_print)
|
function(hunter_gate_status_print)
|
||||||
if(HUNTER_STATUS_PRINT OR HUNTER_STATUS_DEBUG)
|
if(HUNTER_STATUS_PRINT OR HUNTER_STATUS_DEBUG)
|
||||||
|
@ -79,9 +79,9 @@ function(hunter_gate_status_debug)
|
||||||
endif()
|
endif()
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
function(hunter_gate_wiki wiki_page)
|
function(hunter_gate_error_page error_page)
|
||||||
message("------------------------------ WIKI -------------------------------")
|
message("------------------------------ ERROR ------------------------------")
|
||||||
message(" ${HUNTER_WIKI}/${wiki_page}")
|
message(" ${HUNTER_ERROR_PAGE}/${error_page}.html")
|
||||||
message("-------------------------------------------------------------------")
|
message("-------------------------------------------------------------------")
|
||||||
message("")
|
message("")
|
||||||
message(FATAL_ERROR "")
|
message(FATAL_ERROR "")
|
||||||
|
@ -94,14 +94,13 @@ function(hunter_gate_internal_error)
|
||||||
endforeach()
|
endforeach()
|
||||||
message("[hunter ** INTERNAL **] [Directory:${CMAKE_CURRENT_LIST_DIR}]")
|
message("[hunter ** INTERNAL **] [Directory:${CMAKE_CURRENT_LIST_DIR}]")
|
||||||
message("")
|
message("")
|
||||||
hunter_gate_wiki("error.internal")
|
hunter_gate_error_page("error.internal")
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
function(hunter_gate_fatal_error)
|
function(hunter_gate_fatal_error)
|
||||||
cmake_parse_arguments(hunter "" "WIKI" "" "${ARGV}")
|
cmake_parse_arguments(hunter "" "ERROR_PAGE" "" "${ARGV}")
|
||||||
string(COMPARE EQUAL "${hunter_WIKI}" "" have_no_wiki)
|
if("${hunter_ERROR_PAGE}" STREQUAL "")
|
||||||
if(have_no_wiki)
|
hunter_gate_internal_error("Expected ERROR_PAGE")
|
||||||
hunter_gate_internal_error("Expected wiki")
|
|
||||||
endif()
|
endif()
|
||||||
message("")
|
message("")
|
||||||
foreach(x ${hunter_UNPARSED_ARGUMENTS})
|
foreach(x ${hunter_UNPARSED_ARGUMENTS})
|
||||||
|
@ -109,11 +108,11 @@ function(hunter_gate_fatal_error)
|
||||||
endforeach()
|
endforeach()
|
||||||
message("[hunter ** FATAL ERROR **] [Directory:${CMAKE_CURRENT_LIST_DIR}]")
|
message("[hunter ** FATAL ERROR **] [Directory:${CMAKE_CURRENT_LIST_DIR}]")
|
||||||
message("")
|
message("")
|
||||||
hunter_gate_wiki("${hunter_WIKI}")
|
hunter_gate_error_page("${hunter_ERROR_PAGE}")
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
function(hunter_gate_user_error)
|
function(hunter_gate_user_error)
|
||||||
hunter_gate_fatal_error(${ARGV} WIKI "error.incorrect.input.data")
|
hunter_gate_fatal_error(${ARGV} ERROR_PAGE "error.incorrect.input.data")
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
function(hunter_gate_self root version sha1 result)
|
function(hunter_gate_self root version sha1 result)
|
||||||
|
@ -195,7 +194,7 @@ function(hunter_gate_detect_root)
|
||||||
|
|
||||||
hunter_gate_fatal_error(
|
hunter_gate_fatal_error(
|
||||||
"Can't detect HUNTER_ROOT"
|
"Can't detect HUNTER_ROOT"
|
||||||
WIKI "error.detect.hunter.root"
|
ERROR_PAGE "error.detect.hunter.root"
|
||||||
)
|
)
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
|
@ -214,7 +213,7 @@ function(hunter_gate_download dir)
|
||||||
"Settings:"
|
"Settings:"
|
||||||
" HUNTER_ROOT: ${HUNTER_GATE_ROOT}"
|
" HUNTER_ROOT: ${HUNTER_GATE_ROOT}"
|
||||||
" HUNTER_SHA1: ${HUNTER_GATE_SHA1}"
|
" HUNTER_SHA1: ${HUNTER_GATE_SHA1}"
|
||||||
WIKI "error.run.install"
|
ERROR_PAGE "error.run.install"
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
string(COMPARE EQUAL "${dir}" "" is_bad)
|
string(COMPARE EQUAL "${dir}" "" is_bad)
|
||||||
|
@ -400,7 +399,7 @@ macro(HunterGate)
|
||||||
hunter_gate_fatal_error(
|
hunter_gate_fatal_error(
|
||||||
"Please set HunterGate *before* 'project' command. "
|
"Please set HunterGate *before* 'project' command. "
|
||||||
"Detected project: ${PROJECT_NAME}"
|
"Detected project: ${PROJECT_NAME}"
|
||||||
WIKI "error.huntergate.before.project"
|
ERROR_PAGE "error.huntergate.before.project"
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
@ -470,7 +469,7 @@ macro(HunterGate)
|
||||||
"HUNTER_ROOT (${HUNTER_GATE_ROOT}) contains spaces."
|
"HUNTER_ROOT (${HUNTER_GATE_ROOT}) contains spaces."
|
||||||
"Set HUNTER_ALLOW_SPACES_IN_PATH=ON to skip this error"
|
"Set HUNTER_ALLOW_SPACES_IN_PATH=ON to skip this error"
|
||||||
"(Use at your own risk!)"
|
"(Use at your own risk!)"
|
||||||
WIKI "error.spaces.in.hunter.root"
|
ERROR_PAGE "error.spaces.in.hunter.root"
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
|
@ -43,7 +43,10 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
// We need to be sure to have the same STL settings as Assimp
|
// We need to be sure to have the same STL settings as Assimp
|
||||||
|
|
||||||
#include <assimp/cimport.h>
|
#include <assimp/cimport.h>
|
||||||
|
#pragma warning(push)
|
||||||
|
#pragma warning(disable:4389)
|
||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
|
#pragma warning(pop)
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include "UTLogStream.h"
|
#include "UTLogStream.h"
|
||||||
|
|
Loading…
Reference in New Issue