Added emulator-compatible services and VNFs for R4 integration tests.
[osm/vim-emu.git] / Dockerfile
1 # Copyright (c) 2017 SONATA-NFV and Paderborn University
2 # ALL RIGHTS RESERVED.
3
4 # Licensed under the Apache License, Version 2.0 (the "License");
5 # you may not use this file except in compliance with the License.
6 # You may obtain a copy of the License at
7 #
8 #    http://www.apache.org/licenses/LICENSE-2.0
9 #
10 # Unless required by applicable law or agreed to in writing, software
11 # distributed under the License is distributed on an "AS IS" BASIS,
12 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 # See the License for the specific language governing permissions and
14 # limitations under the License.
15 #
16 # Neither the name of the SONATA-NFV, Paderborn University
17 # nor the names of its contributors may be used to endorse or promote
18 # products derived from this software without specific prior written
19 # permission.
20 #
21 # This work has been performed in the framework of the SONATA project,
22 # funded by the European Commission under Grant number 671517 through
23 # the Horizon 2020 and 5G-PPP programmes. The authors would like to
24 # acknowledge the contributions of their colleagues of the SONATA
25 # partner consortium (www.sonata-nfv.eu).
26
27 FROM ubuntu:xenial
28
29 ENV SON_EMU_IN_DOCKER 1
30 ENV PIP_DEFAULT_TIMEOUT=100
31
32 # install required packages
33 RUN apt-get clean
34 RUN apt-get update \
35     && apt-get install -y  git \
36     net-tools \
37     aptitude \
38     build-essential \
39     python-setuptools \
40     python-dev \
41     python-pip \
42     software-properties-common \
43     ansible \
44     curl \
45     iptables \
46     iputils-ping \
47     sudo
48
49 # install containernet (using its Ansible playbook)
50 RUN git clone https://github.com/containernet/containernet.git
51 WORKDIR /containernet/ansible
52 RUN ansible-playbook -i "localhost," -c local --skip-tags "notindocker" install.yml
53
54 # install emulator (using its Ansible playbook)
55 COPY . /son-emu
56 WORKDIR /son-emu/ansible
57 RUN ansible-playbook -i "localhost," -c local --skip-tags "notindocker" install.yml
58 WORKDIR /son-emu
59 RUN python setup.py develop
60
61 # Important: This entrypoint is required to start the OVS service
62 ENTRYPOINT ["/son-emu/utils/docker/entrypoint.sh"]
63 CMD ["python", "examples/default_single_dc_topology.py"]
64
65 # open ports for emulator APIs
66 # SONATA GK
67 EXPOSE 5000
68 # EMU REST API
69 EXPOSE 5001
70 # Monitoring (Prometheus)
71 EXPOSE 8081
72 # Monitoring (GW)
73 EXPOSE 9091
74 # OpenStack-fake
75 EXPOSE 4000
76 # OpenStack-fake
77 EXPOSE 10243
78 # OpenStack-fake
79 EXPOSE 9005
80 # OpenStack-fake (Keystone)
81 EXPOSE 6001
82 # OpenStack-fake
83 EXPOSE 9775
84 # OpenStack-fake
85 EXPOSE 10697