blob: 97befeae20a072eb84034e0ca1e2172767d13381 [file] [log] [blame]
Kailash Khalasie6629eb2018-08-17 11:53:57 -07001*** Settings ***
2Library KafkaLibrary
3Library RequestsLibrary
4Library HttpLibrary.HTTP
5Library Collections
6Library String
7Library OperatingSystem
Kailash2dd4d9d2019-05-01 14:00:11 -07008Resource ../../Framework/utils/utils.robot
Kailash Khalasie6629eb2018-08-17 11:53:57 -07009Suite Setup Setup
10Suite Teardown Teardown
Kailash2dd4d9d2019-05-01 14:00:11 -070011Test Template Send Event and Verify
Kailash Khalasie6629eb2018-08-17 11:53:57 -070012
13*** Variables ***
14${cord_kafka} cord-kafka
15${server_ip} xos-chameleon
16${server_port} 9101
17${subscriber_api} /xosapi/v1/rcord/rcordsubscribers
Kailash2dd4d9d2019-05-01 14:00:11 -070018${att_wf_api} /xosapi/v1/att-workflow-driver/attworkflowdriverservices
19${volt_api} /xosapi/v1/volt/voltservices
Kailash Khalasie6629eb2018-08-17 11:53:57 -070020${att_si_api} /xosapi/v1/att-workflow-driver/attworkflowdriverserviceinstances
Kailash2dd4d9d2019-05-01 14:00:11 -070021${att_whitelist_api} /xosapi/v1/att-workflow-driver/attworkflowdriverwhitelistentries
Kailash Khalasie6629eb2018-08-17 11:53:57 -070022${onu_device_api} /xosapi/v1/volt/onudevices
Kailash2dd4d9d2019-05-01 14:00:11 -070023${olt_api} /xosapi/v1/volt/oltdevices
24${pon_ports_api} /xosapi/v1/volt/ponports
25${uni_ports_api} /xosapi/v1/volt/uniports
Kailash Khalasie6629eb2018-08-17 11:53:57 -070026${onu_serial_no} onudevice123
27${onu_invalid_sn} invalid_serial_no
Kailash Khalasie6629eb2018-08-17 11:53:57 -070028${deviceId} of:robot_test
29${ponportno} 10
30${uniportno} 100
Kailash2dd4d9d2019-05-01 14:00:11 -070031${mac_address} 00:AA:00:00:00:01
32${ip_address} 192.168.3.5
Kailash Khalasie6629eb2018-08-17 11:53:57 -070033
34*** Test Cases ***
Kailash2dd4d9d2019-05-01 14:00:11 -070035Activate Non-Whitelisted ONU onu.events {'status': 'activated', 'serial_number': '${onu_invalid_sn}','uni_port_id': 100, 'of_dpid': '${deviceId}'} onu_serial_number=${onu_invalid_sn} onu_state=DISABLED
Kailash Khalasie6629eb2018-08-17 11:53:57 -070036 [Documentation] Validate that activating an ONU not in whitelist sets onu device to DISABLED
Kailash Khalasie6629eb2018-08-17 11:53:57 -070037
Kailash2dd4d9d2019-05-01 14:00:11 -070038Activate Whitelisted ONU in Wrong Location onu.events {'status': 'activated', 'serial_number': '${onu_serial_no}','uni_port_id': 52, 'of_dpid': 'wrongofdpid'} onu_serial_number=${onu_serial_no} onu_state=DISABLED
Kailash Khalasie6629eb2018-08-17 11:53:57 -070039 [Documentation] Validate that activating an ONU in the whitelist but in the wrong location DISABLES the onu device
Kailash Khalasie6629eb2018-08-17 11:53:57 -070040
Kailash2dd4d9d2019-05-01 14:00:11 -070041Activate Whitelisted ONU onu.events {'status': 'activated', 'serial_number': '${onu_serial_no}','uni_port_id': ${uniportno}, 'of_dpid': '${deviceId}'} onu_serial_number=${onu_serial_no} onu_state=ENABLED
Kailash Khalasie6629eb2018-08-17 11:53:57 -070042 [Documentation] Validate that activating an ONU in the whitelist creates a attworkflow-driver-serviceinstance
Kailash Khalasie6629eb2018-08-17 11:53:57 -070043
Kailash2dd4d9d2019-05-01 14:00:11 -070044Send Auth Request authentication.events {'authenticationState': 'APPROVED', 'deviceId': '${deviceId}','portNumber': ${uniportno}} onu_serial_number=${onu_serial_no} subscriber_state=enabled service_instance_state=APPROVED service_instance_count=1 service_instance_dhcp_state=AWAITING
Kailash Khalasie6629eb2018-08-17 11:53:57 -070045 [Documentation] Validate that sending an auth request to the onu will enable the subscriber and create a service chain
Kailash Khalasie6629eb2018-08-17 11:53:57 -070046
Kailash2dd4d9d2019-05-01 14:00:11 -070047Send DHCP Request dhcp.events {'macAddress': '${mac_address}','ipAddress': '${ip_address}', 'deviceId': '${deviceId}', 'portNumber': ${uniportno}, 'messageType': 'DHCPACK'} onu_serial_number=${onu_serial_no} service_instance_state=APPROVED service_instance_dhcp_state=DHCPACK
48 [Documentation] Validate that sending an dhcp request to update the subscriber's mac+ip address
49
50Send Denied Auth Request authentication.events {'authenticationState': 'DENIED', 'deviceId': '${deviceId}','portNumber': ${uniportno}} onu_serial_number=${onu_serial_no} subscriber_state=auth-failed service_instance_state=DENIED service_instance_dhcp_state=DHCPACK
Kailash Khalasic53eee92018-08-21 11:49:19 -070051 [Documentation] Validate that denied auth request to the onu will disable the subscriber and remove a service chain
Kailash Khalasic53eee92018-08-21 11:49:19 -070052
Kailash Khalasie6629eb2018-08-17 11:53:57 -070053Create New Whitelist Entry
54 [Documentation] Validate that creating a new whitelist entry for the "invalid" onu device will enable the onu
Kailash2dd4d9d2019-05-01 14:00:11 -070055 [Template] None
56 ${resp}= CORD Post ${att_whitelist_api} {"serial_number": "${onu_invalid_sn}", "device_id": "${deviceId}", "pon_port_id": ${ponportno}, "owner_id": ${attworkflowservice_id}}
Kailash Khalasie6629eb2018-08-17 11:53:57 -070057 ${whitelist_entry2_id}= Get Json Value ${resp.content} /id
58 Set Suite Variable ${whitelist_entry2_id}
59 Wait Until Keyword Succeeds 30s 5s Validate ONU Device Status ${onu_invalid_sn} ENABLED
60
Kailash Khalasi8f42b322018-08-21 09:36:53 -070061Remove Whitelist Entry
62 [Documentation] Validate that removing a whitelist entry for an onu device will disable the subscriber and remove it's service chain
Kailash2dd4d9d2019-05-01 14:00:11 -070063 [Template] None
Kailash Khalasi8f42b322018-08-21 09:36:53 -070064 CORD Delete /xosapi/v1/att-workflow-driver/attworkflowdriverwhitelistentries ${whitelist_entry_id}
Kailash Khalasic53eee92018-08-21 11:49:19 -070065 Wait Until Keyword Succeeds 120s 5s Validate Subscriber Status ${onu_serial_no} auth-failed
66 Wait Until Keyword Succeeds 120s 5s Validate Subscriber Service Chain ${onu_serial_no}
Kailash Khalasi8f42b322018-08-21 09:36:53 -070067
Kailash Khalasie6629eb2018-08-17 11:53:57 -070068*** Keywords ***
69Setup
70 Connect Producer ${cord_kafka}:9092 onu.events
71 Connect Producer ${cord_kafka}:9092 authentication.events
72 Connect Producer ${cord_kafka}:9092 dhcp.events
73 ${auth} = Create List admin@opencord.org letmein
74 ${HEADERS} Create Dictionary Content-Type=application/json
75 Create Session ${server_ip} http://${server_ip}:${server_port} auth=${AUTH} headers=${HEADERS}
Kailash2dd4d9d2019-05-01 14:00:11 -070076 Create OLT, ONU, Subscribers, and Whitelists
Kailash Khalasie6629eb2018-08-17 11:53:57 -070077
78Teardown
Kailash Khalasi8f42b322018-08-21 09:36:53 -070079 [Documentation] Delete all models created
Kailash Khalasie6629eb2018-08-17 11:53:57 -070080 CORD Get /xosapi/v1/rcord/rcordsubscribers
Kailash2dd4d9d2019-05-01 14:00:11 -070081 Clean Up Objects ${subscriber_api}
82 Clean Up Objects ${att_si_api}
83 Clean Up Objects ${subscriber_api}
84 Wait Until Keyword Succeeds 60s 1s Clean Up Objects ${olt_api}
85 Clean Up Objects ${att_whitelist_api}
86
87Create OLT, ONU, Subscribers, and Whitelists
88 [Documentation] Create two onu devices to be tested for valid/invalid paths
89 ${resp}= CORD Get ${volt_api}
90 ${jsondata}= To Json ${resp.content}
91 ${voltservice}= Get From List ${jsondata['items']} 0
92 ${voltservice_id}= Get From Dictionary ${voltservice} id
93 ${resp}= CORD Get ${att_wf_api}
94 ${jsondata}= To Json ${resp.content}
95 ${attworkflowservice}= Get From List ${jsondata['items']} 0
96 ${attworkflowservice_id}= Get From Dictionary ${attworkflowservice} id
97 Set Suite Variable ${attworkflowservice_id}
98 ${resp}= CORD Post ${subscriber_api} {"onu_device": "${onu_serial_no}", "status": "pre-provisioned"}
99 ${subscriber_id}= Get Json Value ${resp.content} /id
100 Set Suite Variable ${subscriber_id}
101 ${resp}= CORD Post ${olt_api} {"volt_service_id": ${voltservice_id}, "name": "testoltdevice1", "device_type": "ponism", "host": "172.17.0.1", "port": 50060, "switch_port": "1", "dp_id": "${deviceId}", "outer_tpid": "0x8100", "uplink": "128"}
102 ${oltdevice_id}= Get Json Value ${resp.content} /id
103 Set Suite Variable ${oltdevice_id}
104 ${resp}= CORD Post ${pon_ports_api} {"olt_device_id": ${oltdevice_id}, "port_no": "${ponportno}", "name": "testponport1"}
105 ${ponport_id}= Get Json Value ${resp.content} /id
106 Set Suite Variable ${ponport_id}
107 ${resp}= CORD Post ${onu_device_api} {"serial_number": "${onu_serial_no}", "pon_port_id": ${ponport_id}, "vendor": "abcdefg"}
108 ${onu_device1_id}= Get Json Value ${resp.content} /id
109 Set Suite Variable ${onu_device1_id}
110 ${resp}= CORD Post ${uni_ports_api} {"onu_device_id": "${onu_device1_id}", "port_no": ${uniportno}, "name": "testuniport"}
111 ${uni_port_id}= Get Json Value ${resp.content} /id
112 Set Suite Variable ${uni_port_id}
113 ${resp}= CORD Post ${onu_device_api} {"serial_number": "${onu_invalid_sn}", "pon_port_id": ${ponport_id}, "vendor": "abcdefg"}
114 ${onu_device2_id}= Get Json Value ${resp.content} /id
115 Set Suite Variable ${onu_device2_id}
116 ${resp}= CORD Post ${att_whitelist_api} {"serial_number": "${onu_serial_no}", "device_id": "${deviceId}", "pon_port_id": ${ponportno}, "owner_id": ${attworkflowservice_id}}
117 ${whitelist_entry_id}= Get Json Value ${resp.content} /id
118 Set Suite Variable ${whitelist_entry_id}
119
120Send Event and Verify
121 [Arguments] ${topic} ${event} ${onu_serial_number}=${EMPTY} ${onu_state}=${EMPTY} ${subscriber_state}=${EMPTY} ${service_instance_state}=${EMPTY} ${service_instance_count}=${EMPTY} ${service_instance_dhcp_state}=${EMPTY}
122 Send Kafka Event ${topic} ${event}
123 Run Keyword If '${topic}' == 'onu.events' Wait Until Keyword Succeeds 30s 5s Validate ONU Device Status ${onu_serial_number} ${onu_state}
124 Run Keyword If '${topic}' == 'authentication.events' Wait Until Keyword Succeeds 30s 5s Validate Subscriber Status ${onu_serial_number} ${subscriber_state}
125 Run Keyword If '${topic}' == 'authentication.events' Wait Until Keyword Succeeds 30s 5s Validate Subscriber Service Chain ${onu_serial_number} ${service_instance_count}
126 Run Keyword If '${topic}' == 'authentication.events' Wait Until Keyword Succeeds 30s 5s Validate ATT Service Instance ${onu_serial_number} ${service_instance_state} ${service_instance_dhcp_state}
127 Run Keyword If '${topic}' == 'dhcp.events' Wait Until Keyword Succeeds 30s 5s Validate ATT Service Instance ${onu_serial_number} ${service_instance_state} ${service_instance_dhcp_state}
128 Run Keyword If '${topic}' == 'dhcp.events' Wait Until Keyword Succeeds 30s 5s Validate Subscriber Settings ${onu_serial_number}
Kailash Khalasie6629eb2018-08-17 11:53:57 -0700129
130Send Kafka Event
131 [Documentation] Send event
132 [Arguments] ${topic} ${message}
133 Log Sending event
134 ${event}= evaluate json.dumps(${message}) json
135 Send ${topic} ${event}
136 Flush
137
Kailash2dd4d9d2019-05-01 14:00:11 -0700138Validate ATT Service Instance
139 [Documentation] Validates the states in the ATT-WF-SI per onu
140 [Arguments] ${serial_no} ${auth_state} ${dhcp_state}
Kailash Khalasie6629eb2018-08-17 11:53:57 -0700141 ${resp}= Get Request ${server_ip} ${att_si_api}
142 Log ${resp.content}
143 Should Be Equal As Strings ${resp.status_code} 200
144 ## validate sn exists
145 Should Contain ${resp.content} ${serial_no}
146 ${jsondata}= To Json ${resp.content}
147 Log ${jsondata}
148 ${length}= Get Length ${jsondata['items']}
149 : FOR ${INDEX} IN RANGE 0 ${length}
150 \ ${value}= Get From List ${jsondata['items']} ${INDEX}
151 \ ${id}= Get From Dictionary ${value} id
152 \ ${sn}= Get From Dictionary ${value} serial_number
153 \ ${as}= Get From Dictionary ${value} authentication_state
Kailash2dd4d9d2019-05-01 14:00:11 -0700154 \ ${dp}= Get From Dictionary ${value} dhcp_state
Kailash Khalasie6629eb2018-08-17 11:53:57 -0700155 \ Run Keyword If '${sn}' == '${serial_no}' Exit For Loop
Kailash2dd4d9d2019-05-01 14:00:11 -0700156 Should Be Equal ${dp} ${dhcp_state}
Kailash Khalasie6629eb2018-08-17 11:53:57 -0700157 Should Be Equal ${as} ${auth_state}
Kailash Khalasie6629eb2018-08-17 11:53:57 -0700158
Kailash Khalasie6629eb2018-08-17 11:53:57 -0700159Validate Subscriber Status
160 [Arguments] ${serial_no} ${expected_status}
161 ${resp}= CORD Get ${subscriber_api}
162 ${jsondata}= To Json ${resp.content}
163 Log ${jsondata}
164 ${length}= Get Length ${jsondata['items']}
165 : FOR ${INDEX} IN RANGE 0 ${length}
166 \ ${value}= Get From List ${jsondata['items']} ${INDEX}
167 \ ${status}= Get From Dictionary ${value} status
168 \ ${sn}= Get From Dictionary ${value} onu_device
169 \ Run Keyword If '${sn}' == '${serial_no}' Exit For Loop
170 Should Be Equal ${status} ${expected_status}
171
172Validate Subscriber Service Chain
Kailash Khalasic53eee92018-08-21 11:49:19 -0700173 [Arguments] ${serial_no} ${expected_no_sc}=${EMPTY}
Kailash Khalasie6629eb2018-08-17 11:53:57 -0700174 ${resp}= CORD Get ${subscriber_api}
175 ${jsondata}= To Json ${resp.content}
176 Log ${jsondata}
177 ${length}= Get Length ${jsondata['items']}
178 : FOR ${INDEX} IN RANGE 0 ${length}
179 \ ${value}= Get From List ${jsondata['items']} ${INDEX}
180 \ ${sl}= Get From Dictionary ${value} subscribed_links_ids
Kailash Khalasi5cd95a52018-08-22 08:55:04 -0700181 \ ${result} ${slinks}= Run Keyword And Ignore Error Get From List ${sl} 0
Kailash Khalasie6629eb2018-08-17 11:53:57 -0700182 \ ${sn}= Get From Dictionary ${value} onu_device
183 \ Run Keyword If '${sn}' == '${serial_no}' Exit For Loop
Kailash2dd4d9d2019-05-01 14:00:11 -0700184 Run Keyword If '${expected_no_sc}' != '${EMPTY}' Should Not Be Equal As Strings ${result} FAIL
185 Run Keyword If '${expected_no_sc}' != '${EMPTY}' Should Not Be Empty ${result} ELSE Should Be Empty ${sl}
Kailash Khalasie6629eb2018-08-17 11:53:57 -0700186
187Validate ONU Device Status
188 [Arguments] ${serial_no} ${expected_status}
189 ${resp}= CORD Get ${onu_device_api}
190 ${jsondata}= To Json ${resp.content}
191 Log ${jsondata}
192 ${length}= Get Length ${jsondata['items']}
193 : FOR ${INDEX} IN RANGE 0 ${length}
194 \ ${value}= Get From List ${jsondata['items']} ${INDEX}
195 \ ${status}= Get From Dictionary ${value} admin_state
196 \ ${sn}= Get From Dictionary ${value} serial_number
197 \ Run Keyword If '${sn}' == '${serial_no}' Exit For Loop
198 Should Be Equal ${status} ${expected_status}
199
200Validate Subscriber Settings
201 [Arguments] ${serial_no}
202 ${resp}= CORD Get ${subscriber_api}
203 ${jsondata}= To Json ${resp.content}
204 Log ${jsondata}
205 ${length}= Get Length ${jsondata['items']}
206 : FOR ${INDEX} IN RANGE 0 ${length}
207 \ ${value}= Get From List ${jsondata['items']} ${INDEX}
208 \ ${macAddress}= Get From Dictionary ${value} mac_address
Kailash Khalasie6629eb2018-08-17 11:53:57 -0700209 \ ${sn}= Get From Dictionary ${value} onu_device
210 \ Run Keyword If '${sn}' == '${serial_no}' Exit For Loop
Kailash2dd4d9d2019-05-01 14:00:11 -0700211 Should Be Equal ${macAddress} ${mac_address}