utest_auto_run.yml 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. # Automation utest run script for the QEMU platform
  2. # Generate the corresponding config configuration for CI based on the configuration file under .github/utest.
  3. name: utest_auto_run
  4. on:
  5. push:
  6. branches:
  7. - master
  8. paths-ignore:
  9. - documentation/**
  10. - '**/README.md'
  11. - '**/README_zh.md'
  12. pull_request:
  13. branches:
  14. - master
  15. paths-ignore:
  16. - documentation/**
  17. - '**/README.md'
  18. - '**/README_zh.md'
  19. permissions:
  20. contents: read
  21. jobs:
  22. test:
  23. runs-on: ubuntu-22.04
  24. name: ${{ matrix.platform.UTEST }} :${{ matrix.config_file }}
  25. if: github.repository_owner == 'RT-Thread'
  26. strategy:
  27. fail-fast: false
  28. matrix:
  29. platform:
  30. - { UTEST: "A9", RTT_BSP: "bsp/qemu-vexpress-a9", QEMU_ARCH: "arm", QEMU_MACHINE: "vexpress-a9", SD_FILE: "sd.bin", KERNEL: "standard", "SMP_RUN":"" }
  31. - { UTEST: "A9-rtsmart", RTT_BSP: "bsp/qemu-vexpress-a9", QEMU_ARCH: "arm", QEMU_MACHINE: "vexpress-a9", SD_FILE: "sd.bin", KERNEL: "rtsmart", "SMP_RUN":"" }
  32. - { UTEST: "A9-smp", RTT_BSP: "bsp/qemu-vexpress-a9", QEMU_ARCH: "arm", QEMU_MACHINE: "vexpress-a9", SD_FILE: "sd.bin", KERNEL: "standard", "SMP_RUN":"smp" }
  33. - { UTEST: "RISCV", RTT_BSP: "bsp/qemu-virt64-riscv", QEMU_ARCH: "riscv64", QEMU_MACHINE: "virt", SD_FILE: "None", KERNEL: "standard", "SMP_RUN":"" }
  34. - { UTEST: "RISCV-rtsmart", RTT_BSP: "bsp/qemu-virt64-riscv", QEMU_ARCH: "riscv64", QEMU_MACHINE: "virt", SD_FILE: "None", KERNEL: "rtsmart", "SMP_RUN":"" }
  35. # - { UTEST: "RISCV-smp", RTT_BSP: "bsp/qemu-virt64-riscv", QEMU_ARCH: "riscv64", QEMU_MACHINE: "virt", SD_FILE: "None", KERNEL: "standard", "SMP_RUN":"smp" }
  36. - { UTEST: "XUANTIE-rtsmart", RTT_BSP: "bsp/xuantie/virt64/c906", QEMU_ARCH: "riscv64", QEMU_MACHINE: "virt", SD_FILE: "sd.bin", KERNEL: "rtsmart", "SMP_RUN":"" }
  37. - { UTEST: "AARCH64", RTT_BSP: "bsp/qemu-virt64-aarch64", QEMU_ARCH: "aarch64", QEMU_MACHINE: "virt", SD_FILE: "sd.bin", KERNEL: "standard", "SMP_RUN":"" }
  38. - { UTEST: "AARCH64-rtsmart", RTT_BSP: "bsp/qemu-virt64-aarch64", QEMU_ARCH: "aarch64", QEMU_MACHINE: "virt", SD_FILE: "sd.bin", KERNEL: "rtsmart", "SMP_RUN":"" }
  39. # - { UTEST: "AARCH64-smp", RTT_BSP: "bsp/qemu-virt64-aarch64", QEMU_ARCH: "aarch64", QEMU_MACHINE: "virt", SD_FILE: "sd.bin", KERNEL: "standard", "SMP_RUN":"smp" }
  40. config_file:
  41. - "default.cfg"
  42. # cpp11
  43. # - "cpp11/cpp11.cfg"
  44. env:
  45. TEST_QEMU_ARCH: ${{ matrix.platform.QEMU_ARCH }}
  46. TEST_QEMU_MACHINE: ${{ matrix.platform.QEMU_MACHINE }}
  47. TEST_BSP_ROOT: ${{ matrix.platform.RTT_BSP }}
  48. TEST_CONFIG_FILE: ${{ matrix.config_file }}
  49. TEST_SD_FILE: ${{ matrix.platform.SD_FILE }}
  50. steps:
  51. - uses: actions/checkout@main
  52. - name: Install Tools
  53. shell: bash
  54. run: |
  55. sudo apt-get update
  56. sudo apt-get -yqq install scons qemu-system git
  57. pip3 install kconfiglib
  58. - name: Install ToolChains
  59. shell: bash
  60. run: |
  61. TOOLCHAIN_INSTALLED=""
  62. # Install Arm ToolChains
  63. if [[ "${{ matrix.platform.QEMU_ARCH }}" == "arm" && "${{ matrix.platform.KERNEL }}" == "standard" ]]; then
  64. echo "Starting install Arm ToolChains"
  65. wget -q https://github.com/RT-Thread/toolchains-ci/releases/download/v1.3/gcc-arm-none-eabi-10-2020-q4-major-x86_64-linux.tar.bz2
  66. sudo tar xjf gcc-arm-none-eabi-10-2020-q4-major-x86_64-linux.tar.bz2 -C /opt
  67. /opt/gcc-arm-none-eabi-10-2020-q4-major/bin/arm-none-eabi-gcc --version
  68. echo "RTT_EXEC_PATH=/opt/gcc-arm-none-eabi-10-2020-q4-major/bin" >> $GITHUB_ENV
  69. echo "RTT_CC_PREFIX=arm-none-eabi-" >> $GITHUB_ENV
  70. echo "TOOLCHAIN_INSTALLED=arm" >> $GITHUB_ENV
  71. fi
  72. # Install Arm Musl ToolChains
  73. if [[ "${{ matrix.platform.QEMU_ARCH }}" == "arm" && "${{ matrix.platform.KERNEL }}" == "rtsmart" ]]; then
  74. echo "Starting install Arm Musl ToolChains"
  75. wget -q https://github.com/RT-Thread/toolchains-ci/releases/download/v1.7/arm-linux-musleabi_for_x86_64-pc-linux-gnu_stable.tar.bz2
  76. sudo tar xjf arm-linux-musleabi_for_x86_64-pc-linux-gnu_stable.tar.bz2 -C /opt
  77. /opt/arm-linux-musleabi_for_x86_64-pc-linux-gnu/bin/arm-linux-musleabi-gcc --version
  78. echo "RTT_EXEC_PATH=/opt/arm-linux-musleabi_for_x86_64-pc-linux-gnu/bin" >> $GITHUB_ENV
  79. echo "RTT_CC_PREFIX=arm-linux-musleabi-" >> $GITHUB_ENV
  80. echo "TOOLCHAIN_INSTALLED=arm-musl" >> $GITHUB_ENV
  81. fi
  82. # Install RISC-V ToolChains
  83. if [[ "${{ matrix.platform.QEMU_ARCH }}" == "riscv64" && "${{ matrix.platform.KERNEL }}" == "standard" ]]; then
  84. echo "Starting install RISC-V ToolChains"
  85. wget -q https://github.com/RT-Thread/toolchains-ci/releases/download/v1.4/riscv64-unknown-elf-toolchain-10.2.0-2020.12.8-x86_64-linux-ubuntu14.tar.gz
  86. sudo tar zxvf riscv64-unknown-elf-toolchain-10.2.0-2020.12.8-x86_64-linux-ubuntu14.tar.gz -C /opt
  87. /opt/riscv64-unknown-elf-toolchain-10.2.0-2020.12.8-x86_64-linux-ubuntu14/bin/riscv64-unknown-elf-gcc --version
  88. echo "RTT_EXEC_PATH=/opt/riscv64-unknown-elf-toolchain-10.2.0-2020.12.8-x86_64-linux-ubuntu14/bin" >> $GITHUB_ENV
  89. echo "TOOLCHAIN_INSTALLED=riscv" >> $GITHUB_ENV
  90. fi
  91. # Install RISC-V Musl ToolChains
  92. if [[ "${{ matrix.platform.QEMU_ARCH }}" == "riscv64" && "${{ matrix.platform.KERNEL }}" == "rtsmart" ]]; then
  93. echo "Starting install RISC-V Musl ToolChains"
  94. wget -q https://github.com/RT-Thread/toolchains-ci/releases/download/v1.7/riscv64-linux-musleabi_for_x86_64-pc-linux-gnu_latest.tar.bz2
  95. sudo tar xjf riscv64-linux-musleabi_for_x86_64-pc-linux-gnu_latest.tar.bz2 -C /opt
  96. /opt/riscv64-linux-musleabi_for_x86_64-pc-linux-gnu/bin/riscv64-unknown-linux-musl-gcc --version
  97. echo "RTT_EXEC_PATH=/opt/riscv64-linux-musleabi_for_x86_64-pc-linux-gnu/bin" >> $GITHUB_ENV
  98. echo "RTT_CC_PREFIX=riscv64-unknown-linux-musl-" >> $GITHUB_ENV
  99. echo "TOOLCHAIN_INSTALLED=riscv-musl" >> $GITHUB_ENV
  100. fi
  101. # Install RISC-V XUANTIE Musl ToolChains
  102. if [[ "${{ matrix.platform.UTEST }}" == "XUANTIE-rtsmart" && "${{ matrix.platform.QEMU_ARCH }}" == "riscv64" && "${{ matrix.platform.KERNEL }}" == "rtsmart" ]]; then
  103. echo "Starting install RISC-V XUANTIE Musl ToolChains"
  104. wget -q https://github.com/RT-Thread/toolchains-ci/releases/download/v1.9/Xuantie-900-gcc-linux-6.6.0-musl64-x86_64-V3.0.2.tar.gz
  105. sudo tar zxvf Xuantie-900-gcc-linux-6.6.0-musl64-x86_64-V3.0.2.tar.gz -C /opt
  106. /opt/Xuantie-900-gcc-linux-6.6.0-musl64-x86_64-V3.0.2/bin/riscv64-unknown-linux-musl-gcc --version
  107. echo "RTT_EXEC_PATH=/opt/Xuantie-900-gcc-linux-6.6.0-musl64-x86_64-V3.0.2/bin" >> $GITHUB_ENV
  108. echo "RTT_CC_PREFIX=riscv64-unknown-linux-musl-" >> $GITHUB_ENV
  109. echo "TOOLCHAIN_INSTALLED=riscv-musl" >> $GITHUB_ENV
  110. fi
  111. # Install AARCH64 ToolChains
  112. if [[ "${{ matrix.platform.QEMU_ARCH }}" == "aarch64" && "${{ matrix.platform.KERNEL }}" == "standard" ]]; then
  113. echo "Starting install AARCH64 ToolChains"
  114. wget -q https://github.com/RT-Thread/toolchains-ci/releases/download/v1.6/gcc-arm-10.2-2020.11-x86_64-aarch64-none-elf.tar.xz
  115. sudo tar -xvJf gcc-arm-10.2-2020.11-x86_64-aarch64-none-elf.tar.xz -C /opt
  116. /opt/gcc-arm-10.2-2020.11-x86_64-aarch64-none-elf/bin/aarch64-none-elf-gcc --version
  117. echo "RTT_EXEC_PATH=/opt/gcc-arm-10.2-2020.11-x86_64-aarch64-none-elf/bin" >> $GITHUB_ENV
  118. echo "RTT_CC_PREFIX=aarch64-none-elf-" >> $GITHUB_ENV
  119. echo "TOOLCHAIN_INSTALLED=aarch64" >> $GITHUB_ENV
  120. fi
  121. # Install AARCH64 Musl ToolChains
  122. if [[ "${{ matrix.platform.QEMU_ARCH }}" == "aarch64" && "${{ matrix.platform.KERNEL }}" == "rtsmart" ]]; then
  123. echo "Starting install AARCH64 Musl ToolChains"
  124. wget -q https://github.com/RT-Thread/toolchains-ci/releases/download/v1.7/aarch64-linux-musleabi_for_x86_64-pc-linux-gnu_stable.tar.bz2
  125. sudo tar xjf aarch64-linux-musleabi_for_x86_64-pc-linux-gnu_stable.tar.bz2 -C /opt
  126. /opt/aarch64-linux-musleabi_for_x86_64-pc-linux-gnu/bin/aarch64-linux-musleabi-gcc --version
  127. echo "RTT_EXEC_PATH=/opt/aarch64-linux-musleabi_for_x86_64-pc-linux-gnu/bin" >> $GITHUB_ENV
  128. echo "RTT_CC_PREFIX=aarch64-linux-musleabi-" >> $GITHUB_ENV
  129. echo "TOOLCHAIN_INSTALLED=aarch64-musl" >> $GITHUB_ENV
  130. fi
  131. # Install CPP11 Preprocessing Toolchain
  132. if [[ "${{ matrix.platform.QEMU_ARCH }}" == "arm" && "${{ matrix.config_file }}" == "cpp11/cpp11.cfg" && "${{ matrix.platform.KERNEL }}" == "standard" ]]; then
  133. sudo rm -f /opt/gcc-arm-none-eabi-10-2020-q4-major/arm-none-eabi/include/c++/10.2.1/thread
  134. sudo rm -f /opt/gcc-arm-none-eabi-10-2020-q4-major/arm-none-eabi/include/c++/10.2.1/mutex
  135. sudo rm -f /opt/gcc-arm-none-eabi-10-2020-q4-major/arm-none-eabi/include/c++/10.2.1/condition_variable
  136. sudo rm -f /opt/gcc-arm-none-eabi-10-2020-q4-major/arm-none-eabi/include/c++/10.2.1/future
  137. sudo rm -f /opt/gcc-arm-none-eabi-10-2020-q4-major/arm-none-eabi/include/pthread.h
  138. sudo cat /dev/null > /opt/gcc-arm-none-eabi-10-2020-q4-major/arm-none-eabi/include/sys/_pthreadtypes.h
  139. sed -i 's/-fno-exceptions/ /g' $TEST_BSP_ROOT/rtconfig.py
  140. fi
  141. if [ "$TOOLCHAIN_INSTALLED" == "None" ]; then
  142. echo "No valid toolchain installed, stopping the workflow."
  143. fi
  144. - name: Build BSP
  145. if: ${{ env.TOOLCHAIN_INSTALLED != '' && success() }}
  146. run: |
  147. # Whether plan to run SMP?
  148. if [[ "${{ matrix.platform.SMP_RUN }}" == "smp" ]]; then
  149. cat .github/utest/smp/smp.cfg >> $TEST_BSP_ROOT/.config
  150. fi
  151. # Is the kernel rtsmart?
  152. if [[ "${{ matrix.platform.KERNEL }}" == "rtsmart" ]]; then
  153. cat .github/utest/rtsmart/rtsmart.cfg >> $TEST_BSP_ROOT/.config
  154. fi
  155. echo CONFIG_RT_USING_UTESTCASES=y >> $TEST_BSP_ROOT/.config
  156. cat .github/utest/$TEST_CONFIG_FILE >> $TEST_BSP_ROOT/.config
  157. scons --pyconfig-silent -C $TEST_BSP_ROOT
  158. scons -j$(nproc) --strict -C $TEST_BSP_ROOT
  159. - name: QEMU Run Test
  160. if: ${{ env.TOOLCHAIN_INSTALLED != '' && success() }}
  161. run: |
  162. if [ "$TEST_SD_FILE" != "None" ]; then
  163. dd if=/dev/zero of=$TEST_BSP_ROOT/sd.bin bs=1024 count=65536
  164. mkfs.fat $TEST_BSP_ROOT/sd.bin
  165. fi
  166. if [[ "${{ matrix.platform.QEMU_ARCH }}" == "aarch64" ]]; then
  167. qemu-system-$TEST_QEMU_ARCH -M virt,gic-version=2 -cpu cortex-a53 -smp 4 -kernel $TEST_BSP_ROOT/rtthread.bin -nographic \
  168. -drive if=none,file=$TEST_BSP_ROOT/sd.bin,format=raw,id=blk0 -device virtio-blk-device,drive=blk0,bus=virtio-mmio-bus.0 \
  169. -netdev user,id=net0 -device virtio-net-device,netdev=net0,bus=virtio-mmio-bus.1 \
  170. > qemu_output_$TEST_QEMU_ARCH.log 2>&1 &
  171. elif [[ "${{ matrix.platform.UTEST }}" == "XUANTIE-rtsmart" ]]; then
  172. sudo apt-get install -y dos2unix libcapstone-dev libbrlapi-dev
  173. wget -q https://occ-oss-prod.oss-cn-hangzhou.aliyuncs.com/resource//1736318325160/Xuantie-qemu-x86_64-Ubuntu-20.04-V5.0.5-B20250108-0335.tar.gz
  174. tar zxvf Xuantie-qemu-x86_64-Ubuntu-20.04-V5.0.5-B20250108-0335.tar.gz
  175. dos2unix ./install/qemu_post_install_small.sh
  176. sudo chmod +x ./install/qemu_post_install_small.sh
  177. sudo ./install/qemu_post_install_small.sh
  178. QEMU_BIN="./install/bin/qemu-system-$TEST_QEMU_ARCH"
  179. [ ! -f "$QEMU_BIN" ] && echo "ERROR: $QEMU_BIN not found." && exit 1
  180. tmp_output=$(mktemp)
  181. ldd "$QEMU_BIN" > "$tmp_output" 2>&1
  182. missing_libs=$(grep "not found" "$tmp_output" | awk '{print $1}')
  183. for lib in $missing_libs; do
  184. base_lib=$(echo "$lib" | sed -E 's/\.so.*/\.so/')
  185. echo "🔍 修复基础库:$base_lib ..."
  186. sudo ln -s /usr/lib/x86_64-linux-gnu/$base_lib /usr/lib/x86_64-linux-gnu/$lib
  187. done
  188. echo "✅ 所有缺失库已处理。"
  189. $QEMU_BIN -cpu c906fd -M $TEST_QEMU_MACHINE -kernel $TEST_BSP_ROOT/rtthread.bin -nographic \
  190. -drive if=none,file=$TEST_BSP_ROOT/sd.bin,format=raw,id=blk0 -device virtio-blk-device,drive=blk0,bus=virtio-mmio-bus.0 \
  191. > qemu_output_$TEST_QEMU_ARCH.log 2>&1 &
  192. elif [[ "${{ matrix.platform.QEMU_ARCH }}" == "arm" ]]; then
  193. qemu-system-$TEST_QEMU_ARCH \
  194. -nographic \
  195. -M $TEST_QEMU_MACHINE \
  196. -kernel $TEST_BSP_ROOT/rtthread.bin \
  197. -sd $TEST_BSP_ROOT/sd.bin \
  198. > qemu_output_$TEST_QEMU_ARCH.log 2>&1 &
  199. else
  200. qemu-system-$TEST_QEMU_ARCH \
  201. -nographic \
  202. -M $TEST_QEMU_MACHINE \
  203. -kernel $TEST_BSP_ROOT/rtthread.bin \
  204. > qemu_output_$TEST_QEMU_ARCH.log 2>&1 &
  205. fi
  206. QEMU_PID=$!
  207. disown $QEMU_PID
  208. - name: Monitor qemu log
  209. if: ${{ env.TOOLCHAIN_INSTALLED != '' && success() }}
  210. run: |
  211. FAILURE_DETECTED=false
  212. ERROR_LOGS=""
  213. echo "=========================================================================================="
  214. echo " || || "
  215. echo " || Start automatic running of Utest || "
  216. echo " VV VV "
  217. echo "=========================================================================================="
  218. tail -n 0 -f qemu_output_$TEST_QEMU_ARCH.log | while read line; do
  219. echo $line
  220. if [[ "$line" == *"[ FAILED ] [ result ]"* ]]; then
  221. ERROR_LOGS="$ERROR_LOGS$line"$'\n'
  222. FAILURE_DETECTED=true
  223. fi
  224. if [[ "$line" == *"[==========] [ utest ] finished"* ]]; then
  225. if $FAILURE_DETECTED; then
  226. echo "=========================================================================================="
  227. echo " || || "
  228. echo " || Error: Failures detected in logs. Below are the failure details... || "
  229. echo " VV VV "
  230. echo "=========================================================================================="
  231. echo "$ERROR_LOGS"
  232. exit 1
  233. fi
  234. echo "=========================================================================================="
  235. echo " Successed: Utest run completed. Exiting log monitoring "
  236. echo "=========================================================================================="
  237. break
  238. fi
  239. done