Skip to content

Commit a9e06d2

Browse files
committed
fix installation test for various CMake versions
1 parent 433fcb1 commit a9e06d2

10 files changed

+221
-246
lines changed

.github/workflows/pr_push.yml

Lines changed: 0 additions & 83 deletions
Original file line numberDiff line numberDiff line change
@@ -18,86 +18,3 @@ permissions:
1818
jobs:
1919
CodeChecks:
2020
uses: ./.github/workflows/reusable_checks.yml
21-
FastBuild:
22-
name: Fast builds
23-
needs: [CodeChecks]
24-
uses: ./.github/workflows/reusable_fast.yml
25-
Build:
26-
name: Basic builds
27-
needs: [FastBuild]
28-
uses: ./.github/workflows/reusable_basic.yml
29-
DevDax:
30-
needs: [FastBuild]
31-
uses: ./.github/workflows/reusable_dax.yml
32-
MultiNuma:
33-
needs: [FastBuild]
34-
uses: ./.github/workflows/reusable_multi_numa.yml
35-
L0:
36-
needs: [Build]
37-
uses: ./.github/workflows/reusable_gpu.yml
38-
with:
39-
provider: "LEVEL_ZERO"
40-
runner: "L0"
41-
shared_lib: "['ON']"
42-
L0-BMG:
43-
needs: [Build]
44-
uses: ./.github/workflows/reusable_gpu.yml
45-
with:
46-
provider: "LEVEL_ZERO"
47-
runner: "L0-BMG"
48-
shared_lib: "['ON']"
49-
os: "['Ubuntu']"
50-
CUDA:
51-
needs: [Build]
52-
uses: ./.github/workflows/reusable_gpu.yml
53-
with:
54-
provider: "CUDA"
55-
runner: "CUDA"
56-
shared_lib: "['ON']"
57-
Sanitizers:
58-
needs: [FastBuild]
59-
uses: ./.github/workflows/reusable_sanitizers.yml
60-
QEMU:
61-
needs: [FastBuild]
62-
uses: ./.github/workflows/reusable_qemu.yml
63-
with:
64-
short_run: true
65-
ProxyLib:
66-
needs: [Build]
67-
uses: ./.github/workflows/reusable_proxy_lib.yml
68-
Valgrind:
69-
needs: [Build]
70-
uses: ./.github/workflows/reusable_valgrind.yml
71-
Coverage:
72-
# total coverage (on upstream only)
73-
if: github.repository == 'oneapi-src/unified-memory-framework'
74-
needs: [Build, DevDax, L0, CUDA, MultiNuma, QEMU, ProxyLib]
75-
uses: ./.github/workflows/reusable_coverage.yml
76-
secrets: inherit
77-
with:
78-
trigger: "${{github.event_name}}"
79-
Coverage_partial:
80-
# partial coverage (on forks)
81-
if: github.repository != 'oneapi-src/unified-memory-framework'
82-
needs: [Build, QEMU, ProxyLib]
83-
uses: ./.github/workflows/reusable_coverage.yml
84-
CodeQL:
85-
needs: [Build]
86-
permissions:
87-
contents: read
88-
security-events: write
89-
uses: ./.github/workflows/reusable_codeql.yml
90-
Trivy:
91-
needs: [Build]
92-
permissions:
93-
contents: read
94-
security-events: write
95-
uses: ./.github/workflows/reusable_trivy.yml
96-
Compatibility:
97-
needs: [Build]
98-
uses: ./.github/workflows/reusable_compatibility.yml
99-
strategy:
100-
matrix:
101-
tag: ["v0.11.0-rc1"]
102-
with:
103-
tag: ${{matrix.tag}}

.github/workflows/reusable_basic.yml

Lines changed: 45 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -239,14 +239,16 @@ jobs:
239239
name: Windows
240240
env:
241241
VCPKG_PATH: "${{github.workspace}}/build/vcpkg/packages/hwloc_x64-windows;${{github.workspace}}/build/vcpkg/packages/tbb_x64-windows;${{github.workspace}}/build/vcpkg/packages/jemalloc_x64-windows"
242+
VCPKG_PATH_BIN: "${{github.workspace}}/build/vcpkg/packages/hwloc_x64-windows/bin;${{github.workspace}}/build/vcpkg/packages/tbb_x64-windows/bin;${{github.workspace}}/build/vcpkg/packages/jemalloc_x64-windows/bin"
242243
strategy:
243244
matrix:
244245
os: ['windows-2019', 'windows-2022']
245-
build_type: [Debug, Release]
246+
build_type: [Debug]
246247
compiler: [{c: cl, cxx: cl}]
247-
shared_library: ['ON', 'OFF']
248+
shared_library: ['ON']
248249
level_zero_provider: ['ON']
249250
cuda_provider: ['ON']
251+
cmake_ver: ['default']
250252
include:
251253
- os: 'windows-2019'
252254
# clang build fails on Windows 2022
@@ -256,19 +258,22 @@ jobs:
256258
level_zero_provider: 'ON'
257259
cuda_provider: 'ON'
258260
toolset: "-T ClangCL"
261+
cmake_ver: '3.14.0-win64-x64'
259262
- os: 'windows-2022'
260263
build_type: Release
261264
compiler: {c: cl, cxx: cl}
262265
shared_library: 'ON'
263266
level_zero_provider: 'ON'
264267
cuda_provider: 'ON'
265268
umfd_lib: 'ON'
269+
cmake_ver: '3.28.0-windows-x86_64'
266270
- os: 'windows-2022'
267271
build_type: Release
268272
compiler: {c: cl, cxx: cl}
269273
shared_library: 'ON'
270274
level_zero_provider: 'OFF'
271275
cuda_provider: 'OFF'
276+
cmake_ver: 'default'
272277

