[Build-System] Add a Dockerfile for Coverity scan.
This commit is contained in:
parent
12997dde6a
commit
da081d4b9f
|
@ -0,0 +1,49 @@
|
||||||
|
FROM debian:bookworm-20241202
|
||||||
|
MAINTAINER Andrey Volk <andrey@signalwire.com>
|
||||||
|
|
||||||
|
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"]
|
|
@ -0,0 +1,23 @@
|
||||||
|
# Coverity scan
|
||||||
|
|
||||||
|
## Build an image for Coverity
|
||||||
|
```
|
||||||
|
docker build -t coverity --build-arg REPOTOKEN=<signalwire token> --build-arg COVERITYTOKEN=<coverity token> .
|
||||||
|
```
|
||||||
|
|
||||||
|
## 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=<coverity token> \
|
||||||
|
--form email=andrey@signalwire.com \
|
||||||
|
--form file=@freeswitch.tgz \
|
||||||
|
--form version="Version" \
|
||||||
|
--form description="Description" \
|
||||||
|
https://scan.coverity.com/builds?project=FreeSWITCH
|
||||||
|
```
|
Loading…
Reference in New Issue