Skip to content

Commit 7aa4331

Browse files
committed
feat: ci script associated with auto_utest.
1 parent ab1f438 commit 7aa4331

File tree

5 files changed

+200
-1
lines changed

5 files changed

+200
-1
lines changed

.github/utest/cpp11/cpp11.cfg

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
CONFIG_UTEST_CPP11_THREAD_TC=y
2+
# dependencies
3+
CONFIG_RT_USING_CI_ACTION=y
4+
CONFIG_RT_USING_CPLUSPLUS=y
5+
CONFIG_RT_USING_CPLUSPLUS11=y

.github/utest/default.cfg

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
CONFIG_RT_USING_CI_ACTION=y

.github/utest/rtsmart/rtsmart.cfg

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
CONFIG_UTEST_MEMHEAP_TC=y
2+
3+
# dependencies
4+
CONFIG_RT_USING_CI_ACTION=y
5+
CONFIG_RT_USING_SMART=y
6+
CONFIG_RT_USING_MEMHEAP=y
7+
CONFIG_RT_USING_DFS_V2=y
Lines changed: 186 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,186 @@
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

components/utilities/utest/utest.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -278,9 +278,9 @@ static void utest_do_run(const char *utest_name)
278278
break;
279279
}
280280

281-
LOG_I("[==========] [ utest ] finished");
282281
LOG_I("[==========] [ utest ] %d tests from %d testcase ran.", tc_run_num, tc_num);
283282
LOG_I("[ PASSED ] [ result ] %d tests.", tc_run_num - tc_fail_num);
283+
LOG_I("[==========] [ utest ] finished");
284284

285285
if(tc_fail_list && (tc_fail_num > 0))
286286
{

0 commit comments

Comments
 (0)