forked from NORDUnet/opennsa
-
Notifications
You must be signed in to change notification settings - Fork 0
/
client-test
executable file
·122 lines (78 loc) · 4.03 KB
/
client-test
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
#!/usr/bin/env python
import os
import uuid
import random
import time
import datetime
from twisted.internet import reactor, defer
from opennsa import nsa, setup
DYNAMICKL_SERVICE = 'http://220.69.219.228:8010/nsi/ConnectionServiceProvider'
OPENNSA_SERVICE = 'http://orval.grid.aau.dk:9080/NSI/services/ConnectionService'
LOCALHOST_SERVICE = 'http://localhost:9080/NSI/services/ConnectionService'
ORVAL_REQUESTER = 'http://orval.grid.aau.dk:7080/NSI/services/ConnectionService'
LOCAL_REQUESTER = 'http://localhost:7080/NSI/services/ConnectionService'
HOST = 'localhost'
PORT = 7080
def matchState(query_result, expected_state):
state = query_result.reservationSummary[0].connectionState
if state == expected_state:
print 'State match (%s)' % expected_state
else:
print "State mismatch. Was %s, should have been %s" % (state, expected_state)
@defer.inlineCallbacks
def doMain():
print 'OpenNSA WS test client'
wsdl_dir = os.path.join(os.path.dirname(os.path.abspath(__file__)), 'wsdl')
client, factory = setup.createClient(HOST, PORT, wsdl_dir)
reactor.listenTCP(PORT, factory)
client_nsa = nsa.NetworkServiceAgent('OpenNSA-testclient', LOCAL_REQUESTER)
provider_local_aruba = nsa.Network('Aruba', nsa.NetworkServiceAgent('Aruba-OpenNSA', LOCALHOST_SERVICE))
provider_orval_aruba = nsa.Network('Aruba', nsa.NetworkServiceAgent('Aruba-OpenNSA', OPENNSA_SERVICE))
provider_martinique = nsa.Network('Martinique', nsa.NetworkServiceAgent('Martinique-DynamicKL', DYNAMICKL_SERVICE))
provider = provider_local_aruba
#provider = provider_orval_aruba
#provider = provider_martinique
source_stp = nsa.STP('Aruba', 'A1' )
#source_stp = nsa.STP('Aruba', 'Axel' )
#source_stp = nsa.STP('Martinique', 'M1')
#dest_stp = nsa.STP('Aruba', 'A2')
dest_stp = nsa.STP('Bonaire', 'B3')
#dest_stp = nsa.STP('Curacao', 'C3')
start_time = datetime.datetime.utcfromtimestamp(time.time() + 3 )
end_time = datetime.datetime.utcfromtimestamp(time.time() + 120 )
#start_time, end_time = end_time, start_time
bandwidth = 200
#service_params = nsa.ServiceParameters('2011-09-01T08:56:00Z', '2011-10-01T08:56:00Z' , source_stp, dest_stp, bwp)
service_params = nsa.ServiceParameters(start_time, end_time, source_stp, dest_stp, bandwidth)
global_reservation_id = 'urn:uuid:' + str(uuid.uuid1())
connection_id = 'urn:uuid:' + str(uuid.uuid1())
print "Connection id", connection_id
r = yield client.reserve(client_nsa, provider.nsa, None, global_reservation_id, 'Test Connection', connection_id, service_params)
print "Reservation created. Connection ID:", connection_id
qr = yield client.query(client_nsa, provider.nsa, None, "Summary", connection_ids = [ connection_id ] )
matchState(qr, 'Reserved')
d = client.provision(client_nsa, provider.nsa, None, connection_id)
qr = yield client.query(client_nsa, provider.nsa, None, "Summary", connection_ids = [ connection_id ] )
matchState(qr, 'Auto-Provision')
yield d
print "Connection provisioned"
qr = yield client.query(client_nsa, provider.nsa, None, "Summary", connection_ids = [ connection_id ] )
matchState(qr, 'Provisioned')
_ = yield client.release(client_nsa, provider.nsa, None, connection_id)
print "Connection released"
qr = yield client.query(client_nsa, provider.nsa, None, "Summary", connection_ids = [ connection_id ] )
matchState(qr, 'Scheduled')
_ = yield client.terminate(client_nsa, provider.nsa, None, connection_id)
print "Reservation terminated"
qr = yield client.query(client_nsa, provider.nsa, None, "Summary", connection_ids = [ connection_id ] )
matchState(qr, 'Terminated')
def main():
d = defer.maybeDeferred(doMain)
def p(failure):
failure.printTraceback()
d.addErrback(p)
d.addBoth(lambda _ : reactor.callLater(0.1, reactor.stop) )
return d
if __name__ == '__main__':
reactor.callWhenRunning(main)
reactor.run()