utest_auto_run.yml 13 KB

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