blob: 0adc91739baa154d3d269fd472c892a12ddddda9 [file] [log] [blame]
peusterm41006b72016-03-12 12:13:06 +01001"""
2Helper module that implements helpers for test implementations.
3"""
4
5import unittest
6import os
7import subprocess
8import docker
9from emuvim.dcemulator.net import DCNetwork
10from mininet.clean import cleanup
peustermef6629e2016-03-14 17:21:56 +010011from mininet.node import Controller
peusterm41006b72016-03-12 12:13:06 +010012
13class SimpleTestTopology(unittest.TestCase):
14 """
15 Helper class to do basic test setups.
16 s1 -- s2 -- s3 -- ... -- sN
17 """
18
19 def __init__(self, *args, **kwargs):
20 self.net = None
21 self.s = [] # list of switches
22 self.h = [] # list of hosts
23 self.d = [] # list of docker containers
24 self.dc = [] # list of data centers
25 self.docker_cli = None
26 super(SimpleTestTopology, self).__init__(*args, **kwargs)
27
28 def createNet(
29 self,
30 nswitches=0, ndatacenter=0, nhosts=0, ndockers=0,
stevenvanrossem7cd3c252016-05-11 22:55:15 +020031 autolinkswitches=False, controller=Controller, **kwargs):
peusterm41006b72016-03-12 12:13:06 +010032 """
33 Creates a Mininet instance and automatically adds some
34 nodes to it.
peustermde14f332016-03-15 16:14:21 +010035
36 Attention, we should always use Mininet's default controller
37 for our tests. Only use other controllers if you want to test
38 specific controller functionality.
peusterm41006b72016-03-12 12:13:06 +010039 """
stevenvanrossem7cd3c252016-05-11 22:55:15 +020040 self.net = DCNetwork(controller=controller, **kwargs)
peusterm41006b72016-03-12 12:13:06 +010041
42 # add some switches
stevenvanrosseme3e034e2016-05-11 23:51:06 +020043 # start from s1 because ovs does not like to have dpid = 0
44 # and switch name-number is being used by mininet to set the dpid
45 for i in range(1, nswitches+1):
peusterm41006b72016-03-12 12:13:06 +010046 self.s.append(self.net.addSwitch('s%d' % i))
47 # if specified, chain all switches
48 if autolinkswitches:
49 for i in range(0, len(self.s) - 1):
50 self.net.addLink(self.s[i], self.s[i + 1])
51 # add some data centers
52 for i in range(0, ndatacenter):
53 self.dc.append(
54 self.net.addDatacenter(
55 'datacenter%d' % i,
56 metadata={"unittest_dc": i}))
57 # add some hosts
58 for i in range(0, nhosts):
59 self.h.append(self.net.addHost('h%d' % i))
60 # add some dockers
61 for i in range(0, ndockers):
peusterm0dc3ae02016-04-27 09:33:28 +020062 self.d.append(self.net.addDocker('d%d' % i, dimage="ubuntu:trusty"))
peusterm41006b72016-03-12 12:13:06 +010063
64 def startNet(self):
65 self.net.start()
66
67 def stopNet(self):
68 self.net.stop()
69
70 def getDockerCli(self):
71 """
72 Helper to interact with local docker instance.
73 """
74 if self.docker_cli is None:
75 self.docker_cli = docker.Client(
76 base_url='unix://var/run/docker.sock')
77 return self.docker_cli
78
peusterm5877ea22016-05-11 13:44:59 +020079 def getContainernetContainers(self):
peusterm41006b72016-03-12 12:13:06 +010080 """
peusterm5877ea22016-05-11 13:44:59 +020081 List the containers managed by containernet
peusterm41006b72016-03-12 12:13:06 +010082 """
peusterm5877ea22016-05-11 13:44:59 +020083 return self.getDockerCli().containers(filters={"label": "com.containernet"})
peusterm41006b72016-03-12 12:13:06 +010084
85 @staticmethod
86 def setUp():
87 pass
88
89 @staticmethod
90 def tearDown():
91 cleanup()
92 # make sure that all pending docker containers are killed
93 with open(os.devnull, 'w') as devnull:
94 subprocess.call(
peusterm5877ea22016-05-11 13:44:59 +020095 "sudo docker rm -f $(sudo docker ps --filter 'label=com.containernet' -a -q)",
peusterm41006b72016-03-12 12:13:06 +010096 stdout=devnull,
97 stderr=devnull,
98 shell=True)