2c34599f51077f1b79f7f47cec3729c02454d492
[nepi.git] / test / resources / omf / omf6_vlc_traces.py
1 #!/usr/bin/env python
2 #
3 #    NEPI, a framework to manage network experiments
4 #    Copyright (C) 2013 INRIA
5 #
6 #    This program is free software: you can redistribute it and/or modify
7 #    it under the terms of the GNU General Public License version 2 as
8 #    published by the Free Software Foundation;
9 #
10 #    This program is distributed in the hope that it will be useful,
11 #    but WITHOUT ANY WARRANTY; without even the implied warranty of
12 #    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 #    GNU General Public License for more details.
14 #
15 #    You should have received a copy of the GNU General Public License
16 #    along with this program.  If not, see <http://www.gnu.org/licenses/>.
17 #
18 # Author: Julien Tribino <julien.tribino@inria.fr>
19
20
21 from nepi.execution.resource import ResourceFactory, ResourceManager, ResourceAction, ResourceState
22 from nepi.execution.ec import ExperimentController
23
24 from nepi.resources.omf.node import OMFNode
25 from nepi.resources.omf.application import OMFApplication
26 from nepi.resources.omf.interface import OMFWifiInterface
27 from nepi.resources.omf.channel import OMFChannel
28 from nepi.resources.omf.omf_api_factory import OMFAPIFactory
29
30 from nepi.util.timefuncs import *
31
32 import os
33 import time
34 import unittest
35
36 class OMFPingNormalCase(unittest.TestCase):
37     def test_deploy(self):
38         ec = ExperimentController(exp_id = "5421" )
39
40         self.node1 = ec.register_resource("omf::Node")
41         ec.set(self.node1, 'hostname', 'wlab12')
42         ec.set(self.node1, 'xmppUser', "nepi")
43         ec.set(self.node1, 'xmppServer', "xmpp-plexus.onelab.eu")
44         ec.set(self.node1, 'xmppPort', "5222")
45         ec.set(self.node1, 'xmppPassword', "1234")
46         
47         self.iface1 = ec.register_resource("omf::WifiInterface")
48         ec.set(self.iface1, 'name', "wlan0")
49         ec.set(self.iface1, 'mode', "adhoc")
50         ec.set(self.iface1, 'hw_mode', "g")
51         ec.set(self.iface1, 'essid', "vlcexp")
52         ec.set(self.iface1, 'ip', "10.0.0.17/24")
53         
54         self.channel = ec.register_resource("omf::Channel")
55         ec.set(self.channel, 'channel', "6")
56         ec.set(self.channel, 'xmppUser', "nepi")
57         ec.set(self.channel, 'xmppServer', "xmpp-plexus.onelab.eu")
58         ec.set(self.channel, 'xmppPort', "5222")
59         ec.set(self.channel, 'xmppPassword', "1234")
60         
61         self.app1 = ec.register_resource("omf::Application")
62         ec.set(self.app1, 'appid', 'Vlc#1')
63         ec.set(self.app1, 'command', "ping -c5 10.0.0.17")
64
65         ec.register_connection(self.app1, self.node1)
66         ec.register_connection(self.node1, self.iface1)
67         ec.register_connection(self.iface1, self.channel)
68
69         ec.register_condition(self.app1, ResourceAction.STOP, self.app1, ResourceState.STARTED , "10s")
70
71         ec.deploy()
72
73         ec.wait_finished(self.app1)
74
75         stdout_1 = ec.trace(self.app1, "stdout")
76         stderr_1 = ec.trace(self.app1, "stderr")
77
78         if stdout_1:
79             f = open("app1_out.txt", "w")
80             f.write(stdout_1)
81             f.close()
82
83         if stderr_1:
84             f = open("app1_err.txt", "w")
85             f.write(stderr_1)
86             f.close()
87
88         self.assertEquals(ec.get_resource(self.node1).state, ResourceState.STARTED)
89         self.assertEquals(ec.get_resource(self.iface1).state, ResourceState.STARTED)
90         self.assertEquals(ec.get_resource(self.channel).state, ResourceState.STARTED)
91         self.assertEquals(ec.get_resource(self.app1).state, ResourceState.STOPPED)
92
93         ec.shutdown()
94
95         self.assertEquals(ec.get_resource(self.node1).state, ResourceState.RELEASED)
96         self.assertEquals(ec.get_resource(self.iface1).state, ResourceState.RELEASED)
97         self.assertEquals(ec.get_resource(self.channel).state, ResourceState.RELEASED)
98         self.assertEquals(ec.get_resource(self.app1).state, ResourceState.RELEASED)
99
100         t = open("app1_out.txt", "r")
101         l = t.readlines()
102         self.assertEquals(l[0], "PING 10.0.0.17 (10.0.0.17) 56(84) bytes of data.\n")
103         self.assertIn("5 packets transmitted, 5 received, 0% packet loss, time", l[-2])
104         self.assertIn("rtt min/avg/max/mdev = ", l[-1])
105         
106         t.close()
107         os.remove("app1_out.txt")
108         
109
110
111 if __name__ == '__main__':
112     unittest.main()
113
114
115