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
122
123
124
125
|
import ast
import requests
from assertpy import assert_that
from robot.api import logger
from robot.api.deco import keyword
JSESSIONID_COOKIE = "JSESSIONID"
_vid_to_so_request_details = {
"requestDetails": {
"cloudConfiguration": {
"lcpCloudRegionId": "RegionOne",
"tenantId": "982c540f6e69488eb6be5664255e00c0"
},
"modelInfo": {
"modelInvariantId": "41b3c314-dfab-4501-9c5e-1c9fe5d8e151",
"modelName": "SoWs1..base_ws..module-0",
"modelType": "vfModule",
"modelVersion": "1",
"modelVersionId": "7ea96ae9-9eac-4eaa-882e-077478a6c44a"
},
"relatedInstanceList": [{
"relatedInstance": {
"instanceId": "0d8a98d8-d7ca-4c26-b7ab-81d3729e3b6c",
"modelInfo": {
"modelInvariantId": "a4413616-cf96-4615-a94e-0dc5a6a65430",
"modelName": "SC_WS_SW_2",
"modelType": "service",
"modelVersion": "3.0",
"modelVersionId": "0fdaaf44-3c6c-4d81-9c57-b2ce7224dbb9"
}
}
},
{
"relatedInstance": {
"instanceId": "61c19619-2714-46f8-90c9-39734e4f545f",
"modelInfo": {
"modelCustomizationName": "SO_WS_1 0",
"modelInvariantId": "3b2c9dcb-6ef8-4c3c-8d5b-43d5776f7110",
"modelName": "SO_WS_1",
"modelType": "vnf",
"modelVersion": "1.0",
"modelVersionId": "0fdaaf44-3c6c-4d81-9c57-b2ce7224dbb9"
}
}
}
],
"requestInfo": {
"source": "VID",
"suppressRollback": False,
"requestorId": "az2016",
"instanceName": "SC_WS_VNF_1_2"
},
"requestParameters": {
"controllerType": "SDNC",
"userParams": []
}
}
}
_expected_so_response = {
"status": 202,
"entity": {
"requestReferences": {
"instanceId": "fffcbb6c-1983-42df-9ca8-89ae8b3a46c1",
"requestId": "b2197d7e-3a7d-410e-82ba-7b7e8191bc46"
}
}
}
def _extract_cookie_from_headers(headers):
for i in headers["Set-Cookie"].split(";"):
if JSESSIONID_COOKIE in i:
return i
raise RuntimeError("No cookie when logging in to VID")
def _log_request(response):
logger.console(
"\n=========\n"
"Performing request to : {} \nBODY: {}\nHEADERS: {}"
.format(str(response.request.url), str(response.request.body), str(response.request.headers)))
logger.console(
"---------\n"
"Got response\n BODY: {} \n HEADERS: {}"
"\n=========\n".format(str(response.headers), str(response.content)))
@keyword('Login To VID')
def login_to_vid():
headers = {'User-Agent': 'Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:61.0) Gecko/20100101 Firefox/61.0',
'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8',
'Accept-Language': 'pl,en-US;q=0.7,en;q=0.3',
'Accept-Encoding': 'gzip, deflate', 'Referer': 'http://localhost:8080/vid/login.htm',
'Content-Type': 'application/x-www-form-urlencoded',
'Content-Length': '36',
'Cookie': 'JSESSIONID=1B4AF817AA4BCB87C07BB5B49EFE8526',
'Connection': 'keep-alive',
'Upgrade-Insecure-Requests': '1'}
response = requests.post("https://localhost:8443/vid/login_external", data="loginId=demo&password=Kp8bJ4SXszM0WX",
headers=headers, allow_redirects=False, verify=False)
logger.console("Performing login")
_log_request(response)
return _extract_cookie_from_headers(response.headers)
@keyword('Send create VF module instance request to VID')
def send_create_vfmodule_instance_request_to_vid(jsession_cookie):
response = requests.post(
"https://localhost:8443/vid/mso/mso_create_vfmodule_instance/0d8a98d8-d7ca-4c26-b7ab-81d3729e3b6c/vnfs/61c19619-2714-46f8-90c9-39734e4f545f ",
headers={"Cookie": jsession_cookie}, json=_vid_to_so_request_details, verify=False)
content = ast.literal_eval(response.content)
logger.console("Triggering VF module instance creation")
_log_request(response)
return content
@keyword('Response should contain valid entity')
def expect_response_from_so_was_correctly_propageted(content):
logger.console("\nActual entity" + str(content['entity']))
logger.console("Expected entity" + str(_expected_so_response))
assert_that(content['entity']).is_equal_to(_expected_so_response)
|