blob: 2dc846282bb3e3f84c4d130251705ae96a98f99a [file] [log] [blame]
Saryu Shahcbc6cd12017-11-08 23:13:31 +00001
2.. This work is licensed under a Creative Commons Attribution 4.0 International License.
3.. http://creativecommons.org/licenses/by/4.0
4
5**********************************************************
6Tutorial: Testing the VOLTE Use Case in a standalone PDP-D
7**********************************************************
8
9.. contents::
10 :depth: 3
11
12In this tutorial we will go over how to access and start up the PDP-D, setup the prerequisites for the VOLTE flow, enable/disable the VFC Simulator that will be used in the VOLTE flow, and inject messages to trigger the VOLTE flow.
13
14Accessing and starting the PDP-D
15^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
16
17The 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
23The 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
25Once 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
31The 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
38Prerequisites for the VOLTE flow
39^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
40
41In order to trigger the VOLTE 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 VOLTE ONSET message.
42
43Navigate 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
51Next, we're going to create a file named *dcae.volte.onset.json* and edit it to paste the VOLTE ONSET message contents.
52
53 .. code-block:: bash
54
55 touch dcae.volte.onset.json
56 vi dcae.volte.onset.json
57
58Here are the contents of the VOLTE ONSET message. Copy/paste this into dcae.volte.onset.json:
59
60 .. code-block:: json
Saryu Shahcbc6cd12017-11-08 23:13:31 +000061
Saryu Shah65640a22018-10-18 01:19:03 +000062 {
63 "closedLoopControlName": "ControlLoop-VOLTE-2179b738-fd36-4843-a71a-a8c24c70c55b",
64 "closedLoopAlarmStart": 1484677482204798,
65 "closedLoopEventClient": "DCAE.HolmesInstance",
66 "closedLoopEventStatus": "ONSET",
67 "requestID": "97964e10-686e-4790-8c45-bdfa61df770f",
68 "target_type": "VM",
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 "service-instance.service-instance-id" : "vserver-name-16102016-aai3255-data-11-1",
75 "generic-vnf.vnf-id" : "vnf-id-16102016-aai3255-data-11-1",
76 "generic-vnf.vnf-name" : "vnf-name-16102016-aai3255-data-11-1"
77 },
78 "from": "DCAE",
79 "version": "1.0.2"
80 }
81
Saryu Shahcbc6cd12017-11-08 23:13:31 +000082
83Enabling the VFC Simulator
84^^^^^^^^^^^^^^^^^^^^^^^^^^
85
86Enabling 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:
87
88 .. code-block:: bash
89
90 policy stop
91 features enable controlloop-utils
92 policy start
93
94Now, 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 VFC simulator.
95
96Injecting an ONSET to trigger the VOLTE Flow
97^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
98
99We are now ready to inject an ONSET message to trigger the VOLTE flow. Simply navigate back to the directory *dcae.volte.onset.json* file is saved (i.e. cd /tmp/util) and run this curl command:
100
101 .. code-block:: bash
102
Saryu Shah65640a22018-10-18 01:19:03 +0000103 http --verify=no --default-scheme=https -a @1b3rt:31nst31n PUT :9696/policy/pdp/engine/topics/sources/ueb/unauthenticated.DCAE_CL_OUTPUT/events @dcae.volte.onset.json Content-Type:"text/plain"
Saryu Shahcbc6cd12017-11-08 23:13:31 +0000104
105You should see some output similar to this:
106
107.. image:: tutorial_VOLTE_1.png
108
109You 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*.
110
111Reading the logs
112^^^^^^^^^^^^^^^^
113
114Once you've injected the onset message, this should appear in the network.log:
115
116.. image:: tutorial_VOLTE_2.png
117
118
119End of Document
120
121.. SSNote: Wiki page ref. https://wiki.onap.org/display/DW/Tutorial%3A+Testing+the+VOLTE+Use+Case+in+a+standalone+PDP-D