aboutsummaryrefslogtreecommitdiffstats
path: root/docs/development
diff options
context:
space:
mode:
Diffstat (limited to 'docs/development')
-rw-r--r--docs/development/devtools/distribution-s3p-results/dist_stability_monitor.PNGbin81517 -> 0 bytes
-rw-r--r--docs/development/devtools/distribution-s3p-results/dist_stability_statistics.PNGbin53205 -> 0 bytes
-rw-r--r--docs/development/devtools/distribution-s3p-results/dist_stability_threads.PNGbin77025 -> 0 bytes
-rw-r--r--docs/development/devtools/distribution-s3p-results/dist_stability_threshold.PNGbin28238 -> 0 bytes
-rw-r--r--docs/development/devtools/distribution-s3p-results/distribution-jmeter-testcases.pngbin0 -> 68050 bytes
-rw-r--r--docs/development/devtools/distribution-s3p-results/distribution-s3p-testplan.pngbin53609 -> 0 bytes
-rw-r--r--docs/development/devtools/distribution-s3p-results/distribution-s3p-vvm-sample.pngbin139259 -> 0 bytes
-rw-r--r--docs/development/devtools/distribution-s3p-results/distribution-visualvm-snapshot.pngbin0 -> 28049 bytes
-rw-r--r--docs/development/devtools/distribution-s3p-results/performance-statistics.pngbin93384 -> 105215 bytes
-rw-r--r--docs/development/devtools/distribution-s3p-results/performance-threshold.pngbin62947 -> 68979 bytes
-rw-r--r--docs/development/devtools/distribution-s3p-results/stability-monitor.pngbin0 -> 27304 bytes
-rw-r--r--docs/development/devtools/distribution-s3p-results/stability-statistics.pngbin0 -> 98335 bytes
-rw-r--r--docs/development/devtools/distribution-s3p-results/stability-threads.pngbin0 -> 47752 bytes
-rw-r--r--docs/development/devtools/distribution-s3p-results/stability-threshold.pngbin0 -> 62425 bytes
-rw-r--r--docs/development/devtools/distribution-s3p.rst58
-rw-r--r--docs/development/devtools/policy-participant-smoke.rst76
16 files changed, 96 insertions, 38 deletions
diff --git a/docs/development/devtools/distribution-s3p-results/dist_stability_monitor.PNG b/docs/development/devtools/distribution-s3p-results/dist_stability_monitor.PNG
deleted file mode 100644
index 83eae8cc..00000000
--- a/docs/development/devtools/distribution-s3p-results/dist_stability_monitor.PNG
+++ /dev/null
Binary files differ
diff --git a/docs/development/devtools/distribution-s3p-results/dist_stability_statistics.PNG b/docs/development/devtools/distribution-s3p-results/dist_stability_statistics.PNG
deleted file mode 100644
index dce9b7cc..00000000
--- a/docs/development/devtools/distribution-s3p-results/dist_stability_statistics.PNG
+++ /dev/null
Binary files differ
diff --git a/docs/development/devtools/distribution-s3p-results/dist_stability_threads.PNG b/docs/development/devtools/distribution-s3p-results/dist_stability_threads.PNG
deleted file mode 100644
index 13e27c99..00000000
--- a/docs/development/devtools/distribution-s3p-results/dist_stability_threads.PNG
+++ /dev/null
Binary files differ
diff --git a/docs/development/devtools/distribution-s3p-results/dist_stability_threshold.PNG b/docs/development/devtools/distribution-s3p-results/dist_stability_threshold.PNG
deleted file mode 100644
index d65e8cc3..00000000
--- a/docs/development/devtools/distribution-s3p-results/dist_stability_threshold.PNG
+++ /dev/null
Binary files differ
diff --git a/docs/development/devtools/distribution-s3p-results/distribution-jmeter-testcases.png b/docs/development/devtools/distribution-s3p-results/distribution-jmeter-testcases.png
new file mode 100644
index 00000000..db28a7b2
--- /dev/null
+++ b/docs/development/devtools/distribution-s3p-results/distribution-jmeter-testcases.png
Binary files differ
diff --git a/docs/development/devtools/distribution-s3p-results/distribution-s3p-testplan.png b/docs/development/devtools/distribution-s3p-results/distribution-s3p-testplan.png
deleted file mode 100644
index 7a8559ce..00000000
--- a/docs/development/devtools/distribution-s3p-results/distribution-s3p-testplan.png
+++ /dev/null
Binary files differ
diff --git a/docs/development/devtools/distribution-s3p-results/distribution-s3p-vvm-sample.png b/docs/development/devtools/distribution-s3p-results/distribution-s3p-vvm-sample.png
deleted file mode 100644
index 4b2aa663..00000000
--- a/docs/development/devtools/distribution-s3p-results/distribution-s3p-vvm-sample.png
+++ /dev/null
Binary files differ
diff --git a/docs/development/devtools/distribution-s3p-results/distribution-visualvm-snapshot.png b/docs/development/devtools/distribution-s3p-results/distribution-visualvm-snapshot.png
new file mode 100644
index 00000000..03b73d36
--- /dev/null
+++ b/docs/development/devtools/distribution-s3p-results/distribution-visualvm-snapshot.png
Binary files differ
diff --git a/docs/development/devtools/distribution-s3p-results/performance-statistics.png b/docs/development/devtools/distribution-s3p-results/performance-statistics.png
index 6530a1bc..e6218537 100644
--- a/docs/development/devtools/distribution-s3p-results/performance-statistics.png
+++ b/docs/development/devtools/distribution-s3p-results/performance-statistics.png
Binary files differ
diff --git a/docs/development/devtools/distribution-s3p-results/performance-threshold.png b/docs/development/devtools/distribution-s3p-results/performance-threshold.png
index df15ba0f..85c2f5d4 100644
--- a/docs/development/devtools/distribution-s3p-results/performance-threshold.png
+++ b/docs/development/devtools/distribution-s3p-results/performance-threshold.png
Binary files differ
diff --git a/docs/development/devtools/distribution-s3p-results/stability-monitor.png b/docs/development/devtools/distribution-s3p-results/stability-monitor.png
new file mode 100644
index 00000000..2d2848d9
--- /dev/null
+++ b/docs/development/devtools/distribution-s3p-results/stability-monitor.png
Binary files differ
diff --git a/docs/development/devtools/distribution-s3p-results/stability-statistics.png b/docs/development/devtools/distribution-s3p-results/stability-statistics.png
new file mode 100644
index 00000000..04cd9063
--- /dev/null
+++ b/docs/development/devtools/distribution-s3p-results/stability-statistics.png
Binary files differ
diff --git a/docs/development/devtools/distribution-s3p-results/stability-threads.png b/docs/development/devtools/distribution-s3p-results/stability-threads.png
new file mode 100644
index 00000000..a2e9e9f0
--- /dev/null
+++ b/docs/development/devtools/distribution-s3p-results/stability-threads.png
Binary files differ
diff --git a/docs/development/devtools/distribution-s3p-results/stability-threshold.png b/docs/development/devtools/distribution-s3p-results/stability-threshold.png
new file mode 100644
index 00000000..a9cc71eb
--- /dev/null
+++ b/docs/development/devtools/distribution-s3p-results/stability-threshold.png
Binary files differ
diff --git a/docs/development/devtools/distribution-s3p.rst b/docs/development/devtools/distribution-s3p.rst
index b91e394f..9ae93378 100644
--- a/docs/development/devtools/distribution-s3p.rst
+++ b/docs/development/devtools/distribution-s3p.rst
@@ -14,22 +14,16 @@ VM Details
----------
The stability and performance tests are performed on VM's running in the OpenStack cloud
-environment in the ONAP integration lab. There are two separate VMs, one for running backend policy
-services which policy distribution needs, and the other for the policy distribution service itself
-and Jmeter.
+environment in the ONAP integration lab.
-**OpenStack environment details**
+**Policy VM details**
-- Version: Windriver Titanium
-
-**Policy Backend VM details (VM1)**
-
-- OS: Ubuntu 18.04.5 LTS
-- CPU: 8 core, Intel Xeon E3-12xx v2 (Ivy Bridge), 2693.668 MHz, 16384 kB cache
-- RAM: 32 GB
-- HardDisk: 200 GB
-- Docker version 19.03.8, build afacb8b7f0
-- Java: openjdk 11.0.8 2020-07-14
+- OS: Ubuntu 18.04 LTS (GNU/Linux 4.15.0-151-generic x86_64)
+- CPU: 4 core
+- RAM: 15 GB
+- HardDisk: 39 GB
+- Docker version 20.10.7, build 20.10.7-0ubuntu1~18.04.2
+- Java: openjdk 11.0.11 2021-04-20
Common Setup
@@ -52,9 +46,9 @@ Ensure that the Java version that is executing is OpenJDK version 11
.. code-block:: bash
$ java --version
- openjdk 11.0.8 2020-07-14
- OpenJDK Runtime Environment (build 11.0.8+10-post-Ubuntu-0ubuntu118.04.1)
- OpenJDK 64-Bit Server VM (build 11.0.8+10-post-Ubuntu-0ubuntu118.04.1, mixed mode, sharing)
+ openjdk 11.0.11 2021-04-20
+ OpenJDK Runtime Environment (build 11.0.11+9-Ubuntu-0ubuntu2.18.04)
+ OpenJDK 64-Bit Server VM (build 11.0.11+9-Ubuntu-0ubuntu2.18.04, mixed mode)
Install Docker and Docker Compose
@@ -223,14 +217,14 @@ This will load up the visualVM GUI
Connect to Distribution JMX Port.
- 1. Right click on "Local" in the left panel of the screen and select "Add JMX Connection"
+ 1. On the visualvm toolbar, click on "Add JMX Connection"
2. Enter the Distribution container IP and Port 9090. This is the JMX port exposed by the
distribution container
- 3. Double click on the newly added nodes under "Local" to start monitoring CPU, Memory & GC.
+ 3. Double click on the newly added nodes under "Remotes" to start monitoring CPU, Memory & GC.
Example Screenshot of visualVM
-.. image:: distribution-s3p-results/distribution-s3p-vvm-sample.png
+.. image:: distribution-s3p-results/distribution-visualvm-snapshot.png
Stability Test of Policy Distribution
@@ -261,11 +255,10 @@ The 72h stability test will run the following steps sequentially in a single thr
- **Add CSAR** - Adds CSAR to the directory that distribution is watching
- **Get Healthcheck** - Ensures Healthcheck is returning 200 OK
- **Get Statistics** - Ensures Statistics is returning 200 OK
-- **CheckPDPGroupQuery** - Checks that PDPGroupQuery contains the deployed policy
-- **CheckPolicyDeployed** - Checks that the policy is deployed
-- **Undeploy Policy** - Undeploys the policy
-- **Delete Policy** - Deletes the Policy for the next loop
-- **Check PDP Group for Deletion** - Ensures the policy has been removed and does not exist
+- **Assert PDP Group Query** - Checks that PDPGroupQuery contains the deployed policy
+- **Assert PoliciesDeployed** - Checks that the policy is deployed
+- **Undeploy/Delete Policy** - Undeploys and deletes the Policy for the next loop
+- **Assert PDP Group Query for Deleted Policy** - Ensures the policy has been removed and does not exist
The following steps can be used to configure the parameters of the test plan.
@@ -285,7 +278,7 @@ The following steps can be used to configure the parameters of the test plan.
Screenshot of Distribution stability test plan
-.. image:: distribution-s3p-results/distribution-s3p-testplan.png
+.. image:: distribution-s3p-results/distribution-jmeter-testcases.png
Running the Test Plan
@@ -295,6 +288,11 @@ Check if the /tmp/policydistribution/distributionmount exists as it was created
script execution. If not, run the following commands to create folder and change folder permissions
to allow the testplan to insert the CSAR into the /tmp/policydistribution/distributionmount folder.
+.. note::
+ Make sure that only csar file is being loaded in the watched folder and log generation is in a
+ logs folder, as any sort of zip file can be understood by distribution as a policy file. A
+ logback.xml configuration file is available under setup/distribution folder.
+
.. code-block:: bash
sudo mkdir -p /tmp/policydistribution/distributionmount
@@ -324,13 +322,13 @@ Test Results
**Test Statistics**
-.. image:: distribution-s3p-results/dist_stability_statistics.PNG
-.. image:: distribution-s3p-results/dist_stability_threshold.PNG
+.. image:: distribution-s3p-results/stability-statistics.png
+.. image:: distribution-s3p-results/stability-threshold.png
**VisualVM Screenshots**
-.. image:: distribution-s3p-results/dist_stability_monitor.PNG
-.. image:: distribution-s3p-results/dist_stability_threads.PNG
+.. image:: distribution-s3p-results/stability-monitor.png
+.. image:: distribution-s3p-results/stability-threads.png
Performance Test of Policy Distribution
diff --git a/docs/development/devtools/policy-participant-smoke.rst b/docs/development/devtools/policy-participant-smoke.rst
index 0aeb089e..113e16c5 100644
--- a/docs/development/devtools/policy-participant-smoke.rst
+++ b/docs/development/devtools/policy-participant-smoke.rst
@@ -4,7 +4,6 @@
CLAMP Policy Participant Smoke Tests
------------------------------------
-
1. Introduction
***************
The Smoke testing of the policy participant is executed in a local CLAMP/Policy environment. The CLAMP-Controlloop interfaces interact with the Policy Framework to perform actions based on the state of the policy participant. The goal of the Smoke tests is the ensure that CLAMP Policy Participant and Policy Framework work together as expected.
@@ -22,9 +21,12 @@ This section will show the developer how to set up their environment to start te
2.2 Assumptions
===============
+
- You are accessing the policy repositories through gerrit
- You are using "git review".
+
The following repositories are required for development in this project. These repositories should be present on your machine and you should run "mvn clean install" on all of them so that the packages are present in your .m2 repository.
+
- policy/parent
- policy/common
- policy/models
@@ -36,13 +38,19 @@ In this setup guide, we will be setting up all the components technically requir
2.3 Setting up the components
=============================
+
2.3.1 MariaDB Setup
^^^^^^^^^^^^^^^^^^^
+
We will be using Docker to run our mariadb instance. It will have a total of two databases running in it.
+
- controlloop: the runtime-controlloop db
- policyadmin: the policy-api db
+
The easiest way to do this is to perform a small alteration on an SQL script provided by the clamp backend in the file "runtime/extra/sql/bulkload/create-db.sql"
+
.. code-block:: mysql
+
CREATE DATABASE `controlloop`;
USE `controlloop`;
DROP USER 'policy';
@@ -54,9 +62,13 @@ The easiest way to do this is to perform a small alteration on an SQL script pro
CREATE USER 'policy_user';
GRANT ALL on controlloop.* to 'policy_user' identified by 'policy_user' with GRANT OPTION;
FLUSH PRIVILEGES;
+
Once this has been done, we can run the bash script provided here: "runtime/extra/bin-for-dev/start-db.sh"
+
.. code-block:: bash
+
./start-db.sh
+
This will setup the two databases needed. The database will be exposed locally on port 3306 and will be backed by an anonymous docker volume.
2.3.2 DMAAP Simulator
@@ -64,7 +76,9 @@ This will setup the two databases needed. The database will be exposed locally o
For convenience, a dmaap simulator has been provided in the policy/models repository. To start the simulator, you can do the following:
1. Navigate to /models-sim/policy-models-simulators in the policy/models repository.
2. Add a configuration file to src/test/resources with the following contents:
+
.. code-block:: json
+
{
"dmaapProvider":{
"name":"DMaaP simulator",
@@ -80,15 +94,21 @@ For convenience, a dmaap simulator has been provided in the policy/models reposi
}
]
}
+
3. You can then start dmaap with:
+
.. code-block:: bash
+
mvn exec:java -Dexec.mainClass=org.onap.policy.models.simulators.Main -Dexec.args="src/test/resources/YOUR_CONF_FILE.json"
+
At this stage the dmaap simulator should be running on your local machine on port 3904.
2.3.3 Policy API
^^^^^^^^^^^^^^^^
In the policy-api repo, you should find the file "src/main/resources/etc/defaultConfig.json". This file must be altered slightly - as below with the restServerParameters and databaseProviderParameters shown. Note how the database parameters match-up with what you setup in Mariadb:
+
.. code-block:: json
+
{
"restServerParameters": {
"host": "0.0.0.0",
@@ -109,14 +129,19 @@ In the policy-api repo, you should find the file "src/main/resources/etc/default
"persistenceUnit": "PolicyMariaDb"
},
}
+
Next, navigate to the "/main" directory. You can then run the following command to start the policy api:
+
.. code-block:: bash
+
mvn exec:java -Dexec.mainClass=org.onap.policy.api.main.startstop.Main -Dexec.args=" -c ../packages/policy-api-tarball/src/main/resources/etc/defaultConfig.json"
2.3.4 Policy PAP
^^^^^^^^^^^^^^^^
In the policy-pap repo, you should find the file 'main/src/test/resources/parameters/PapConfigParameters.json'. This file may need to be altered slightly as below:
+
.. code-block:: json
+
{
"name": "PapGroup",
"restServerParameters": {
@@ -181,20 +206,27 @@ In the policy-pap repo, you should find the file 'main/src/test/resources/parame
"basePath": "healthcheck"
}]
}
+
Next, navigate to the "/main" directory. You can then run the following command to start the policy pap
+
.. code-block:: bash
+
mvn -q -e clean compile exec:java -Dexec.mainClass="org.onap.policy.pap.main.startstop.Main" -Dexec.args="-c /src/test/resources/parameters/PapConfigParameters.json"
2.3.5 Controlloop Runtime
^^^^^^^^^^^^^^^^^^^^^^^^^
To start the controlloop runtime we need to go the "runtime-controlloop" directory in the clamp repo. There is a config file that is used, by default, for the controlloop runtime. That config file is here: "src/main/resources/application.yaml". For development in your local environment, it shouldn't need any adjustment and we can just run the controlloop runtime with:
+
.. code-block:: bash
+
mvn spring-boot:run
2.3.6 Controlloop Policy Participant
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
To start the policy participant we need to go to the "participant-impl/participant-impl-policy" directory in the clamp repo. There is a config file under "src/main/resources/config/application.yaml". For development in your local environment, we will need to adjust this file slightly:
+
.. code-block:: yaml
+
server:
port: 8082
@@ -240,15 +272,20 @@ To start the policy participant we need to go to the "participant-impl/participa
servers:
- ${topicServer:localhost}
topicCommInfrastructure: dmaap
+
Navigate to the participant-impl/particpant-impl-policy/main directory. We can then run the policy-participant with the following command:
+
.. code-block:: bash
+
mvn spring-boot:run -Dspring-boot.run.arguments="--server.port=8082 --topicServer=localhost"
3. Testing Procedure
====================
+
3.1 Testing Outline
^^^^^^^^^^^^^^^^^^^
To perform the Smoke testing of the policy-participant we will be verifying the behaviours of the participant when the control loop changes state. The scenarios are:
+
- UNINITIALISED to PASSIVE: participant creates policies and policyTypes specified in the ToscaServiceTemplate using policy-api
- PASSIVE to RUNNING: participant deploys created policies specified in the ToscaServiceTemplate
- RUNNING to PASSIVE: participant undeploys policies which have been deployed
@@ -261,15 +298,21 @@ Creation of Controlloop:
************************
A Control Loop is created by commissioning a Tosca template with Control loop definitions and instantiating the Control Loop with the state "UNINITIALISED".
Using postman, commision a TOSCA template and instantiate using the following template:
-:download:'Tosca Service Template <tosca/tosca_service_template_pptnt_smoke.yaml>'
-:download:'Instantiate Controlloop <tosca/instantiation_pptnt_smoke.json>'
+
+:download:`Tosca Service Template <tosca/tosca_service_template_pptnt_smoke.yaml>`
+
+:download:`Instantiate Controlloop <tosca/instantiation_pptnt_smoke.json>`
+
To verify this, we check that the Controlloop has been created and is in state UNINITIALISED.
+
.. image:: images/pol-part-controlloop-creation-ver.png
Creation of policies and policyTypes:
*************************************
The Controlloop STATE is changed from UNINITIALISED to PASSIVE using postman:
-.. code-block::json
+
+.. code-block:: json
+
{
"orderedState": "PASSIVE",
"controlLoopIdentifierList": [
@@ -279,15 +322,21 @@ The Controlloop STATE is changed from UNINITIALISED to PASSIVE using postman:
}
]
}
+
This state change will trigger the creation of policies and policyTypes using the policy-api. To verify this we will check, using policy-api endpoints, that the "Sirisha" policyType, which is specified in the service template, has been created.
+
.. image:: images/pol-part-controlloop-sirisha-ver.png
+
We can also check that the pm-control policy has been created.
+
.. image:: images/pol-part-controlloop-pmcontrol-ver.png
Deployment of policies:
***********************
The Controlloop STATE is changed from PASSIVE to RUNNING using postman:
-.. code-block::json
+
+.. code-block:: json
+
{
"orderedState": "RUNNING",
"controlLoopIdentifierList": [
@@ -297,14 +346,17 @@ The Controlloop STATE is changed from PASSIVE to RUNNING using postman:
}
]
}
+
This state change will trigger the deployment of the policies specified in the ToscaServiceTemplate. To verify this, we will check that the apex pmcontrol policy has been deployed to the defaultGroup. We check this using pap:
+
.. image:: images/pol-part-controlloop-pmcontrol-deploy-ver.png
Undeployment of policies:
*************************
-
The Controlloop STATE is changed from RUNNING to PASSIVE using postman:
-.. code-block::json
+
+.. code-block:: json
+
{
"orderedState": "PASSIVE",
"controlLoopIdentifierList": [
@@ -314,13 +366,17 @@ The Controlloop STATE is changed from RUNNING to PASSIVE using postman:
}
]
}
+
This state change will trigger the undeployment of the pmcontrol policy which was deployed previously. To verifiy this we do a PdpGroup Query as before and check that the pmcontrol policy has been undeployed and removed from the defaultGroup:
+
.. image:: images/pol-part-controlloop-pmcontrol-undep-ver.png
Deletion of policies and policyTypes:
*************************************
The Controlloop STATE is changed from PASSIVE to UNINITIALISED using postman:
-.. code-block::json
+
+.. code-block:: json
+
{
"orderedState": "UNINITIALISED",
"controlLoopIdentifierList": [
@@ -330,6 +386,10 @@ The Controlloop STATE is changed from PASSIVE to UNINITIALISED using postman:
}
]
}
+
This state change will trigger the deletion of the previously created policies and policyTypes. To verify this, as before, we can check that the Sirisha policyType is not found this time and likewise for the pmcontrol policy:
+
.. image:: images/pol-part-controlloop-sirisha-nf.png
+
.. image:: images/pol-part-controlloop-pmcontrol-nf.png
+