diff options
Diffstat (limited to 'test')
-rw-r--r-- | test/mocks/pnf-onboarding/README.md | 25 | ||||
-rw-r--r-- | test/mocks/pnf-onboarding/pom.xml | 16 | ||||
-rw-r--r-- | test/mocks/pnf-onboarding/readme.md | 40 | ||||
-rw-r--r-- | test/mocks/pnf-onboarding/src/main/scripts/generate-signature.sh | 22 |
4 files changed, 38 insertions, 65 deletions
diff --git a/test/mocks/pnf-onboarding/README.md b/test/mocks/pnf-onboarding/README.md new file mode 100644 index 000000000..8440b3483 --- /dev/null +++ b/test/mocks/pnf-onboarding/README.md @@ -0,0 +1,25 @@ + +PNF Package for Integration Test +================================ + +**NOTE: Currently this solution only works on Linux OS and requires openssl to be preinstalled.** + +This module builds 2 PNF packages based on the files in `/src/main/resources/csarContent/` + +1. unsigned package: `sample-pnf-1.0.1-SNAPSHOT.csar` +2. signed package: `sample-signed-pnf-1.0.1-SNAPSHOT.zip` + +The signed package is based on ETSI SOL004 Security Option 2. It contains the csar, cert and cms files. + +The packages are generated by running the following command in the same directory as this readme file i.e. pnf-onboarding directory: +> `$ mvn clean install` + +The packages will be stored in the maven generated `target` directory. + +To be able to use the signed package in SDC the `src/main/resources/securityContent/root.cert` file has to be loaded into SDC onboarding backend container. + +If SDC is running in containers locally then the following commands could be used to copy the root.cert to the default location in SDC Onboarding Container. It is assumed that the commands are executed from inside pnf-onboarding directory. + +> `$ docker exec -it <sdc-onboard-backend-container-id> mkdir -p /var/lib/jetty/cert` + +> `$ docker cp src/main/resources/securityContent/root.cert <sdc-onboard-backend-container-id>:/var/lib/jetty` diff --git a/test/mocks/pnf-onboarding/pom.xml b/test/mocks/pnf-onboarding/pom.xml index 569d1e2e4..7f513eb00 100644 --- a/test/mocks/pnf-onboarding/pom.xml +++ b/test/mocks/pnf-onboarding/pom.xml @@ -128,11 +128,21 @@ </execution> </executions> <configuration> - <executable>src/main/scripts/generate-signature.sh</executable> + <executable>openssl</executable> <arguments> - <argument>src/main/resources/securityContent/sample-pnf.cert</argument> - <argument>src/main/resources/securityContent/sample-pnf-private-key.pem</argument> + <argument>cms</argument> + <argument>-sign</argument> + <argument>-binary</argument> + <argument>-nocerts</argument> + <argument>-outform</argument> + <argument>pem</argument> + <argument>-signer</argument> + <argument>${project.basedir}/src/main/resources/securityContent/sample-pnf.cert</argument> + <argument>-inkey</argument> + <argument>${project.basedir}/src/main/resources/securityContent/sample-pnf-private-key.pem</argument> + <argument>-in</argument> <argument>${project.build.directory}/signed-csar/${csar.name}.csar</argument> + <argument>-out</argument> <argument>${project.build.directory}/signed-csar/${csar.name}.cms</argument> </arguments> </configuration> diff --git a/test/mocks/pnf-onboarding/readme.md b/test/mocks/pnf-onboarding/readme.md deleted file mode 100644 index 4ddf701b5..000000000 --- a/test/mocks/pnf-onboarding/readme.md +++ /dev/null @@ -1,40 +0,0 @@ -# PNF Package for Integration Test - - - -Builds 2 PNF packages based on the files in `/src/main/resources/csarContent/` - - - -1. unsigned package: - - `sample-pnf-1.0.1-SNAPSHOT.csar` - - - -2. signed package: - - `sample-signed-pnf-1.0.1-SNAPSHOT.zip` -The signed package is based on ETSI SOL004 Security Option 2. It contains csar, cert and cms files. - -The packages are generated by running the following command in the same directory as this readme file i.e. pnf-onboarding directory: -> `mvn clean install` - - - -The packages will be stored in target folder under the pnf-onboarding directory. -**NOTE: Currently this solution works for Linux OS only.** - - - -To be able to use the signed package in SDC the `src/main/resources/securityContent/root.cert` file has to be loaded into SDC onboarding backend container. - - - -If SDC is running in containers locally then the following commands could be used to copy the root.cert to the default location in SDC Onboarding Container. It is assumed that the commands are executed from inside pnf-onboarding directory. - -``` - docker exec -it <sdc-onboard-backend-container-id> mkdir -p /var/lib/jetty/cert - docker cp src/main/resources/securityContent/root.cert <sdc-onboard-backend-container-id>:/var/lib/jetty -``` - diff --git a/test/mocks/pnf-onboarding/src/main/scripts/generate-signature.sh b/test/mocks/pnf-onboarding/src/main/scripts/generate-signature.sh deleted file mode 100644 index f9950cfeb..000000000 --- a/test/mocks/pnf-onboarding/src/main/scripts/generate-signature.sh +++ /dev/null @@ -1,22 +0,0 @@ -#!/bin/bash - -signingCertificate=$1 -signingCertPrivateKey=$2 -csarFile=$3 -signatureName=$4 - -echo Creating signature file with following inputs -printf "\t%s = %s\n" "signingCertificate" $signingCertificate -printf "\t%s = %s\n" "signingCertPrivateKey" $signingCertPrivateKey -printf "\t%s = %s\n" "csarFile" $csarFile - -openssl cms -sign -signer $signingCertificate -inkey $signingCertPrivateKey -outform pem -binary -nocerts < $csarFile > $signatureName - -retVal=$? -if [ $retVal -eq 0 ]; then - echo Signature file $signatureName created successfully -else - echo Failed to create Signature file $signatureName -fi - -exit $retVal |