Remove unused exposed ports
[integration/csit.git] / tests / dcaegen2 / prh-testcases / resources / prh_library.robot
1 *** Settings ***
2 Library           RequestsLibrary
3 Library           Collections
4 Library           PrhLibrary.py
5 Resource          ../../../common.robot
6
7 *** Keywords ***
8 Verify PNF ready sent
9     [Arguments]    ${test_case_directory}
10     ${pnf_entry}=    Get Data From File    ${test_case_directory}/aai-entry.json
11     ${ves_event}=    Get Data From File    ${test_case_directory}/ves-event.json
12     ${expected_pnf_ready_event}=    Get Data From File    ${test_case_directory}/expected-pnf-ready-event.json
13     Add PNF entry in AAI    ${pnf_entry}
14     Set VES event in DMaaP    ${ves_event}
15     Wait Until Keyword Succeeds    10x    3000ms    Check CBS ready
16     Wait Until Keyword Succeeds    10x    3000ms    Check created PNF_READY notification    ${expected_pnf_ready_event}
17
18 Verify PNF ready sent and logical link created
19     [Arguments]    ${test_case_directory}
20     ${expected_logical_link}=    Get Data From File    ${test_case_directory}/expected-logical-link.json
21     Verify PNF ready sent    ${test_case_directory}
22     Check created Logical Link   ${expected_logical_link}
23
24 Verify event with missing required field is logged
25     [Arguments]    ${test_case_directory}
26     ${invalid_ves_event}=    Get Data From File    ${test_case_directory}/invalid-ves-event.json
27     Set VES event in DMaaP    ${invalid_ves_event}
28     ${notification}=    Create invalid notification    ${invalid_ves_event}
29     ${error_msg}=    Set Variable    Incorrect json, consumerDmaapModel can not be created:
30     Wait Until Keyword Succeeds    10x    3000ms    Check PRH json log    ${error_msg}    ${notification}
31
32 Verify incorrect JSON event is logged
33     [Timeout]    60s
34     [Arguments]    ${test_case_directory}
35     ${invalid_ves_event}=    Get Data From File    ${test_case_directory}/invalid-ves-event.json
36     Set VES event in DMaaP    ${invalid_ves_event}
37     Check PRH log    |com.google.gson.JsonSyntaxException: Expected a com.google.gson.JsonArray
38
39 Verify missing AAI record is logged
40     [Timeout]    100s
41     [Arguments]    ${test_case_directory}
42     ${incorrect_aai_entry}=    Get Data From File    ${test_case_directory}/incorrect-aai-entry.json
43     ${ves_event}=    Get Data From File    ${test_case_directory}/ves-event.json
44     Add PNF entry in AAI    ${incorrect_aai_entry}
45     Set VES event in DMaaP    ${ves_event}
46     Check PRH log    Request failed for URL 'https://aai:3334/aai/v12/network/pnfs/pnf/NOK6061ZW8'. Response code: 404 Not Found
47
48 Verify AAI not responding is logged
49     [Timeout]    100s
50     [Arguments]    ${test_case_directory}
51     ${ves_event}=    Get Data From File    ${test_case_directory}/ves-event.json
52     Ensure Container Is Exited    aai_simulator
53     Set VES event in DMaaP    ${ves_event}
54     Check PRH log    connection timed out: aai    Host is unreachable: aai
55     Ensure Container Is Running   aai_simulator
56
57 Verify PNF re registration
58     [Timeout]    100s
59     [Arguments]    ${test_case_directory}
60     ${expected_logical_link}=    Get Data From File    ${test_case_directory}/expected-logical-link.json
61     Verify PNF ready sent    ${test_case_directory}
62     Check created Logical Link    ${expected_logical_link}
63
64     ${ves_event}=    Get Data From File    ${test_case_directory}/ves-event.json
65     Set VES event in DMaaP    ${ves_event}
66     ${expected_pnf_update_event}=    Get Data From File    ${test_case_directory}/expected-pnf-update-event.json
67     Wait Until Keyword Succeeds    10x    3000ms    Check created PNF_UPDATE notification    ${expected_pnf_update_event}
68
69 Check CBS ready
70     ${resp}=    Get Request    ${consul_setup_session}    /v1/catalog/services
71     Should Be Equal As Strings    ${resp.status_code}    200
72     Log    Service Catalog response: ${resp.content}
73     Dictionary Should Contain Key    ${resp.json()}    cbs    |Consul service catalog should contain CBS entry
74
75 Check created PNF_READY notification
76     [Arguments]    ${expected_event_pnf_ready_in_dpaap}
77     ${resp}=    Get Request    ${dmaap_setup_session}    /verify/pnf_ready    headers=${suite_headers}
78     Should Be Equal As Strings    ${resp.status_code}    200
79     Should Be Equal As JSON    ${resp.content}    ${expected_event_pnf_ready_in_dpaap}
80
81 Check created PNF_UPDATE notification
82     [Arguments]    ${expected_event_pnf_update_in_dpaap}
83     ${resp}=    Get Request    ${dmaap_setup_session}    /verify/pnf_update    headers=${suite_headers}
84     Log    Response from DMaaP: ${resp.content}
85     Should Be Equal As Strings    ${resp.status_code}    200
86     #Should Be Equal As JSON    ${resp.content}    ${expected_event_pnf_ready_in_dpaap}
87
88 Check created Logical Link
89     [Arguments]    ${expected_logical_link_in_aai}
90     ${resp}=    Get Request    ${aai_setup_session}    /verify/created_logical_link    headers=${suite_headers}
91     Should Be Equal As Strings    ${resp.status_code}    200
92     Should Be Equal As JSON    ${resp.content}    ${expected_logical_link_in_aai}
93
94 Check PRH log
95     [Arguments]    @{log_entries}
96     ${found}=    Find one of log entryies    ${log_entries}
97     Should Be True    ${found}
98
99 Check PRH json log
100     [Arguments]    ${prefix}    ${json}
101     ${found}=    Find log json    ${prefix}    ${json}
102     Should Be True    ${found}
103
104 Create event parsing error
105     [Arguments]    ${ves_event}
106     ${notification}=    Create invalid notification    ${ves_event}
107     ${error_msg}=    Catenate    SEPARATOR= \\n    |Incorrect json, consumerDmaapModel can not be created:     ${notification}
108     [Return]    ${error_msg}
109
110 Add PNF entry in AAI
111     [Arguments]    ${pnf_entry}
112     ${headers}=    Create Dictionary    Accept=application/json    Content-Type=application/json
113     Log    AAI url ${AAI_SIMULATOR_SETUP_URL}
114     ${resp}=    Put Request    ${aai_setup_session}    /setup/add_pnf_entry    headers=${suite_headers}    data=${pnf_entry}
115     Should Be Equal As Strings    ${resp.status_code}    200
116
117 Set VES event in DMaaP
118     [Arguments]    ${ves_event}
119     ${resp}=    Put Request    ${dmaap_setup_session}    /setup/ves_event    headers=${suite_headers}    data=${ves_event}
120     Should Be Equal As Strings    ${resp.status_code}    200
121
122 Should Be Equal As JSON
123     [Arguments]    ${actual}    ${expected}
124     Log    EXPECTED: ${expected}
125     Log    ACTUAL: ${actual}
126     ${expected_json}=    Evaluate    json.loads("""${expected}""")    json
127     ${actual_json}=    Evaluate    json.loads("""${actual}""")    json
128     Should Be Equal    ${actual_json}    ${expected_json}
129
130 Create sessions
131     Create Session    dmaap_setup_session    ${DMAAP_SIMULATOR_SETUP_URL}
132     Set Suite Variable    ${dmaap_setup_session}    dmaap_setup_session
133     Create Session    aai_setup_session    ${AAI_SIMULATOR_SETUP_URL}
134     Set Suite Variable    ${aai_setup_session}    aai_setup_session
135     Create Session    consul_setup_session    ${CONSUL_SETUP_URL}
136     Set Suite Variable    ${consul_setup_session}    consul_setup_session
137
138 Reset Simulators
139     Reset AAI simulator
140     Reset DMaaP simulator
141
142 Reset AAI simulator
143     ${resp}=    Post Request     ${aai_setup_session}    /reset
144     Should Be Equal As Strings    ${resp.status_code}    200
145
146 Reset DMaaP simulator
147     ${resp}=    Post Request     ${dmaap_setup_session}    /reset
148     Should Be Equal As Strings    ${resp.status_code}    200
149
150 Create headers
151     ${headers}=    Create Dictionary    Accept=application/json    Content-Type=application/json
152     Set Suite Variable    ${suite_headers}    ${headers}