Changing ResourceManager naming for platform::ResourceName
[nepi.git] / test / resources / linux / ccn / ccnping.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 as published by
8 #    the Free Software Foundation, either version 3 of the License, or
9 #    (at your option) any later version.
10 #
11 #    This program is distributed in the hope that it will be useful,
12 #    but WITHOUT ANY WARRANTY; without even the implied warranty of
13 #    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14 #    GNU General Public License for more details.
15 #
16 #    You should have received a copy of the GNU General Public License
17 #    along with this program.  If not, see <http://www.gnu.org/licenses/>.
18 #
19 # Author: Alina Quereilhac <alina.quereilhac@inria.fr>
20
21 from nepi.execution.ec import ExperimentController 
22 from test_utils import skipIfAnyNotAlive
23
24 import os
25 import time
26 import tempfile
27 import unittest
28
29 class LinuxCCNPingTestCase(unittest.TestCase):
30     def setUp(self):
31         self.fedora_host = "nepi2.pl.sophia.inria.fr"
32         self.fedora_user = "inria_nepi"
33
34         self.ubuntu_host = "roseval.pl.sophia.inria.fr"
35         self.ubuntu_user = "alina"
36         
37         self.target = "nepi5.pl.sophia.inria.fr"
38
39     @skipIfAnyNotAlive
40     def t_count(self, user1, host1, user2, host2):
41
42         ec = ExperimentController(exp_id = "test-ccn-ping-count")
43         
44         node1 = ec.register_resource("linux::Node")
45         ec.set(node1, "hostname", host1)
46         ec.set(node1, "username", user1)
47         ec.set(node1, "cleanExperiment", True)
48         ec.set(node1, "cleanProcesses", True)
49
50         ccnd1 = ec.register_resource("linux::CCND")
51         ec.register_connection(ccnd1, node1)
52
53         entry1 = ec.register_resource("linux::FIBEntry")
54         ec.set(entry1, "host", host2)
55         ec.register_connection(entry1, ccnd1)
56  
57         server = ec.register_resource("linux::CCNPingServer")
58         ec.set(server, "prefix", "ccnx:/test")
59         ec.register_connection(server, ccnd1)
60  
61         node2 = ec.register_resource("linux::Node")
62         ec.set(node2, "hostname", host2)
63         ec.set(node2, "username", user2)
64         ec.set(node2, "cleanExperiment", True)
65         ec.set(node2, "cleanProcesses", True)
66
67         ccnd2 = ec.register_resource("linux::CCND")
68         ec.register_connection(ccnd2, node2)
69
70         entry2 = ec.register_resource("linux::FIBEntry")
71         ec.set(entry2, "host", host1)
72         ec.register_connection(entry2, ccnd2)
73  
74         client = ec.register_resource("linux::CCNPing")
75         ec.set(client, "c", 15)
76         ec.set(client, "prefix", "ccnx:/test")
77         ec.register_connection(client, ccnd2)
78         ec.register_connection(client, server)
79
80         ec.deploy()
81
82         ec.wait_finished(client)
83
84         stdout = ec.trace(client, "stdout")
85         expected = "15 Interests transmitted"
86         self.assertTrue(stdout.find(expected) > -1)
87
88         ec.shutdown()
89
90     def test_count_fedora(self):
91         self.t_count(self.fedora_user, self.fedora_host, self.fedora_user, 
92                 self.target)
93
94     def test_count_ubuntu(self):
95         self.t_count(self.ubuntu_user, self.ubuntu_host, self.ubuntu_user,
96                 self.target)
97
98 if __name__ == '__main__':
99     unittest.main()
100