273278
runs-on: ${{matrix.os}}
274279

@@ -278,6 +283,25 @@ jobs:
278283
with:
279284
fetch-depth: 0
280285

286+
- name: Install cmake (non-default version)
287+
if: matrix.cmake_ver != 'default'
288+
run: |
289+
$ErrorActionPreference = "Stop"
290+
$cmakePath = "C:\Program Files\CMake"
291+
if (Test-Path -Path $cmakePath) {
292+
Write-Host "Removing existing CMake installation..."
293+
Remove-Item -Recurse -Force -Path $cmakePath
294+
}
295+
$cmakeInstaller = "cmake-${{matrix.cmake_ver}}.msi"
296+
$cmakeInstallerParts = $cmakeInstaller -split '-|\.'
297+
$cmakeMajorMinorPatch = "$($cmakeInstallerParts[1]).$($cmakeInstallerParts[2]).$($cmakeInstallerParts[3])"
298+
$cmakeUrl = "https://github.com/Kitware/CMake/releases/download/v$cmakeMajorMinorPatch/$cmakeInstaller"
299+
Write-Host "Downloading CMake version ${{matrix.cmake_ver}}..."
300+
Invoke-WebRequest -Uri $cmakeUrl -OutFile $cmakeInstaller -TimeoutSec 360
301+
Write-Host "Installing CMake version ${{matrix.cmake_ver}}..."
302+
Start-Process msiexec.exe -ArgumentList "/i $cmakeInstaller /quiet /norestart" -Wait
303+
cmake --version
304+
281305
- name: Initialize vcpkg
282306
uses: lukka/run-vcpkg@5e0cab206a5ea620130caf672fce3e4a6b5666a1 # v11.5
283307
with:
@@ -286,7 +310,10 @@ jobs:
286310
vcpkgJsonGlob: '**/vcpkg.json'
287311

288312
- name: Install dependencies
289-
run: vcpkg install --triplet x64-windows
313+
run: |
314+
vcpkg install --triplet x64-windows
315+
$env:Path = "${{env.VCPKG_PATH_BIN}};$env:Path"
316+
echo "PATH=$env:Path" >> $env:GITHUB_ENV
290317
shell: pwsh # Specifies PowerShell as the shell for running the script.
291318

292319
- name: Get UMF version
@@ -318,10 +345,23 @@ jobs:
318345

319346
- name: Run tests
320347
working-directory: ${{env.BUILD_DIR}}
321-
run: ctest -C ${{matrix.build_type}} --output-on-failure --test-dir test
348+
# For CMake versions < 3.22 we have to add the build directory to the PATH
349+
# manually
350+
run: |
351+
$m = [regex]::Matches((cmake --version), "cmake version (\d+)\.(\d+)\.(\d+)")
352+
if ($m) {
353+
$major = [int]$m.groups[1].Value
354+
$minor = [int]$m.groups[2].Value
355+
if ($major -lt 3 -or ($major -eq 3 -and $minor -lt 22)) {
356+
$env:Path = "${{env.BUILD_DIR}}/bin/${{matrix.build_type}};${{env.BUILD_DIR}}/src/proxy_lib/${{matrix.build_type}};$env:Path"
357+
}
358+
}
359+
ctest -C ${{matrix.build_type}} --output-on-failure --test-dir test
360+
shell: pwsh
322361

323362
- name: Test UMF installation and uninstallation
324-
# The '--shared-library' parameter is added to the installation test when the UMF is built as a shared library
363+
# The '--shared-library' parameter is added to the installation test when
364+
# the UMF is built as a shared library
325365
run: >
326366
python3 ${{github.workspace}}/test/test_installation.py
327367
--build-dir ${{env.BUILD_DIR}}

test/CMakeLists.txt

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -151,7 +151,8 @@ function(add_umf_test)
151151
"${DLL_PATH_LIST};PATH=path_list_append:${CMAKE_BINARY_DIR}/bin/;PATH=path_list_append:${CMAKE_BINARY_DIR}/bin/$<CONFIG>/"
152152
)
153153

154-
# append PATH to DLLs
154+
# append PATH to DLLs (NOTE: this would work only for the CMake ver >=
155+
# 3.22) TODO
155156
set_property(TEST ${TEST_NAME} PROPERTY ENVIRONMENT_MODIFICATION
156157
"${DLL_PATH_LIST}")
157158
endif()

0 commit comments

Comments
 (0)