utest_auto_run.yml 16 KB

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