Saryu Shah | 7c24c8a | 2017-11-08 21:20:04 +0000 | [diff] [blame] | 1 | |
| 2 | .. This work is licensed under a Creative Commons Attribution 4.0 International License. |
| 3 | .. http://creativecommons.org/licenses/by/4.0 |
| 4 | |
| 5 | ********************************************************* |
| 6 | Tutorial: Testing the vDNS Use Case in a standalone PDP-D |
| 7 | ********************************************************* |
| 8 | |
| 9 | .. contents:: |
| 10 | :depth: 3 |
| 11 | |
| 12 | In this tutorial we will go over how to access and start up the PDP-D, setup the prerequisites for the vDNS flow, enable/disable the AAI and SO Simulators that will be used in the vDNS flow, and inject messages to trigger the vDNS flow. |
| 13 | |
| 14 | Accessing and starting the PDP-D |
| 15 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 16 | |
| 17 | The first step is to access the docker container of name *drools*. |
| 18 | |
| 19 | .. code-block:: bash |
| 20 | |
| 21 | docker exec -it -u 0 drools su - policy |
| 22 | |
| 23 | The PDP-D software is installed under the *policy* account, the policy root directory is under *${POLICY_HOME}* environment variable and it may be changed on a per installation basis. It is typically set up under the */opt/app/policy* directory but can be changed during installation. All PDP-D software runs with non-root privileges as *policy* is a regular user account. |
| 24 | |
| 25 | Once within the drools container, the running status can be observed by using the *policy* command: |
| 26 | |
| 27 | .. code-block:: bash |
| 28 | |
| 29 | policy [--debug] status|start|stop |
| 30 | |
| 31 | The running status of the PDP-D can be observed with *policy status* |
| 32 | |
| 33 | .. code-block:: bash |
| 34 | |
| 35 | policy@drools:~$ policy status [drools-pdp-controllers] L []: Policy Management (pid 1500) is running 1 cron jobs installed. |
| 36 | |
| 37 | |
| 38 | Prerequisites for the vDNS flow |
| 39 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 40 | |
| 41 | In order to trigger the vDNS flow we will need to inject an ONSET message via curl command. We're going to create a temporary *util* directory to store a file that contains the vDNS ONSET message. |
| 42 | |
| 43 | Navigate to */tmp* and create directory *util*. *util* is just a temporary folder we've created to use as our 'workspace'. |
| 44 | |
| 45 | .. code-block:: bash |
| 46 | |
| 47 | cd /tmp |
| 48 | mkdir util |
| 49 | |
| 50 | |
| 51 | Next, we're going to create a file named *dcae.vdns.onset.json* and edit it to paste the vDNS ONSET message contents. |
| 52 | |
| 53 | .. code-block:: bash |
| 54 | |
| 55 | touch dcae.vdns.onset.json |
Saryu Shah | cbc6cd1 | 2017-11-08 23:13:31 +0000 | [diff] [blame] | 56 | vi dcae.vdns.onset.json |
Saryu Shah | 7c24c8a | 2017-11-08 21:20:04 +0000 | [diff] [blame] | 57 | |
| 58 | Here are the contents of the vDNS ONSET message. Copy/paste this into dcae.vdns.onset.json: |
| 59 | |
Saryu Shah | cbc6cd1 | 2017-11-08 23:13:31 +0000 | [diff] [blame] | 60 | .. code-block:: json |
Saryu Shah | 7c24c8a | 2017-11-08 21:20:04 +0000 | [diff] [blame] | 61 | |
Saryu Shah | 28d8a3e | 2018-10-17 00:27:13 +0000 | [diff] [blame] | 62 | { |
| 63 | "closedLoopControlName": "ControlLoop-vDNS-6f37f56d-a87d-4b85-b6a9-cc953cf779b3", |
| 64 | "closedLoopAlarmStart": 1484677482204798, |
| 65 | "closedLoopEventClient": "DCAE_INSTANCE_ID.dcae-tca", |
| 66 | "closedLoopEventStatus": "ONSET", |
| 67 | "requestID": "e4f95e0c-a013-4530-8e59-c5c5f9e539b6", |
| 68 | "target_type": "VNF", |
| 69 | "target": "vserver.vserver-name", |
| 70 | "AAI": { |
| 71 | "vserver.is-closed-loop-disabled": "false", |
| 72 | "vserver.prov-status": "ACTIVE", |
| 73 | "vserver.vserver-name": "dfw1lb01lb01" |
| 74 | }, |
| 75 | "from": "DCAE", |
| 76 | "version": "1.0.2" |
Saryu Shah | cbc6cd1 | 2017-11-08 23:13:31 +0000 | [diff] [blame] | 77 | } |
Saryu Shah | 28d8a3e | 2018-10-17 00:27:13 +0000 | [diff] [blame] | 78 | |
Saryu Shah | 7c24c8a | 2017-11-08 21:20:04 +0000 | [diff] [blame] | 79 | |
| 80 | |
| 81 | Enabling the AAI and SO Simulators |
| 82 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 83 | |
| 84 | Enabling the *controlloop-utils* feature will enable the simulators. To do this, simply stop the drools pdp, enable the feature, and restart the drools pdp like so: |
| 85 | |
| 86 | .. code-block:: bash |
| 87 | |
| 88 | policy stop |
| 89 | features enable controlloop-utils |
| 90 | policy start |
| 91 | |
| 92 | Now, in */opt/app/policy/config/* directory, you should see a new properties file named *simulators.properties.environment*. In here you will find the credentials for the AAI and SO simulators. |
| 93 | |
| 94 | Injecting an ONSET to trigger the vDNS Flow |
| 95 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 96 | |
| 97 | We are now ready to inject an ONSET message to trigger the vDNS flow. Simply navigate back to the directory *dcae.vdns.onset.json* file is saved (i.e. cd /tmp/util) and run this curl command: |
| 98 | |
| 99 | .. code-block:: bash |
| 100 | |
Saryu Shah | 28d8a3e | 2018-10-17 00:27:13 +0000 | [diff] [blame] | 101 | http --verify=no --default-scheme=https -a @1b3rt:31nst31n PUT :9696/policy/pdp/engine/topics/sources/ueb/unauthenticated.DCAE_CL_OUTPUT/events @dcae.vdns.onset.json Content-Type:"text/plain" |
Saryu Shah | 7c24c8a | 2017-11-08 21:20:04 +0000 | [diff] [blame] | 102 | |
| 103 | You should see some output similar to this: |
| 104 | |
Saryu Shah | 28d8a3e | 2018-10-17 00:27:13 +0000 | [diff] [blame] | 105 | .. image:: tutorial_vDNS_1.png |
Saryu Shah | 7c24c8a | 2017-11-08 21:20:04 +0000 | [diff] [blame] | 106 | |
| 107 | You can view the logs to see the network activity or find any errors that may have occurred. Logs are located in */opt/app/policy/logs*. |
| 108 | |
| 109 | Reading the logs |
| 110 | ^^^^^^^^^^^^^^^^ |
| 111 | |
| 112 | Once you've injected the onset message, this should appear in the network.log: |
| 113 | |
Saryu Shah | 28d8a3e | 2018-10-17 00:27:13 +0000 | [diff] [blame] | 114 | .. image:: tutorial_vDNS_2.png |
Saryu Shah | 7c24c8a | 2017-11-08 21:20:04 +0000 | [diff] [blame] | 115 | |
| 116 | |
| 117 | End of Document |
| 118 | |
Saryu Shah | 28d8a3e | 2018-10-17 00:27:13 +0000 | [diff] [blame] | 119 | .. SSNote: Wiki page ref. https://wiki.onap.org/display/DW/Tutorial%3A+Testing+the+vDNS+Use+Case+in+a+standalone+PDP-D |