generic.yml 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437
  1. name: 'Build'
  2. run-name: 'Configure, Build and Test SDL'
  3. on:
  4. workflow_call:
  5. inputs:
  6. platforms:
  7. description: 'JSON-encoded test properties'
  8. type: string
  9. required: true
  10. jobs:
  11. build:
  12. name: ${{ matrix.platform.name }}
  13. runs-on: ${{ matrix.platform.os }}
  14. container: ${{ matrix.platform.container }}
  15. defaults:
  16. run:
  17. shell: ${{ matrix.platform.shell }}
  18. strategy:
  19. fail-fast: false
  20. matrix:
  21. platform: ${{ fromJSON(inputs.platforms) }}
  22. steps:
  23. - name: 'Set up MSYS2'
  24. if: ${{ matrix.platform.platform == 'msys2' }}
  25. uses: msys2/setup-msys2@v2
  26. with:
  27. msystem: ${{ matrix.platform.msys2-msystem }}
  28. install: ${{ matrix.platform.msys2-packages }}
  29. - name: 'About this job'
  30. run: |
  31. echo "key=${{ matrix.platform.key }}"
  32. echo "name=${{ matrix.platform.name }}"
  33. echo "os=${{ matrix.platform.os }}"
  34. echo ""
  35. echo "Add [sdl-ci-filter ${{ matrix.platform.key }}] to your commit message to reduce the number of jobs."
  36. - uses: actions/checkout@v4
  37. - name: 'Set up ninja'
  38. if: ${{ matrix.platform.setup-ninja }}
  39. uses: ./.github/actions/setup-ninja
  40. - name: 'Set up libusb for MSVC'
  41. if: ${{ matrix.platform.setup-libusb-arch != '' }}
  42. uses: ./.github/actions/setup-msvc-libusb
  43. with:
  44. arch: ${{ matrix.platform.setup-libusb-arch }}
  45. - uses: mymindstorm/setup-emsdk@v14
  46. if: ${{ matrix.platform.platform == 'emscripten' }}
  47. with:
  48. version: 3.1.35
  49. - uses: browser-actions/setup-chrome@v1
  50. id: setup-chrome
  51. if: ${{ matrix.platform.platform == 'emscripten' }}
  52. with:
  53. install-chromedriver: true
  54. - name: 'Add chrome to PATH'
  55. if: ${{ matrix.platform.platform == 'emscripten' }}
  56. run: |
  57. chrome_dir="$(dirname "${{ steps.setup-chrome.outputs.chrome-path }}")"
  58. chromedriver_dir="$(dirname "${{ steps.setup-chrome.outputs.chromedriver-path }}")"
  59. echo "CHROME_BINARY=${{ steps.setup-chrome.outputs.chrome-path }}" >>$GITHUB_ENV
  60. echo "CHROMEDRIVER_BINARY=${{ steps.setup-chrome.outputs.chromedriver-path }}" >>$GITHUB_ENV
  61. echo "chrome_dir=${chrome_dir}"
  62. echo "chromedriver_dir=${chromedriver_dir}"
  63. echo "${chrome_dir}" >>${GITHUB_PATH}
  64. echo "${chromedriver_dir}" >>${GITHUB_PATH}
  65. - uses: nttld/setup-ndk@v1
  66. if: ${{ matrix.platform.android-ndk }}
  67. id: setup-ndk
  68. with:
  69. local-cache: false
  70. ndk-version: r28c
  71. - name: 'Configure Android NDK variables'
  72. if: ${{ matrix.platform.android-ndk }}
  73. shell: sh
  74. run: |
  75. # We cannot use GitHub expressions in the controller job
  76. echo "ANDROID_NDK_HOME=${{ steps.setup-ndk.outputs.ndk-path }}" >>$GITHUB_ENV
  77. - uses: actions/setup-java@v4
  78. if: ${{ matrix.platform.java }}
  79. with:
  80. distribution: 'temurin'
  81. java-version: '17'
  82. - uses: ilammy/msvc-dev-cmd@v1
  83. if: ${{ matrix.platform.platform == 'msvc' }}
  84. with:
  85. arch: ${{ matrix.platform.msvc-vcvars-arch }}
  86. sdk: ${{ matrix.platform.msvc-vcvars-sdk }}
  87. - name: 'Set up Nokia N-Gage SDK'
  88. uses: ./.github/actions/setup-ngage-sdk
  89. if: ${{ matrix.platform.setup-ngage-sdk-path != '' }}
  90. with:
  91. path: '${{ matrix.platform.setup-ngage-sdk-path }}'
  92. - name: 'Set up Windows GDK Desktop'
  93. uses: ./.github/actions/setup-gdk-desktop
  94. if: ${{ matrix.platform.setup-gdk-folder != '' }}
  95. with:
  96. folder: '${{ matrix.platform.setup-gdk-folder }}'
  97. - name: 'Set up LoongArch64 toolchain'
  98. uses: ./.github/actions/setup-loongarch64-toolchain
  99. id: setup-loongarch64-toolchain
  100. if: ${{ matrix.platform.platform == 'loongarch64' }}
  101. - name: 'Setup Intel oneAPI toolchain'
  102. id: intel
  103. if: ${{ matrix.platform.intel }}
  104. run: |
  105. # Download the key to system keyring
  106. wget -O- https://apt.repos.intel.com/intel-gpg-keys/GPG-PUB-KEY-INTEL-SW-PRODUCTS.PUB \
  107. | gpg --dearmor | sudo tee /usr/share/keyrings/oneapi-archive-keyring.gpg > /dev/null
  108. # Add signed entry to apt sources and configure the APT client to use Intel repository:
  109. echo "deb [signed-by=/usr/share/keyrings/oneapi-archive-keyring.gpg] https://apt.repos.intel.com/oneapi all main" | sudo tee /etc/apt/sources.list.d/oneAPI.list
  110. # Update package list
  111. sudo apt-get update -y
  112. # Install oneAPI
  113. sudo apt-get install -y intel-oneapi-compiler-dpcpp-cpp-and-cpp-classic
  114. - name: 'Install apk packages'
  115. if: ${{ matrix.platform.apk-packages != '' }}
  116. run: |
  117. ${{ matrix.platform.sudo }} apk update
  118. ${{ matrix.platform.sudo }} apk add ${{ matrix.platform.apk-packages }}
  119. - name: 'Install apt packages'
  120. if: ${{ matrix.platform.apt-packages != '' }}
  121. run: |
  122. ${{ matrix.platform.sudo }} apt-get update
  123. ${{ matrix.platform.sudo }} apt-get install -y ${{ matrix.platform.apt-packages }}
  124. - name: 'Install brew packages'
  125. if: ${{ matrix.platform.brew-packages != '' }}
  126. run: |
  127. export HOMEBREW_NO_INSTALLED_DEPENDENTS_CHECK=1
  128. brew update
  129. brew install ${{ matrix.platform.brew-packages }}
  130. - name: 'Setup Python'
  131. uses: 'actions/setup-python@main'
  132. if: ${{ matrix.platform.setup-python }}
  133. with:
  134. python-version: '3.x'
  135. - name: 'Install PyPI packages'
  136. if: ${{ matrix.platform.pypi-packages != '' }}
  137. run: |
  138. python -m pip install --user ${{ matrix.platform.pypi-packages }}
  139. - name: 'Set up GLES for VITA' # Must be after apk
  140. if: ${{ matrix.platform.setup-vita-gles-type != '' }}
  141. uses: ./.github/actions/setup-vita-gles
  142. with:
  143. type: ${{ matrix.platform.setup-vita-gles-type }}
  144. - name: 'Pollute toolchain with "bad" SDL headers'
  145. if: ${{ matrix.platform.pollute-directories != '' }}
  146. #shell: ${{ matrix.platform.shell }}
  147. run: |
  148. # Create "bad" SDL headers in the toolchain.
  149. # SDL sources should not use these.
  150. for include in ${{ matrix.platform.pollute-directories }}; do
  151. toolchain_directory="${include}/SDL3"
  152. echo "Creating directory ${toolchain_directory}"
  153. mkdir -p "${toolchain_directory}/SDL3"
  154. for header in include/SDL3/*.h; do
  155. dest="${toolchain_directory}/SDL3/$(basename "${header}")"
  156. echo "Creating ${dest}"
  157. echo '#error "System SDL headers must not be used by build system"' >"$dest"
  158. done
  159. done
  160. - name: 'Calculate ccache key'
  161. if: ${{ matrix.platform.ccache }}
  162. id: prepare-restore-ccache
  163. run: |
  164. echo "timestamp=$(date -u "+%Y%m%d%H%M_%S")" >> "$GITHUB_OUTPUT"
  165. - name: 'Restore ccache'
  166. if: ${{ matrix.platform.ccache }}
  167. uses: actions/cache/restore@v4
  168. id: restore-ccache
  169. with:
  170. path: ${{ runner.temp }}/ccache
  171. key: ccache-${{ matrix.platform.key }}-${{ steps.prepare-restore-ccache.outputs.timestamp }}
  172. restore-keys: |
  173. ccache-${{matrix.platform.key}}
  174. - name: 'Configure ccache'
  175. if: ${{ matrix.platform.ccache }}
  176. run: |
  177. echo 'CCACHE_DIR=${{ runner.temp }}/ccache' >>${GITHUB_ENV}
  178. - name: 'Prepare ccache'
  179. if: ${{ matrix.platform.ccache && steps.restore-ccache.outputs.cache-hit }}
  180. run: |
  181. if [ "x${{ runner.os }}" = "xmacOS" ]; then
  182. touch_date="2025-02-01T12:00:00Z"
  183. else
  184. touch_date="2025-02-01"
  185. fi
  186. find "${CCACHE_DIR}" -type f -exec touch -a -m -d "$touch_date" {} +
  187. ccache -s
  188. ccache -z
  189. - name: 'Configure (CMake)'
  190. if: ${{ !matrix.platform.no-cmake }}
  191. #shell: ${{ matrix.platform.shell }}
  192. run: |
  193. ${{ matrix.platform.source-cmd }}
  194. ${{ matrix.platform.cmake-config-emulator }} cmake -S . -B build -G "${{ matrix.platform.cmake-generator }}" \
  195. -Wdeprecated -Wdev -Werror \
  196. ${{ matrix.platform.cmake-toolchain-file != '' && format('-DCMAKE_TOOLCHAIN_FILE={0}', matrix.platform.cmake-toolchain-file) || '' }} \
  197. -DSDL_WERROR=${{ matrix.platform.werror }} \
  198. -DSDL_EXAMPLES=${{ matrix.platform.build-tests }} \
  199. -DSDL_TESTS=${{ matrix.platform.build-tests }} \
  200. -DSDLTEST_TRACKMEM=ON \
  201. -DSDL_INSTALL_TESTS=${{ matrix.platform.build-tests }} \
  202. -DSDL_CLANG_TIDY=${{ matrix.platform.clang-tidy }} \
  203. -DSDL_INSTALL_DOCS=ON \
  204. -DSDL_INSTALL_CPACK=ON \
  205. -DSDL_INSTALL_DOCS=ON \
  206. ${{ matrix.platform.cmake-arguments }} \
  207. -DSDL_SHARED=${{ matrix.platform.shared }} \
  208. -DSDL_STATIC=${{ matrix.platform.static }} \
  209. -DSDL_VENDOR_INFO="Github Workflow" \
  210. -DCMAKE_INSTALL_PREFIX=prefix \
  211. -DCMAKE_INSTALL_LIBDIR=lib \
  212. -DCMAKE_BUILD_TYPE=${{ matrix.platform.cmake-build-type }}
  213. - name: 'Build (CMake)'
  214. id: build
  215. if: ${{ !matrix.platform.no-cmake }}
  216. # shell: ${{ matrix.platform.shell }}
  217. run: |
  218. ${{ matrix.platform.source-cmd }}
  219. cmake --build build --config ${{ matrix.platform.cmake-build-type }} --verbose -- ${{ matrix.platform.cmake-build-arguments }}
  220. - name: 'Verify SDL_REVISION'
  221. if: ${{ !matrix.platform.no-cmake }}
  222. run: |
  223. echo "This should show us the SDL_REVISION"
  224. echo "Shared library:"
  225. ${{ (matrix.platform.shared-lib && format('{0} build/{1} | grep "Github Workflow"', matrix.platform.binutils-strings, matrix.platform.shared-lib)) || 'echo "<Shared library not supported by platform>"' }}
  226. echo "Static library:"
  227. ${{ (matrix.platform.static-lib && format('{0} build/{1} | grep "Github Workflow"', matrix.platform.binutils-strings, matrix.platform.static-lib)) || 'echo "<Static library not supported by platform>"' }}
  228. - name: 'Run build-time tests (CMake)'
  229. id: tests
  230. if: ${{ !matrix.platform.no-cmake && matrix.platform.run-tests }}
  231. # shell: ${{ matrix.platform.shell }}
  232. run: |
  233. ${{ matrix.platform.source-cmd }}
  234. ${{ matrix.platform.pretest-cmd }}
  235. set -eu
  236. export SDL_TESTS_QUICK=1
  237. ctest -VV --test-dir build/ -j2
  238. - name: "Build test apk's (CMake)"
  239. id: apks
  240. if: ${{ always() && steps.build.outcome == 'success' && matrix.platform.android-apks != '' }}
  241. # shell: ${{ matrix.platform.shell }}
  242. run: |
  243. ${{ matrix.platform.source-cmd }}
  244. cmake --build build --config ${{ matrix.platform.cmake-build-type }} \
  245. --target \
  246. ${{ matrix.platform.android-apks }} \
  247. --verbose \
  248. -- ${{ matrix.platform.cmake-build-arguments }}
  249. - name: 'Install (CMake)'
  250. id: install
  251. if: ${{ always() && steps.build.outcome == 'success' }}
  252. # shell: ${{ matrix.platform.shell }}
  253. run: |
  254. ${{ matrix.platform.source-cmd }}
  255. cmake --install build --config ${{ matrix.platform.cmake-build-type }}
  256. echo "prefix=$(pwd)/prefix" >> $GITHUB_OUTPUT
  257. ( cd prefix; find . ) | LC_ALL=C sort -u
  258. - name: 'Package (CPack)'
  259. id: package
  260. if: ${{ always() && steps.build.outcome == 'success' }}
  261. # shell: ${{ matrix.platform.shell }}
  262. run: |
  263. # DMG creation on macOS occasionally fails, so try multiple times
  264. # https://gitlab.kitware.com/cmake/cmake/-/issues/25671
  265. success=0
  266. max_tries=10
  267. for i in $(seq $max_tries); do
  268. cmake --build build/ --config ${{ matrix.platform.cmake-build-type }} --target package -- ${{ matrix.platform.cmake-build-arguments }} && success=1
  269. if test $success = 1; then
  270. break
  271. fi
  272. echo "Package creation failed. Sleep 1 second and try again."
  273. sleep 1
  274. done
  275. if test $success = 0; then
  276. echo "Package creation failed after $max_tries attempts."
  277. exit 1
  278. fi
  279. - name: 'Verify CMake configuration files'
  280. if: ${{ steps.install.outcome == 'success' }}
  281. # shell: ${{ matrix.platform.shell }}
  282. run: |
  283. ${{ matrix.platform.source-cmd }}
  284. ${{ matrix.platform.cmake-config-emulator }} cmake -S cmake/test -B cmake_test_build -GNinja \
  285. ${{ matrix.platform.cmake-toolchain-file != '' && format('-DCMAKE_TOOLCHAIN_FILE={0}', matrix.platform.cmake-toolchain-file) || '' }} \
  286. -DTEST_SHARED=${{ matrix.platform.shared }} \
  287. -DTEST_STATIC=${{ matrix.platform.static }} \
  288. ${{ matrix.platform.cmake-arguments }} \
  289. -DCMAKE_BUILD_TYPE=${{ matrix.platform.cmake-build-type }} \
  290. -DCMAKE_PREFIX_PATH="${{ steps.install.outputs.prefix }}"
  291. cmake --build cmake_test_build --verbose --config ${{ matrix.platform.cmake-build-type }} -- ${{ matrix.platform.cmake-build-arguments }}
  292. - name: 'Extract CC/CXX/CFLAGS/CXXFLAGS from CMake toolchain'
  293. if: ${{ steps.install.outcome == 'success' && matrix.platform.cc-from-cmake }}
  294. # shell: ${{ matrix.platform.shell }}
  295. run: |
  296. cmake -S .github/cmake -B /tmp/cmake_extract \
  297. ${{ matrix.platform.cmake-toolchain-file != '' && format('-DCMAKE_TOOLCHAIN_FILE={0}', matrix.platform.cmake-toolchain-file) || '' }} \
  298. -DCMAKE_BUILD_TYPE=${{ matrix.platform.cmake-build-type }} \
  299. -DVAR_PATH=/tmp/env.txt
  300. cat /tmp/env.txt >> $GITHUB_ENV
  301. - name: 'Verify sdl3.pc'
  302. # shell: ${{ matrix.platform.shell }}
  303. if: ${{ steps.install.outcome == 'success' && matrix.platform.test-pkg-config }}
  304. run: |
  305. ${{ matrix.platform.source-cmd }}
  306. ${{ matrix.platform.cc && format('export CC="{0}"', matrix.platform.cc) || '' }}
  307. ${{ matrix.platform.cflags && format('export CFLAGS="{0}"', matrix.platform.cflags) || '' }}
  308. ${{ matrix.platform.ldflags && format('export LDFLAGS="{0}"', matrix.platform.ldflags) || '' }}
  309. export PKG_CONFIG_PATH=${{ steps.install.outputs.prefix }}/lib/pkgconfig
  310. cmake/test/test_pkgconfig.sh
  311. - name: 'Build (cross-platform-actions, BSD)'
  312. id: cpactions
  313. if: ${{ matrix.platform.cpactions }}
  314. uses: cross-platform-actions/action@v0.29.0
  315. with:
  316. operating_system: '${{ matrix.platform.cpactions-os }}'
  317. architecture: '${{ matrix.platform.cpactions-arch }}'
  318. version: '${{ matrix.platform.cpactions-version }}'
  319. run: |
  320. ${{ matrix.platform.cpactions-setup-cmd }}
  321. ${{ matrix.platform.cpactions-install-cmd }}
  322. cmake -S . -B build -GNinja \
  323. ${{ matrix.platform.cmake-toolchain-file != '' && format('-DCMAKE_TOOLCHAIN_FILE={0}', matrix.platform.cmake-toolchain-file) || '' }} \
  324. -Wdeprecated -Wdev -Werror \
  325. -DSDL_WERROR=${{ matrix.platform.werror }} \
  326. -DSDL_INSTALL_DOCS=ON \
  327. ${{ matrix.platform.cmake-arguments }} \
  328. -DSDL_SHARED=${{ matrix.platform.shared }} \
  329. -DSDL_STATIC=${{ matrix.platform.static }} \
  330. -DSDL_VENDOR_INFO="Github Workflow" \
  331. -DCMAKE_INSTALL_PREFIX=prefix \
  332. -DCMAKE_INSTALL_LIBDIR=lib \
  333. -DCMAKE_BUILD_TYPE=${{ matrix.platform.cmake-build-type }}
  334. cmake --build build/ --config ${{ matrix.platform.cmake-build-type }} --verbose
  335. cmake --build build/ --config ${{ matrix.platform.cmake-build-type }} --target package
  336. cmake --build build/ --config ${{ matrix.platform.cmake-build-type }} --target clean
  337. rm -rf build/dist/_CPack_Packages
  338. rm -rf build/CMakeFiles
  339. rm -rf build/docs
  340. - name: Add msbuild to PATH
  341. id: setup-msbuild
  342. if: ${{ matrix.platform.msvc-project != '' }}
  343. uses: microsoft/setup-msbuild@v2
  344. - name: Build msbuild
  345. if: ${{ matrix.platform.msvc-project != '' }}
  346. run: |
  347. "$(cygpath -u '${{ steps.setup-msbuild.outputs.msbuildPath }}\msbuild.exe')" ${{ matrix.platform.msvc-project }} -m -p:BuildInParallel=true -p:Configuration=Release ${{ matrix.platform.msvc-project-flags }}
  348. - name: 'Build (Android.mk)'
  349. if: ${{ matrix.platform.android-mk }}
  350. run: |
  351. ./build-scripts/androidbuildlibs.sh
  352. - name: 'Create Gradle project (Android)'
  353. if: ${{ matrix.platform.android-gradle }}
  354. run: |
  355. for folder in build-ndk-build build-cmake; do
  356. python build-scripts/create-android-project.py \
  357. --output "${folder}" \
  358. --variant copy \
  359. org.libsdl.testspriteminimal \
  360. test/testspriteminimal.c test/icon.h
  361. done
  362. echo ""
  363. echo "Project contents:"
  364. echo ""
  365. find "build-ndk-build/org.libsdl.testspriteminimal"
  366. - name: 'Build Android app (Gradle & ndk-build)'
  367. if: ${{ matrix.platform.android-gradle }}
  368. run: |
  369. cd build-ndk-build/org.libsdl.testspriteminimal
  370. ./gradlew -i assembleRelease
  371. - name: 'Build Android app (Gradle & CMake)'
  372. if: ${{ matrix.platform.android-gradle }}
  373. run: |
  374. cd build-cmake/org.libsdl.testspriteminimal
  375. ./gradlew -i assembleRelease -PBUILD_WITH_CMAKE=1
  376. - name: 'Build (xcode)'
  377. if: ${{ matrix.platform.xcode-sdk != '' }}
  378. run: |
  379. xcodebuild -project Xcode/SDL/SDL.xcodeproj -target SDL3 -configuration Release -sdk ${{ matrix.platform.xcode-sdk }} clean build
  380. - name: 'Prune old ccache files'
  381. if: ${{ matrix.platform.ccache }}
  382. run: |
  383. ccache --evict-older-than=1d
  384. ccache -s
  385. - name: 'Save ccache'
  386. if: ${{ matrix.platform.ccache }}
  387. uses: actions/cache/save@v4
  388. with:
  389. path: ${{ runner.temp }}/ccache
  390. key: ${{ steps.restore-ccache.outputs.cache-primary-key }}
  391. - name: 'Check Sources'
  392. if: ${{ matrix.platform.check-sources }}
  393. run: |
  394. set -e
  395. build-scripts/test-versioning.sh
  396. python build-scripts/check_android_jni.py
  397. python build-scripts/check_stdlib_usage.py
  398. - name: 'Verify alignment of Android test apks'
  399. if: ${{ matrix.platform.android-ndk && !matrix.platform.no-cmake }}
  400. run: |
  401. find ./ -iname '*.apk' | xargs -L1 ./build-scripts/check_elf_alignment.sh
  402. - name: 'Verify alignment of Android .so files'
  403. if: ${{ matrix.platform.android-ndk && !matrix.platform.no-cmake }}
  404. run: |
  405. find ./ -iname '*.so' | xargs -L1 ./build-scripts/check_elf_alignment.sh
  406. - name: 'Upload binary package'
  407. uses: actions/upload-artifact@v4
  408. if: ${{ always() && matrix.platform.artifact != '' && (steps.package.outcome == 'success' || steps.cpactions.outcome == 'success') && (matrix.platform.enable-artifacts || steps.tests.outcome == 'failure') }}
  409. with:
  410. if-no-files-found: error
  411. name: '${{ matrix.platform.artifact }}'
  412. path: |
  413. build/dist/SDL3*
  414. build/include*
  415. - name: 'Upload minidumps'
  416. uses: actions/upload-artifact@v4
  417. if: ${{ always() && steps.tests.outcome == 'failure' && (matrix.platform.platform == 'msvc' || matrix.platform.platform == 'msys2') }}
  418. with:
  419. if-no-files-found: ignore
  420. name: '${{ matrix.platform.artifact }}-minidumps'
  421. path: build/**/*.dmp
  422. - name: "Upload Android test apk's"
  423. uses: actions/upload-artifact@v4
  424. if: ${{ matrix.platform.enable-artifacts && always() && matrix.platform.artifact != '' && steps.apks.outcome == 'success' }}
  425. with:
  426. if-no-files-found: error
  427. name: '${{ matrix.platform.artifact }}-apks'
  428. path: build/test/*.apk