utest_auto_run.yml 18 KB

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