[docker-ptf] Add support for spytest to ptf container (#4410)

- Install apt and pip dependencies
- Define traffic generator service

Signed-off-by: Danny Allen <daall@microsoft.com>
This commit is contained in:
Danny Allen 2020-04-13 16:56:19 -07:00 committed by Abhishek Dosi
parent 0d6754d140
commit 0824509373
3 changed files with 21 additions and 6 deletions

View File

@ -22,6 +22,7 @@ debs/
ENV DEBIAN_FRONTEND=noninteractive ENV DEBIAN_FRONTEND=noninteractive
## Set the apt source, update package cache and install necessary packages ## Set the apt source, update package cache and install necessary packages
## TODO: Clean up this step
RUN sed --in-place 's/httpredir.debian.org/debian-archive.trafficmanager.net/' /etc/apt/sources.list \ RUN sed --in-place 's/httpredir.debian.org/debian-archive.trafficmanager.net/' /etc/apt/sources.list \
&& apt-get update \ && apt-get update \
&& apt-get upgrade -y \ && apt-get upgrade -y \
@ -38,7 +39,6 @@ RUN sed --in-place 's/httpredir.debian.org/debian-archive.trafficmanager.net/' /
unzip \ unzip \
pkg-config \ pkg-config \
binutils \ binutils \
net-tools \
build-essential \ build-essential \
libssl-dev \ libssl-dev \
libffi-dev \ libffi-dev \
@ -52,7 +52,6 @@ RUN sed --in-place 's/httpredir.debian.org/debian-archive.trafficmanager.net/' /
iputils-ping \ iputils-ping \
hping3 \ hping3 \
curl \ curl \
tcpdump \
tmux \ tmux \
python \ python \
python-dev \ python-dev \
@ -63,7 +62,9 @@ RUN sed --in-place 's/httpredir.debian.org/debian-archive.trafficmanager.net/' /
rsyslog \ rsyslog \
ntp \ ntp \
ntpstat \ ntpstat \
ntpdate ntpdate \
arping \
bridge-utils
RUN dpkg -i \ RUN dpkg -i \
{% for deb in docker_ptf_debs.split(' ') -%} {% for deb in docker_ptf_debs.split(' ') -%}
@ -71,6 +72,7 @@ debs/{{ deb }}{{' '}}
{%- endfor %} {%- endfor %}
# Install all python modules from pypi. python-scapy is exception, ptf debian package requires python-scapy # Install all python modules from pypi. python-scapy is exception, ptf debian package requires python-scapy
# TODO: Clean up this step
RUN rm -rf /debs \ RUN rm -rf /debs \
&& apt-get -y autoclean \ && apt-get -y autoclean \
&& apt-get -y autoremove \ && apt-get -y autoremove \
@ -106,6 +108,7 @@ RUN rm -rf /debs \
&& pip install flask \ && pip install flask \
&& pip install exabgp==3.4.17\ && pip install exabgp==3.4.17\
&& pip install pyaml \ && pip install pyaml \
&& pip install pybrctl pyro4 rpyc yabgp \
&& mkdir -p /opt \ && mkdir -p /opt \
&& cd /opt \ && cd /opt \
&& wget https://raw.githubusercontent.com/p4lang/ptf/master/ptf_nn/ptf_nn_agent.py && wget https://raw.githubusercontent.com/p4lang/ptf/master/ptf_nn/ptf_nn_agent.py
@ -117,8 +120,9 @@ RUN mkdir /var/run/sshd \
&& sed -ri '/^#?UsePAM/c\UsePAM no' /etc/ssh/sshd_config \ && sed -ri '/^#?UsePAM/c\UsePAM no' /etc/ssh/sshd_config \
&& sed -ri '/^#?UseDNS/c\UseDNS no' /etc/ssh/sshd_config && sed -ri '/^#?UseDNS/c\UseDNS no' /etc/ssh/sshd_config
COPY ["supervisord.conf", "/etc/supervisor/"] COPY supervisord.conf /etc/supervisor/
COPY ["conf.d/supervisord.conf", "conf.d/sshd.conf", "conf.d/ptf_nn_agent.conf", "/etc/supervisor/conf.d/"] COPY conf.d/ /etc/supervisor/conf.d/
COPY ptf_tgen.sh /ptf_tgen/
# Move tcpdump into /usr/bin Otherwise it's impossible to run tcpdump due to a docker bug # Move tcpdump into /usr/bin Otherwise it's impossible to run tcpdump due to a docker bug
RUN mv /usr/sbin/tcpdump /usr/bin/tcpdump RUN mv /usr/sbin/tcpdump /usr/bin/tcpdump
@ -126,6 +130,6 @@ RUN ln -s /usr/bin/tcpdump /usr/sbin/tcpdump
RUN mkdir -p /var/log/supervisor RUN mkdir -p /var/log/supervisor
EXPOSE 22 EXPOSE 22 8009
ENTRYPOINT ["/usr/local/bin/supervisord", "-c", "/etc/supervisor/supervisord.conf"] ENTRYPOINT ["/usr/local/bin/supervisord", "-c", "/etc/supervisor/supervisord.conf"]

View File

@ -0,0 +1,10 @@
[program:ptf_tgen]
command=/ptf_tgen/ptf_tgen.sh
process_name=ptf_tgen
stdout_logfile=/tmp/ptf_tgen.out.log
stderr_logfile=/tmp/ptf_tgen.err.log
redirect_stderr=false
autostart=false
autorestart=true
startsecs=1
numprocs=1

1
dockers/docker-ptf/ptf_tgen.sh Executable file
View File

@ -0,0 +1 @@
# PLACEHOLDER - This file is intended to be overwritten by SPYTest.