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+
4+ name : action_auto_utest
5+
6+ on :
7+ push :
8+ branches :
9+ - master
10+ paths-ignore :
11+ - documentation/**
12+ - ' **/README.md'
13+ - ' **/README_zh.md'
14+ pull_request :
15+ branches :
16+ - master
17+ paths-ignore :
18+ - documentation/**
19+ - ' **/README.md'
20+ - ' **/README_zh.md'
21+
22+ permissions :
23+ contents : read
24+
25+ jobs :
26+ test :
27+ runs-on : ubuntu-22.04
28+ name : ${{ matrix.platform.UTEST }}-${{ matrix.platform.KERNEL }} - ${{ matrix.config_file }}
29+ if : github.repository_owner == 'RT-Thread'
30+ strategy :
31+ fail-fast : false
32+ matrix :
33+ platform :
34+ - { UTEST: "qemu-vexpress-a9", RTT_BSP: "bsp/qemu-vexpress-a9", QEMU_ARCH: "arm", QEMU_MACHINE: "vexpress-a9", SD_FILE: "sd.bin", RUN: "yes", KERNEL: "standard" }
35+ - { UTEST: "qemu-virt64-riscv", RTT_BSP: "bsp/qemu-virt64-riscv", QEMU_ARCH: "riscv64", QEMU_MACHINE: "virt", SD_FILE: "None", RUN: "yes", KERNEL: "standard" }
36+ - { UTEST: "qemu-virt64-aarch64", RTT_BSP: "bsp/qemu-virt64-aarch64", QEMU_ARCH: "aarch64", QEMU_MACHINE: "virt", SD_FILE: "sd.bin", RUN: "yes", KERNEL: "rtsmart" }
37+ config_file :
38+ - " default.cfg"
39+
40+ # kernel
41+ - " kernel/atomic_c11.cfg"
42+ - " kernel/atomic.cfg"
43+ - " kernel/device.cfg"
44+ - " kernel/ipc.cfg"
45+ - " kernel/irq.cfg"
46+ - " kernel/mem.cfg"
47+ - " kernel/thread.cfg"
48+ - " kernel/timer.cfg"
49+
50+ # cpp11
51+ - " cpp11/cpp11.cfg"
52+
53+ # rtsmart
54+ - " rtsmart/rtsmart.cfg"
55+
56+ env :
57+ TEST_QEMU_ARCH : ${{ matrix.platform.QEMU_ARCH }}
58+ TEST_QEMU_MACHINE : ${{ matrix.platform.QEMU_MACHINE }}
59+ TEST_BSP_ROOT : ${{ matrix.platform.RTT_BSP }}
60+ TEST_CONFIG_FILE : ${{ matrix.config_file }}
61+ TEST_SD_FILE : ${{ matrix.platform.SD_FILE }}
62+ RUN_FLAG : ${{ RUN_FLAG }}
63+ KERNEL_FLAG : ${{ matrix.platform.KERNEL }}
64+ steps :
65+ - uses : actions/checkout@v4
66+
67+ - name : Install Tools
68+ shell : bash
69+ run : |
70+ sudo apt-get update
71+ sudo apt-get -yqq install scons qemu-system git
72+ pip3 install kconfiglib
73+
74+ - name : Install ToolChains
75+ shell : bash
76+ run : |
77+ TOOLCHAIN_INSTALLED=""
78+
79+ # Install Arm ToolChains
80+ if [ TEST_QEMU_ARCH == "arm" && KERNEL_FLAG == "standard" && TEST_CONFIG_FILE != "rtsmart/rtsmart.cfg" ]; then
81+ 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
82+ sudo tar xjf gcc-arm-none-eabi-10-2020-q4-major-x86_64-linux.tar.bz2 -C /opt
83+ /opt/gcc-arm-none-eabi-10-2020-q4-major/bin/arm-none-eabi-gcc --version
84+ echo "RTT_EXEC_PATH=/opt/gcc-arm-none-eabi-10-2020-q4-major/bin" >> $GITHUB_ENV
85+ echo "RTT_CC_PREFIX=arm-none-eabi-" >> $GITHUB_ENV
86+ echo "TOOLCHAIN_INSTALLED=arm" >> $GITHUB_ENV
87+ fi
88+
89+ # Install Arm Musl ToolChains
90+ if [ TEST_QEMU_ARCH == "arm" && KERNEL_FLAG == "rtsmart" && TEST_CONFIG_FILE == "rtsmart/rtsmart.cfg" ]; then
91+ 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
92+ sudo tar xjf arm-linux-musleabi_for_x86_64-pc-linux-gnu_stable.tar.bz2 -C /opt
93+ /opt/arm-linux-musleabi_for_x86_64-pc-linux-gnu/bin/arm-linux-musleabi-gcc --version
94+ echo "RTT_EXEC_PATH=/opt/arm-linux-musleabi_for_x86_64-pc-linux-gnu/bin" >> $GITHUB_ENV
95+ echo "RTT_CC_PREFIX=arm-linux-musleabi-" >> $GITHUB_ENV
96+ echo "TOOLCHAIN_INSTALLED=arm-musl" >> $GITHUB_ENV
97+ fi
98+
99+ # Install RISC-V ToolChains
100+ if [ "TEST_QEMU_ARCH == "riscv64" && KERNEL_FLAG == "standard" && TEST_CONFIG_FILE != "rtsmart/rtsmart.cfg" ]; then
101+ 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
102+ sudo tar zxvf riscv64-unknown-elf-toolchain-10.2.0-2020.12.8-x86_64-linux-ubuntu14.tar.gz -C /opt
103+ /opt/riscv64-unknown-elf-toolchain-10.2.0-2020.12.8-x86_64-linux-ubuntu14/bin/riscv64-unknown-elf-gcc --version
104+ echo "RTT_EXEC_PATH=/opt/riscv64-unknown-elf-toolchain-10.2.0-2020.12.8-x86_64-linux-ubuntu14/bin" >> $GITHUB_ENV
105+ echo "TOOLCHAIN_INSTALLED=riscv" >> $GITHUB_ENV
106+ fi
107+
108+ # Install RISC-V Musl ToolChains
109+ if [ TEST_QEMU_ARCH == "riscv64" && KERNEL_FLAG == "rtsmart" && TEST_CONFIG_FILE == "rtsmart/rtsmart.cfg" ]; then
110+ 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
111+ sudo tar xjf riscv64-linux-musleabi_for_x86_64-pc-linux-gnu_latest.tar.bz2 -C /opt
112+ /opt/riscv64-linux-musleabi_for_x86_64-pc-linux-gnu/bin/riscv64-unknown-linux-musl-gcc --version
113+ echo "RTT_EXEC_PATH=/opt/riscv64-linux-musleabi_for_x86_64-pc-linux-gnu/bin" >> $GITHUB_ENV
114+ echo "RTT_CC_PREFIX=riscv64-unknown-linux-musl-" >> $GITHUB_ENV
115+ echo "TOOLCHAIN_INSTALLED=riscv-musl" >> $GITHUB_ENV
116+ fi
117+
118+ # Install AARCH64 Musl ToolChains
119+ if [ TEST_QEMU_ARCH == "aarch64" && KERNEL_FLAG == "rtsmart" && TEST_CONFIG_FILE == "rtsmart/rtsmart.cfg" ]; then
120+ 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
121+ sudo tar xjf aarch64-linux-musleabi_for_x86_64-pc-linux-gnu_stable.tar.bz2 -C /opt
122+ /opt/aarch64-linux-musleabi_for_x86_64-pc-linux-gnu/bin/aarch64-linux-musleabi-gcc --version
123+ echo "RTT_EXEC_PATH=/opt/aarch64-linux-musleabi_for_x86_64-pc-linux-gnu/bin" >> $GITHUB_ENV
124+ echo "RTT_CC_PREFIX=aarch64-linux-musleabi-" >> $GITHUB_ENV
125+ echo "TOOLCHAIN_INSTALLED=aarch64-musl" >> $GITHUB_ENV
126+ fi
127+
128+ # Install CPP11 Preprocessing Toolchain
129+ if [ TEST_QEMU_ARCH == "arm" && TEST_CONFIG_FILE == "cpp11/cpp11.cfg" ]; then
130+ sudo rm -f /opt/gcc-arm-none-eabi-10-2020-q4-major/arm-none-eabi/include/c++/10.2.1/thread
131+ sudo rm -f /opt/gcc-arm-none-eabi-10-2020-q4-major/arm-none-eabi/include/c++/10.2.1/mutex
132+ sudo rm -f /opt/gcc-arm-none-eabi-10-2020-q4-major/arm-none-eabi/include/c++/10.2.1/condition_variable
133+ sudo rm -f /opt/gcc-arm-none-eabi-10-2020-q4-major/arm-none-eabi/include/c++/10.2.1/future
134+ sudo rm -f /opt/gcc-arm-none-eabi-10-2020-q4-major/arm-none-eabi/include/pthread.h
135+ sudo cat /dev/null > /opt/gcc-arm-none-eabi-10-2020-q4-major/arm-none-eabi/include/sys/_pthreadtypes.h
136+ sed -i 's/-fno-exceptions/ /g' $TEST_BSP_ROOT/rtconfig.py
137+ fi
138+
139+ if [[ -z "$TOOLCHAIN_INSTALLED" ]]; then
140+ echo "No valid toolchain installed, stopping the workflow."
141+ fi
142+
143+ - name : Build BSP
144+ if : ${{ RUN_FLAG == 'yes' && env.TOOLCHAIN_INSTALLED != '' && success() }}
145+ run : |
146+ echo CONFIG_RT_USING_UTESTCASES=y >> $TEST_BSP_ROOT/.config
147+ cat .github/utest/$TEST_CONFIG_FILE >> $TEST_BSP_ROOT/.config
148+ scons --pyconfig-silent -C $TEST_BSP_ROOT
149+ scons -j$(nproc) --strict -C $TEST_BSP_ROOT
150+
151+ - name : QEMU Run Test
152+ if : ${{ RUN_FLAG == 'yes' && env.TOOLCHAIN_INSTALLED != '' && success() }}
153+ run : |
154+ if [ "$TEST_SD_FILE" != "None" ]; then
155+ dd if=/dev/zero of=$TEST_BSP_ROOT/sd.bin bs=1024 count=65536
156+ qemu-system-$TEST_QEMU_ARCH -nographic -M $TEST_QEMU_MACHINE -kernel $TEST_BSP_ROOT/rtthread.bin -nographic -sd $TEST_BSP_ROOT/sd.bin > qemu_output_${TEST_QEMU_ARCH}.log 2>&1 &
157+ else
158+ qemu-system-$TEST_QEMU_ARCH -nographic -M $TEST_QEMU_MACHINE -kernel $TEST_BSP_ROOT/rtthread.bin -nographic > qemu_output_${TEST_QEMU_ARCH}.log 2>&1 &
159+ fi
160+
161+ QEMU_PID=$!
162+ disown $QEMU_PID
163+
164+ - name : Monitor qemu log
165+ if : ${{ RUN_FLAG == 'yes' && env.TOOLCHAIN_INSTALLED != '' && success() }}
166+ run : |
167+ FAILURE_DETECTED=false
168+ ERROR_LOGS=""
169+
170+ tail -n 0 -f qemu_output_${TEST_QEMU_ARCH}.log | while read line; do
171+ echo $line
172+ if [[ "$line" == *"[ FAILED ] [ result ]"* ]]; then
173+ ERROR_LOGS="$ERROR_LOGS$line"$'\n'
174+ FAILURE_DETECTED=true
175+ fi
176+
177+ if [[ "$line" == *"[==========] [ utest ] finished"* ]]; then
178+ echo "Utest run completed. Exiting log monitoring..."
179+ if $FAILURE_DETECTED; then
180+ echo "Error: Failures detected in logs. Below are the failure details..."
181+ echo "$ERROR_LOGS"
182+ exit 1
183+ fi
184+ break
185+ fi
186+ done
0 commit comments