commit
9599739b7e
|
@ -0,0 +1,94 @@
|
||||||
|
name: CI
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- master
|
||||||
|
pull_request:
|
||||||
|
types:
|
||||||
|
- opened
|
||||||
|
- synchronize
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
unit-tests_1:
|
||||||
|
name: "unit-tests (group 1)"
|
||||||
|
uses: ./.github/workflows/unit-test.yml
|
||||||
|
with:
|
||||||
|
total-groups: 2
|
||||||
|
current-group: 1
|
||||||
|
secrets: inherit
|
||||||
|
|
||||||
|
unit-tests_2:
|
||||||
|
name: "unit-tests (group 2)"
|
||||||
|
uses: ./.github/workflows/unit-test.yml
|
||||||
|
with:
|
||||||
|
total-groups: 2
|
||||||
|
current-group: 2
|
||||||
|
secrets: inherit
|
||||||
|
|
||||||
|
scan-build:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
container:
|
||||||
|
image: signalwire/freeswitch-public-base:bookworm
|
||||||
|
credentials:
|
||||||
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
||||||
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
||||||
|
options: --privileged
|
||||||
|
env:
|
||||||
|
REPOTOKEN: ${{ secrets.REPOTOKEN }}
|
||||||
|
DEBIAN_FRONTEND: noninteractive
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Install dependencies
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
echo "machine freeswitch.signalwire.com password $REPOTOKEN" > /etc/apt/auth.conf && \
|
||||||
|
apt-get update && \
|
||||||
|
apt-get -y remove \
|
||||||
|
libsofia-sip-ua0 \
|
||||||
|
libspandsp-dev && \
|
||||||
|
apt-get -y install \
|
||||||
|
autoconf \
|
||||||
|
libsofia-sip-ua-dev \
|
||||||
|
libspandsp3-dev && \
|
||||||
|
rm -rf /etc/apt/auth.conf
|
||||||
|
|
||||||
|
- name: Checkout code
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
path: /__w/freeswitch/freeswitch
|
||||||
|
|
||||||
|
- name: Bootstrap
|
||||||
|
shell: bash
|
||||||
|
working-directory: /__w/freeswitch/freeswitch
|
||||||
|
run: |
|
||||||
|
./bootstrap.sh -j || exit 1
|
||||||
|
|
||||||
|
- name: Scan-build FreeSwitch
|
||||||
|
shell: bash
|
||||||
|
working-directory: /__w/freeswitch/freeswitch
|
||||||
|
run: |
|
||||||
|
cp build/modules.conf.most modules.conf && \
|
||||||
|
echo 'codecs/mod_openh264' >> modules.conf && \
|
||||||
|
sed -i \
|
||||||
|
-e '/mod_mariadb/s/^#//g' \
|
||||||
|
-e '/mod_v8/s/^#//g' \
|
||||||
|
-e '/mod_ilbc/s/^/#/g' \
|
||||||
|
-e '/mod_isac/s/^/#/g' \
|
||||||
|
-e '/mod_mp4/s/^/#/g' \
|
||||||
|
-e '/mod_mongo/s/^/#/g' \
|
||||||
|
-e '/mod_pocketsphinx/s/^/#/g' \
|
||||||
|
-e '/mod_sangoma_codec/s/^/#/g' \
|
||||||
|
-e '/mod_siren/s/^/#/g' \
|
||||||
|
-e '/mod_avmd/s/^/#/g' \
|
||||||
|
-e '/mod_basic/s/^/#/g' \
|
||||||
|
-e '/mod_cdr_mongodb/s/^/#/g' \
|
||||||
|
-e '/mod_cv/s/^/#/g' \
|
||||||
|
-e '/mod_erlang_event/s/^/#/g' \
|
||||||
|
-e '/mod_perl/s/^/#/g' \
|
||||||
|
-e '/mod_rtmp/s/^/#/g' \
|
||||||
|
-e '/mod_unimrcp/s/^/#/g' \
|
||||||
|
-e '/mod_xml_rpc/s/^/#/g' \
|
||||||
|
modules.conf && \
|
||||||
|
./configure && \
|
||||||
|
./scan_build.sh
|
|
@ -0,0 +1,111 @@
|
||||||
|
name: Unit tests
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_call:
|
||||||
|
inputs:
|
||||||
|
total-groups:
|
||||||
|
description: 'Total number of test groups'
|
||||||
|
required: true
|
||||||
|
type: number
|
||||||
|
current-group:
|
||||||
|
description: 'Current test group number'
|
||||||
|
required: true
|
||||||
|
type: number
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
unit-tests:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
container:
|
||||||
|
image: signalwire/freeswitch-public-base:bookworm
|
||||||
|
credentials:
|
||||||
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
||||||
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
||||||
|
options: --privileged
|
||||||
|
env:
|
||||||
|
DEBIAN_FRONTEND: noninteractive
|
||||||
|
ASAN_OPTIONS: log_path=stdout:disable_coredump=0:unmap_shadow_on_exit=1:fast_unwind_on_malloc=0
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Override core_pattern
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
cat /proc/sys/kernel/core_pattern
|
||||||
|
echo '/cores/core.%s.%E.%e.%p.%t' > /proc/sys/kernel/core_pattern
|
||||||
|
cat /proc/sys/kernel/core_pattern
|
||||||
|
|
||||||
|
- name: Install dependencies
|
||||||
|
shell: bash
|
||||||
|
env:
|
||||||
|
REPOTOKEN: ${{ secrets.REPOTOKEN }}
|
||||||
|
run: |
|
||||||
|
echo "machine freeswitch.signalwire.com password $REPOTOKEN" > /etc/apt/auth.conf && \
|
||||||
|
apt-get update && \
|
||||||
|
apt-get -y remove \
|
||||||
|
libsofia-sip-ua0 \
|
||||||
|
libspandsp-dev && \
|
||||||
|
apt-get -y install \
|
||||||
|
libspandsp3-dev && \
|
||||||
|
rm -rf /etc/apt/auth.conf
|
||||||
|
|
||||||
|
- name: Checkout code
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
path: /__w/freeswitch/freeswitch
|
||||||
|
|
||||||
|
- name: Bootstrap
|
||||||
|
shell: bash
|
||||||
|
working-directory: /__w/freeswitch/freeswitch
|
||||||
|
run: |
|
||||||
|
./bootstrap.sh -j || exit 1
|
||||||
|
|
||||||
|
- name: Checkout Sofia-Sip
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
repository: freeswitch/sofia-sip
|
||||||
|
path: /__w/freeswitch/freeswitch/sofia-sip
|
||||||
|
|
||||||
|
- name: Build sofia-sip
|
||||||
|
shell: bash
|
||||||
|
working-directory: /__w/freeswitch/freeswitch/sofia-sip
|
||||||
|
run: |
|
||||||
|
./autogen.sh && \
|
||||||
|
./configure.gnu && \
|
||||||
|
make -j$(nproc --all) install
|
||||||
|
|
||||||
|
- name: Build FreeSwitch
|
||||||
|
shell: bash
|
||||||
|
working-directory: /__w/freeswitch/freeswitch
|
||||||
|
run: |
|
||||||
|
echo 'codecs/mod_openh264' >> modules.conf && \
|
||||||
|
sed -i \
|
||||||
|
-e '/applications\/mod_http_cache/s/^#//g' \
|
||||||
|
-e '/event_handlers\/mod_rayo/s/^#//g' \
|
||||||
|
-e '/formats\/mod_opusfile/s/^#//g' \
|
||||||
|
-e '/languages\/mod_lua/s/^#//g' \
|
||||||
|
modules.conf && \
|
||||||
|
./configure \
|
||||||
|
--enable-address-sanitizer \
|
||||||
|
--enable-fake-dlclose && \
|
||||||
|
make -j$(nproc --all) |& tee ./unit-tests-build-result.txt
|
||||||
|
|
||||||
|
echo ${PIPESTATUS[0]} > ./build-status.txt
|
||||||
|
if ! test "$(cat ./build-status.txt | tr -d '[:space:]')" -eq 0; then
|
||||||
|
exit "$(cat ./build-status.txt | tr -d '[:space:]')"
|
||||||
|
fi
|
||||||
|
make install
|
||||||
|
|
||||||
|
- name: Run tests
|
||||||
|
shell: bash
|
||||||
|
working-directory: /__w/freeswitch/freeswitch/tests/unit
|
||||||
|
run: |
|
||||||
|
./run-tests.sh ${{ inputs.total-groups }} ${{ inputs.current-group }}
|
||||||
|
mkdir logs && (mv log_run-tests_*.html logs || true) && (mv backtrace_*.txt logs || true)
|
||||||
|
./collect-test-logs.sh
|
||||||
|
|
||||||
|
- name: Notify result
|
||||||
|
if: failure()
|
||||||
|
uses: signalwire/actions-template/.github/actions/notify-ci-result@main
|
||||||
|
with:
|
||||||
|
for: "run_tests"
|
||||||
|
test_logs_path: /__w/freeswitch/freeswitch/tests/unit
|
||||||
|
test_artifacts_suffix: "-${{ inputs.current-group }}"
|
|
@ -0,0 +1,28 @@
|
||||||
|
#!/bin/bash
|
||||||
|
mkdir -p scan-build
|
||||||
|
scan-build-14 --force-analyze-debug-code -o ./scan-build/ make -j`nproc --all` |& tee ./scan-build-result.txt
|
||||||
|
exitstatus=${PIPESTATUS[0]}
|
||||||
|
echo "*** Exit status is $exitstatus"
|
||||||
|
export SubString="scan-build: No bugs found"
|
||||||
|
export COMPILATION_FAILED="false"
|
||||||
|
export BUGS_FOUND="false"
|
||||||
|
if [[ "0" != "$exitstatus" ]] ; then
|
||||||
|
export COMPILATION_FAILED="true"
|
||||||
|
echo MESSAGE="compilation failed" >> $GITHUB_OUTPUT
|
||||||
|
fi
|
||||||
|
export RESULTFILE="$PWD/scan-build-result.txt"
|
||||||
|
# cat $RESULTFILE
|
||||||
|
if ! grep -sq "$SubString" $RESULTFILE; then
|
||||||
|
export BUGS_FOUND="true"
|
||||||
|
echo MESSAGE="found bugs" >> $GITHUB_OUTPUT
|
||||||
|
fi
|
||||||
|
export REPORT=$PWD/`find scan-build* -mindepth 1 -type d`
|
||||||
|
echo "COMPILATION_FAILED: $COMPILATION_FAILED"
|
||||||
|
echo "BUGS_FOUND: $BUGS_FOUND"
|
||||||
|
echo "COMPILATION_FAILED=$COMPILATION_FAILED" >> $GITHUB_OUTPUT
|
||||||
|
echo "BUGS_FOUND=$BUGS_FOUND" >> $GITHUB_OUTPUT
|
||||||
|
echo "REPORT=$REPORT" >> $GITHUB_OUTPUT
|
||||||
|
if [[ "0" != "$exitstatus" ]] || ! grep -sq "$SubString" $RESULTFILE; then
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
exit 0
|
|
@ -38,7 +38,8 @@ test_sipp_based_tests_CFLAGS = $(AM_CFLAGS) $(SOFIA_SIP_CFLAGS) -DSWITCH_TEST_BA
|
||||||
test_sipp_based_tests_LDFLAGS = $(AM_LDFLAGS) -avoid-version -no-undefined $(freeswitch_LDFLAGS) $(switch_builddir)/libfreeswitch.la $(CORE_LIBS) $(APR_LIBS)
|
test_sipp_based_tests_LDFLAGS = $(AM_LDFLAGS) -avoid-version -no-undefined $(freeswitch_LDFLAGS) $(switch_builddir)/libfreeswitch.la $(CORE_LIBS) $(APR_LIBS)
|
||||||
test_sipp_based_tests_LDADD = libsofiamod.la $(SOFIA_SIP_LIBS)
|
test_sipp_based_tests_LDADD = libsofiamod.la $(SOFIA_SIP_LIBS)
|
||||||
|
|
||||||
TESTS = test/test_sofia_funcs.sh test/test_nuafail test/test_run_sipp.sh
|
TESTS = test/test_sofia_funcs.sh test/test_nuafail
|
||||||
|
#TESTS += test/test_run_sipp.sh
|
||||||
|
|
||||||
if ISMAC
|
if ISMAC
|
||||||
mod_sofia_la_LDFLAGS += -framework CoreFoundation -framework SystemConfiguration
|
mod_sofia_la_LDFLAGS += -framework CoreFoundation -framework SystemConfiguration
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
.DEFAULT:
|
||||||
|
./test.sh "$@"
|
||||||
|
|
||||||
|
all: $(TEST_LIST)
|
||||||
|
|
|
@ -3,26 +3,27 @@
|
||||||
# "print_tests" returns relative paths to all the tests
|
# "print_tests" returns relative paths to all the tests
|
||||||
TESTS=$(make -s -C ../.. print_tests)
|
TESTS=$(make -s -C ../.. print_tests)
|
||||||
|
|
||||||
|
chunks=${1:-1}
|
||||||
|
chunk_number=${2:-1}
|
||||||
|
|
||||||
|
IFS=$'\n' read -d '' -r -a lines <<< "$TESTS"
|
||||||
|
|
||||||
|
result=""
|
||||||
|
for ((i=chunk_number-1; i<${#lines[@]}; i+=chunks))
|
||||||
|
do
|
||||||
|
result+="${lines[$i]}"$'\n'
|
||||||
|
done
|
||||||
|
|
||||||
|
TESTS=$result
|
||||||
|
|
||||||
echo "-----------------------------------------------------------------";
|
echo "-----------------------------------------------------------------";
|
||||||
echo "Starting tests";
|
echo "Starting tests on $(nproc --all) processors";
|
||||||
echo "Tests found: ${TESTS}";
|
echo "Tests found: ${TESTS}";
|
||||||
echo "-----------------------------------------------------------------";
|
echo "-----------------------------------------------------------------";
|
||||||
echo "Starting" > pids.txt
|
|
||||||
for i in $TESTS
|
|
||||||
do
|
|
||||||
echo "Testing $i" ;
|
|
||||||
./test.sh "$i" &
|
|
||||||
pid=($!)
|
|
||||||
pids+=($pid)
|
|
||||||
echo "$pid $i" >> pids.txt
|
|
||||||
echo "----------------" ;
|
|
||||||
done
|
|
||||||
|
|
||||||
for pid in "${pids[@]}"
|
make -f run-tests.mk TEST_LIST=$TESTS
|
||||||
do
|
|
||||||
echo "$pid waiting" >> pids.txt
|
echo "Timing results:"
|
||||||
wait "$pid"
|
cat test_times.log
|
||||||
echo "$pid finished" >> pids.txt
|
|
||||||
done
|
|
||||||
|
|
||||||
echo "Done running tests!"
|
echo "Done running tests!"
|
|
@ -1,11 +1,16 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
start_time=$(date +%s)
|
||||||
|
|
||||||
# All output will be collected here
|
# All output will be collected here
|
||||||
TESTSUNITPATH=$PWD
|
TESTSUNITPATH=$PWD
|
||||||
|
|
||||||
# All relative paths are based on the tree's root
|
# All relative paths are based on the tree's root
|
||||||
FSBASEDIR=$(realpath "$PWD/../../")
|
FSBASEDIR=$(realpath "$PWD/../../")
|
||||||
|
|
||||||
|
ulimit -c unlimited
|
||||||
|
ulimit -a
|
||||||
|
|
||||||
i=$1
|
i=$1
|
||||||
|
|
||||||
echo "----------------------------------" ;
|
echo "----------------------------------" ;
|
||||||
|
@ -28,20 +33,23 @@ echo "Start executing $currenttestpath"
|
||||||
$currenttestpath 2>&1 | tee >(ansi2html > $log) ;
|
$currenttestpath 2>&1 | tee >(ansi2html > $log) ;
|
||||||
exitstatus=${PIPESTATUS[0]} ;
|
exitstatus=${PIPESTATUS[0]} ;
|
||||||
echo "End executing $currenttestpath"
|
echo "End executing $currenttestpath"
|
||||||
|
end_time=$(date +%s)
|
||||||
|
duration=$((end_time - start_time))
|
||||||
|
echo "Test $1 took $duration seconds" >> test_times.log
|
||||||
echo "Exit status is $exitstatus"
|
echo "Exit status is $exitstatus"
|
||||||
|
|
||||||
if [ "0" -eq $exitstatus ] ; then
|
if [ "0" -eq $exitstatus ] ; then
|
||||||
rm $log ;
|
rm $log ;
|
||||||
else
|
else
|
||||||
echo "*** ./$i exit status is $exitstatus" ;
|
echo "*** ./$i exit status is $exitstatus" ;
|
||||||
corefilesearch=/cores/core.*.!drone!src!${relativedir//\//!}!.libs!$file.* ;
|
corefilesearch=/cores/core.*.!__w!freeswitch!freeswitch!${relativedir//\//!}!.libs!$file.* ;
|
||||||
echo $corefilesearch ;
|
echo $corefilesearch ;
|
||||||
if ls $corefilesearch 1> /dev/null 2>&1; then
|
if ls $corefilesearch 1> /dev/null 2>&1; then
|
||||||
echo "coredump found";
|
echo "coredump found";
|
||||||
coredump=$(ls $corefilesearch) ;
|
coredump=$(ls $corefilesearch) ;
|
||||||
echo $coredump;
|
echo $coredump;
|
||||||
echo "set logging file $TESTSUNITPATH/backtrace_${i//\//!}.txt" ;
|
echo "set logging file $TESTSUNITPATH/backtrace_${i//\//!}.txt" ;
|
||||||
gdb -ex "set logging file $TESTSUNITPATH/backtrace_${i//\//!}.txt" -ex "set logging on" -ex "set pagination off" -ex "bt full" -ex "bt" -ex "info threads" -ex "thread apply all bt" -ex "thread apply all bt full" -ex "quit" /drone/src/$relativedir/.libs/$file $coredump ;
|
gdb -ex "set logging file $TESTSUNITPATH/backtrace_${i//\//!}.txt" -ex "set logging on" -ex "set pagination off" -ex "bt full" -ex "bt" -ex "info threads" -ex "thread apply all bt" -ex "thread apply all bt full" -ex "quit" /__w/freeswitch/freeswitch/$relativedir/.libs/$file $coredump ;
|
||||||
fi ;
|
fi ;
|
||||||
echo "*** $log was saved" ;
|
echo "*** $log was saved" ;
|
||||||
fi ;
|
fi ;
|
||||||
|
|
Loading…
Reference in New Issue