From da081d4b9f4eb150db2422cd1169d82714483912 Mon Sep 17 00:00:00 2001 From: Andrey Volk Date: Tue, 10 Dec 2024 21:26:10 +0300 Subject: [PATCH] [Build-System] Add a Dockerfile for Coverity scan. --- docker/coverity/Dockerfile | 49 ++++++++++++++++++++++++++++++++++++++ docker/coverity/README.md | 23 ++++++++++++++++++ 2 files changed, 72 insertions(+) create mode 100644 docker/coverity/Dockerfile create mode 100644 docker/coverity/README.md diff --git a/docker/coverity/Dockerfile b/docker/coverity/Dockerfile new file mode 100644 index 0000000000..7f3fb9216f --- /dev/null +++ b/docker/coverity/Dockerfile @@ -0,0 +1,49 @@ +FROM debian:bookworm-20241202 +MAINTAINER Andrey Volk + +ARG REPOTOKEN +ARG COVERITYTOKEN + +RUN apt-get update && \ + DEBIAN_FRONTEND=noninteractive apt-get -yq install \ + wget gnupg2 dos2unix apt-transport-https lsb-release git +RUN echo "machine freeswitch.signalwire.com login signalwire password ${REPOTOKEN}" > /etc/apt/auth.conf +RUN wget --http-user=signalwire --http-password=${REPOTOKEN} -O /usr/share/keyrings/signalwire-freeswitch-repo.gpg https://freeswitch.signalwire.com/repo/deb/debian-release/signalwire-freeswitch-repo.gpg +RUN echo "deb [signed-by=/usr/share/keyrings/signalwire-freeswitch-repo.gpg] https://freeswitch.signalwire.com/repo/deb/debian-release/ `lsb_release -sc` main" > /etc/apt/sources.list.d/freeswitch.list +RUN echo "deb-src [signed-by=/usr/share/keyrings/signalwire-freeswitch-repo.gpg] https://freeswitch.signalwire.com/repo/deb/debian-release/ `lsb_release -sc` main" >> /etc/apt/sources.list.d/freeswitch.list +RUN apt-get update +RUN apt-get -y build-dep freeswitch +RUN mkdir /data + +ENV PATH="/coverity/cov-analysis-linux64/bin:${PATH}" + +RUN echo "#!/bin/bash\n\ +wget https://scan.coverity.com/download/linux64 --post-data \"token=${COVERITYTOKEN}&project=FreeSWITCH\" -O /coverity_tool.tgz\n\ +COVERITYFOLDER=\$(tar -tf /coverity_tool.tgz | head -n1)\n\ +mkdir -p /coverity\n\ +tar zxvf /coverity_tool.tgz -C /coverity/\n\ +cd /coverity\n\ +mv \$COVERITYFOLDER cov-analysis-linux64\n\ +apt-get update && apt-get -y build-dep freeswitch\n\ +apt-get install -y libv8-6.1-dev\n\ +cd /\n\ +git clone https://github.com/signalwire/freeswitch -b "\$FSBRANCH"\n\ +cd /freeswitch\n\ +git status\n\ +mkdir modules\n\ +cd modules\n\ +../debian/bootstrap.sh -c bookworm\n\ +cd ..\n\ +./bootstrap.sh\n\ +cp ./modules/modules_.conf ./modules.conf\n\ +./configure\n\ +cov-build --dir cov-int make -j\$(nproc)\n\ +tar czvf /data/freeswitch.tgz cov-int\n "\ +>> /run.sh + +RUN echo /run.sh + +WORKDIR /data +RUN chmod 755 /run.sh +RUN dos2unix /run.sh +CMD ["/run.sh"] \ No newline at end of file diff --git a/docker/coverity/README.md b/docker/coverity/README.md new file mode 100644 index 0000000000..aef36d0645 --- /dev/null +++ b/docker/coverity/README.md @@ -0,0 +1,23 @@ +# Coverity scan + +## Build an image for Coverity +``` +docker build -t coverity --build-arg REPOTOKEN= --build-arg COVERITYTOKEN= . +``` + +## Scan FreeSWITCH using a Coverity image +``` +docker run --rm -itv .:/data -e FSBRANCH="master" coverity +``` + +This will output `freeswitch.tgz` file to the current folder + +## Uploading the result to the Coverity server +``` +curl --form token= \ + --form email=andrey@signalwire.com \ + --form file=@freeswitch.tgz \ + --form version="Version" \ + --form description="Description" \ + https://scan.coverity.com/builds?project=FreeSWITCH +``` \ No newline at end of file