Merge "Split docker-compose file logs"
diff --git a/tests/dcaegen2/prh-testcases/assets/json_events/ves-event-pnf-registration-simple.json b/tests/dcaegen2/prh-testcases/assets/json_events/ves-event-pnf-registration-simple.json
new file mode 100644
index 0000000..c308967
--- /dev/null
+++ b/tests/dcaegen2/prh-testcases/assets/json_events/ves-event-pnf-registration-simple.json
@@ -0,0 +1,14 @@
+{
+ "event": {
+ "commonEventHeader": {
+ "sourceName":"NOK6061ZW1",
+ "nfNamingCode": "nfNamingCode"
+ },
+ "pnfRegistrationFields": {
+ "serialNumber":"serialNumber",
+ "vendorName":"vendorName",
+ "modelNumber":"modelNumber",
+ "unitType":"unitType"
+ }
+ }
+}
\ No newline at end of file
diff --git a/tests/dcaegen2/prh-testcases/assets/json_events/ves-event-pnf-registration-with-attachment-point.json b/tests/dcaegen2/prh-testcases/assets/json_events/ves-event-pnf-registration-with-attachment-point.json
new file mode 100644
index 0000000..9d730bf
--- /dev/null
+++ b/tests/dcaegen2/prh-testcases/assets/json_events/ves-event-pnf-registration-with-attachment-point.json
@@ -0,0 +1,19 @@
+{
+ "event": {
+ "commonEventHeader": {
+ "sourceName":"NOK6061ZW1",
+ "nfNamingCode": "nfNamingCode"
+ },
+ "pnfRegistrationFields": {
+ "serialNumber":"serialNumber",
+ "vendorName":"vendorName",
+ "modelNumber":"modelNumber",
+ "unitType":"unitType",
+ "additionalFields": {
+ "attachmentPoint": "bla-bla-30-3",
+ "svlan": "1005",
+ "cvlan": "678"
+ }
+ }
+ }
+}
\ No newline at end of file
diff --git a/tests/dcaegen2/prh-testcases/prh_tests.robot b/tests/dcaegen2/prh-testcases/prh_tests.robot
index 701a714..31a7d0d 100644
--- a/tests/dcaegen2/prh-testcases/prh_tests.robot
+++ b/tests/dcaegen2/prh-testcases/prh_tests.robot
@@ -11,6 +11,8 @@
*** Variables ***
${DMAAP_SIMULATOR_SETUP_URL} http://${DMAAP_SIMULATOR_SETUP}
${AAI_SIMULATOR_SETUP_URL} http://${AAI_SIMULATOR_SETUP}
+
+${VES_EVENT_PNF_REGISTRATION_SIMPLE} %{WORKSPACE}/tests/dcaegen2/prh-testcases/assets/json_events/ves-event-pnf-registration-simple.json
${EVENT_WITH_ALL_VALID_REQUIRED_FIELDS} %{WORKSPACE}/tests/dcaegen2/prh-testcases/assets/json_events/event_with_all_fields.json
${EVENT_WITH_IPV4} %{WORKSPACE}/tests/dcaegen2/prh-testcases/assets/json_events/event_with_IPV4.json
${EVENT_WITH_IPV6} %{WORKSPACE}/tests/dcaegen2/prh-testcases/assets/json_events/event_with_IPV6.json
@@ -31,24 +33,25 @@
[Documentation] PRH get valid event from DMaaP with required fields - PRH produce PNF_READY notification
[Tags] PRH Valid event
[Template] Valid event processing
- ${EVENT_WITH_ALL_VALID_REQUIRED_FIELDS}
- ${EVENT_WITH_IPV4}
- ${EVENT_WITH_IPV6}
- ${EVENT_WITHOUT_IPV6_FILED}
- ${EVENT_WITH_OPTIONAL_REGISTRATION_FIELDS_ALL_FILLED}
- ${EVENT_WITH_OPTIONAL_REGISTRATION_FIELDS_EMPTY}
- ${EVENT_WITH_OPTIONAL_REGISTRATION_FIELDS_MISSING_ALL}
- ${EVENT_WITH_OPTIONAL_REGISTRATION_FIELDS_MISSING_PARTIAL}
+ ${VES_EVENT_PNF_REGISTRATION_SIMPLE}
+ #${EVENT_WITH_ALL_VALID_REQUIRED_FIELDS}
+ #${EVENT_WITH_IPV4}
+ #${EVENT_WITH_IPV6}
+ #${EVENT_WITHOUT_IPV6_FILED}
+ #${EVENT_WITH_OPTIONAL_REGISTRATION_FIELDS_ALL_FILLED}
+ #${EVENT_WITH_OPTIONAL_REGISTRATION_FIELDS_EMPTY}
+ #${EVENT_WITH_OPTIONAL_REGISTRATION_FIELDS_MISSING_ALL}
+ #${EVENT_WITH_OPTIONAL_REGISTRATION_FIELDS_MISSING_PARTIAL}
Invalid DMaaP event cannot be converted to PNF_READY notification
[Documentation] PRH get invalid event from DMaaP with missing required fields - PRH does not produce PNF_READY notification
[Tags] PRH Invalid event
[Template] Invalid event processing
- ${EVENT_WITH_MISSING_IPV4_AND_IPV6}
+ #${EVENT_WITH_MISSING_IPV4_AND_IPV6}
${EVENT_WITH_MISSING_SOURCENAME}
- ${EVENT_WITH_MISSING_SOURCENAME_AND_IPV4}
- ${EVENT_WITH_MISSING_SOURCENAME_AND_IPV6}
- ${EVENT_WITH_MISSING_SOURCENAME_IPV4_AND_IPV6}
+ #${EVENT_WITH_MISSING_SOURCENAME_AND_IPV4}
+ #${EVENT_WITH_MISSING_SOURCENAME_AND_IPV6}
+ #${EVENT_WITH_MISSING_SOURCENAME_IPV4_AND_IPV6}
Get valid event from DMaaP and record in AAI does not exist
[Documentation] PRH get valid event from DMaaP with all required fields and in AAI record doesn't exist - PRH does not produce PNF_READY notification
diff --git a/tests/dcaegen2/prh-testcases/resources/prh_library.robot b/tests/dcaegen2/prh-testcases/resources/prh_library.robot
index 9d4dca2..a6a01eb 100644
--- a/tests/dcaegen2/prh-testcases/resources/prh_library.robot
+++ b/tests/dcaegen2/prh-testcases/resources/prh_library.robot
@@ -53,9 +53,9 @@
Set PNF name in AAI
[Arguments] ${pnf_name}
${headers}= Create Dictionary Accept=application/json Content-Type=text/html
- #Log AAI url ${AAI_SIMULATOR_SETUP_URL}
- #Log Http headers ${headers}
- #Log PNF name ${pnf_name}
+ Log AAI url ${AAI_SIMULATOR_SETUP_URL}
+ Log Http headers ${headers}
+ Log PNF name ${pnf_name}
${resp}= Put Request ${aai_setup_session} /set_pnf headers=${headers} data=${pnf_name}
Should Be Equal As Strings ${resp.status_code} 200
diff --git a/tests/dcaegen2/prh-testcases/resources/simulator/AAI.py b/tests/dcaegen2/prh-testcases/resources/simulator/AAI.py
index 91a93de..bd76c61 100644
--- a/tests/dcaegen2/prh-testcases/resources/simulator/AAI.py
+++ b/tests/dcaegen2/prh-testcases/resources/simulator/AAI.py
@@ -1,4 +1,5 @@
import logging
+import json
import sys
import re
import time
@@ -16,22 +17,29 @@
logger = logging.getLogger('AAI-simulator-logger')
pnfs = 'Empty'
-pnf_entry = 'Empty'
+pnf_entry = {}
+
+
+def _mark_response_as_http_ok(http_endpoint):
+ logger.info('Execution status 200')
+ httpServerLib.header_200_and_json(http_endpoint)
+
class AAISetup(BaseHTTPRequestHandler):
def do_PUT(self):
logger.info('AAI SIM Setup Put execution')
- if re.search('/set_pnf', self.path):
+ if re.search('/set_pnf$', self.path):
global pnfs
- content_length = int(self.headers['Content-Length'])
+ content_length = self._get_content_length()
pnfs = self.rfile.read(content_length)
- logger.info('Execution status 200')
- httpServerLib.header_200_and_json(self)
+ _mark_response_as_http_ok(self)
if re.search('/set_pnf_entry',self.path):
- logger.info('Execution status 200')
- httpServerLib.header_200_and_json(self)
+ global pnf_entry
+ content_length = self._get_content_length()
+ pnf_entry = json.loads(self.rfile.read(content_length))
+ _mark_response_as_http_ok(self)
return
@@ -40,14 +48,26 @@
if re.search('/reset', self.path):
global pnfs
pnfs = 'Empty'
- logger.info('Execution status 200')
- httpServerLib.header_200_and_json(self)
+ _mark_response_as_http_ok(self)
return
+ def _get_content_length(self):
+ return int(self.headers['Content-Length'])
+
class AAIHandler(BaseHTTPRequestHandler):
+ def do_GET(self):
+ logger.info('AAI SIM Get execution')
+ if re.search('/get_pnf_entry', self.path):
+ _mark_response_as_http_ok(self)
+ body = json.dumps(pnf_entry)
+ self.wfile.write(body.encode())
+
+ return
+
+
def do_PATCH(self):
logger.info('AAI SIM Patch execution')
pnfs_name = '/aai/v12/network/pnfs/pnf/' + pnfs.decode()
diff --git a/tests/dcaegen2/prh-testcases/ssl_prh_tests.robot b/tests/dcaegen2/prh-testcases/ssl_prh_tests.robot
index 49d2c45..111a4fb 100644
--- a/tests/dcaegen2/prh-testcases/ssl_prh_tests.robot
+++ b/tests/dcaegen2/prh-testcases/ssl_prh_tests.robot
@@ -11,6 +11,8 @@
*** Variables ***
${DMAAP_SIMULATOR_SETUP_URL} http://${DMAAP_SIMULATOR_SETUP}
${AAI_SIMULATOR_SETUP_URL} http://${AAI_SIMULATOR_SETUP}
+
+${VES_EVENT_PNF_REGISTRATION_SIMPLE} %{WORKSPACE}/tests/dcaegen2/prh-testcases/assets/json_events/ves-event-pnf-registration-simple.json
${EVENT_WITH_ALL_VALID_REQUIRED_FIELDS} %{WORKSPACE}/tests/dcaegen2/prh-testcases/assets/json_events/event_with_all_fields.json
${EVENT_WITH_IPV4} %{WORKSPACE}/tests/dcaegen2/prh-testcases/assets/json_events/event_with_IPV4.json
${EVENT_WITH_IPV6} %{WORKSPACE}/tests/dcaegen2/prh-testcases/assets/json_events/event_with_IPV6.json
@@ -21,7 +23,8 @@
[Documentation] PRH get valid event from DMaaP with required fields - PRH produce PNF_READY notification
[Tags] PRH Valid event
[Template] Valid event processing
- ${EVENT_WITH_ALL_VALID_REQUIRED_FIELDS}
- ${EVENT_WITH_IPV4}
- ${EVENT_WITH_IPV6}
- ${EVENT_WITHOUT_IPV6_FILED}
+ ${VES_EVENT_PNF_REGISTRATION_SIMPLE}
+ #${EVENT_WITH_ALL_VALID_REQUIRED_FIELDS}
+ #${EVENT_WITH_IPV4}
+ #${EVENT_WITH_IPV6}
+ #${EVENT_WITHOUT_IPV6_FILED}