diff --git a/.github/workflows/push-trigger.yml b/.github/workflows/push-trigger.yml index d8504039..9adc19ad 100644 --- a/.github/workflows/push-trigger.yml +++ b/.github/workflows/push-trigger.yml @@ -17,8 +17,7 @@ on: - '!release-branch' - release-* - master - - develop - - develop-* + - develop* - 1* - MOSIP* @@ -57,7 +56,7 @@ jobs: sonar-analysis: needs: build-resident-ui if: "${{ github.event_name != 'pull_request' }}" - uses: mosip/kattu/.github/workflows/npm-sonar-analysis.yml@master + uses: mosip/kattu/.github/workflows/npm-sonar-analysis.yml@develop with: SERVICE_LOCATION: resident-ui SONAR_URL: 'https://sonarcloud.io' @@ -66,8 +65,8 @@ jobs: SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} ORG_KEY: ${{ secrets.ORG_KEY }} SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK }} - build-maven-residenttest: - uses: mosip/kattu/.github/workflows/maven-build.yml@master + build-maven-uitest-resident: + uses: mosip/kattu/.github/workflows/maven-build.yml@master-java21 with: SERVICE_LOCATION: ./residenttest BUILD_ARTIFACT: residenttest @@ -87,12 +86,12 @@ jobs: SERVICE_LOCATION: residenttest BUILD_ARTIFACT: residenttest-local steps: - - uses: actions/checkout@v2 - - name: Set up JDK 11 - uses: actions/setup-java@v1 + - uses: actions/checkout@v3 + - name: Set up JDK 21 + uses: actions/setup-java@v3 with: - ref: ${{ github.ref }} - java-version: 11 + distribution: 'temurin' + java-version: '21' server-id: ossrh # Value of the distributionManagement/repository/id field of the pom.xml settings-path: ${{ github.workspace }} # location for the settings.xml file @@ -146,7 +145,7 @@ jobs: BUILD_ARTIFACT: 'residenttest-local' fail-fast: false name: ${{ matrix.SERVICE_NAME }} - uses: mosip/kattu/.github/workflows/docker-build.yml@master + uses: mosip/kattu/.github/workflows/docker-build.yml@master-java21 with: SERVICE_LOCATION: ${{ matrix.SERVICE_LOCATION }} SERVICE_NAME: ${{ matrix.SERVICE_NAME }} @@ -172,7 +171,7 @@ jobs: sonar_analysis_residenttest: needs: build-residentuitests-local if: "${{ github.event_name != 'pull_request' }}" - uses: mosip/kattu/.github/workflows/maven-sonar-analysis.yml@master + uses: mosip/kattu/.github/workflows/maven-sonar-analysis.yml@master-java21 with: SERVICE_LOCATION: residenttest SONAR_URL: 'https://sonarcloud.io' diff --git a/deploy/copy_cm.sh b/deploy/copy_cm.sh old mode 100755 new mode 100644 diff --git a/deploy/copy_cm_func.sh b/deploy/copy_cm_func.sh new file mode 100755 index 00000000..185ae3e5 --- /dev/null +++ b/deploy/copy_cm_func.sh @@ -0,0 +1,33 @@ +#!/bin/bash +# Copy configmap and secret from one namespace to another. +# ./copy_cm_func.sh [name] +# Parameters: +# resource: configmap|secret +# name: Optional new name of the configmap or secret in destination namespace. This may be needed if there is +# clash of names + +if [ $1 = "configmap" ] +then + RESOURCE=configmap +elif [ $1 = "secret" ] +then + RESOURCE=secret +else + echo "Incorrect resource $1. Exiting.." + exit 1 +fi + + +if [ $# -ge 5 ] +then + kubectl -n $4 delete --ignore-not-found=true $RESOURCE $5 + kubectl -n $3 get $RESOURCE $2 -o yaml | sed "s/namespace: $3/namespace: $4/g" | sed "s/name: $2/name: $5/g" | kubectl -n $4 create -f - +else + kubectl -n $4 delete --ignore-not-found=true $RESOURCE $2 + kubectl -n $3 get $RESOURCE $2 -o yaml | sed "s/namespace: $3/namespace: $4/g" | kubectl -n $4 create -f - +fi + + + + + diff --git a/deploy/copy_secrets.sh b/deploy/copy_secrets.sh old mode 100755 new mode 100644 diff --git a/deploy/README.md b/deploy/resident-ui/README.md similarity index 91% rename from deploy/README.md rename to deploy/resident-ui/README.md index 2613aa7b..c47e58c4 100644 --- a/deploy/README.md +++ b/deploy/resident-ui/README.md @@ -4,6 +4,17 @@ ```sh ./install.sh ``` + +## Restart +```sh +./restart.sh +``` + +## Delete +```sh +./delete.sh +``` + * During the execution of the `install.sh` script, a prompt appears requesting information regarding the presence of a public domain and a valid SSL certificate on the server. * If the server lacks a public domain and a valid SSL certificate, it is advisable to select the `n` option. Opting it will enable the `init-container` with an `emptyDir` volume and include it in the deployment process. * The init-container will proceed to download the server's self-signed SSL certificate and mount it to the specified location within the container's Java keystore (i.e., `cacerts`) file. diff --git a/deploy/resident-ui/certs_upload/postman/README.md b/deploy/resident-ui/certs_upload/postman/README.md new file mode 100644 index 00000000..ba697ea0 --- /dev/null +++ b/deploy/resident-ui/certs_upload/postman/README.md @@ -0,0 +1,39 @@ +# Resident Cert Upload (_Work-in-progress_) + +The folder here contains Postman Collection to upload RESIDENT certs. + +## Prerequisites +Install Postman (browser or command line). The command line version is called `newman`. + +## Run +* Inspect `env.json` for any changes in default params. +* Run on command line +```sh +newman run collection.json -e env.json --env-var 'url=https://xxx.yyy.zzz' --env-var 'admin-client-secret=xxxxxxxxxxxx' +``` + +output: + +``` + +┌─────────────────────────┬─────────────────────┬─────────────────────┐ +│ │ executed │ failed │ +├─────────────────────────┼─────────────────────┼─────────────────────┤ +│ iterations │ 1 │ 0 │ +├─────────────────────────┼─────────────────────┼─────────────────────┤ +│ requests │ 8 │ 0 │ +├─────────────────────────┼─────────────────────┼─────────────────────┤ +│ test-scripts │ 8 │ 0 │ +├─────────────────────────┼─────────────────────┼─────────────────────┤ +│ prerequest-scripts │ 4 │ 0 │ +├─────────────────────────┼─────────────────────┼─────────────────────┤ +│ assertions │ 9 │ 0 │ +├─────────────────────────┴─────────────────────┴─────────────────────┤ +│ total run duration: 3.7s │ +├─────────────────────────────────────────────────────────────────────┤ +│ total data received: 7.16KB (approx) │ +├─────────────────────────────────────────────────────────────────────┤ +│ average response time: 432ms [min: 112ms, max: 1461ms, s.d.: 413ms] │ +└─────────────────────────────────────────────────────────────────────┘ + +``` diff --git a/deploy/resident-ui/certs_upload/postman/collection.json b/deploy/resident-ui/certs_upload/postman/collection.json new file mode 100644 index 00000000..e8e7946c --- /dev/null +++ b/deploy/resident-ui/certs_upload/postman/collection.json @@ -0,0 +1,436 @@ +{ + "info": { + "_postman_id": "5a43932c-5022-4731-bafc-282af54996a2", + "name": "Automated Cert Upload for Resident", + "schema": "https://schema.getpostman.com/json/collection/v2.1.0/collection.json" + }, + "item": [ + { + "name": "Authentication", + "event": [ + { + "listen": "prerequest", + "script": { + "exec": [ + "postman.setGlobalVariable('requesttime', (new Date()).toISOString());" + ], + "type": "text/javascript" + } + }, + { + "listen": "test", + "script": { + "exec": [ + "pm.test(\"Clientid and Token combination has been validated successfully\", function () {\r", + " pm.expect(pm.response.text()).to.include(\"Clientid and Token combination had been validated successfully\");\r", + "});" + ], + "type": "text/javascript" + } + } + ], + "request": { + "method": "POST", + "header": [], + "body": { + "mode": "raw", + "raw": "{\r\n \"id\": \"string\",\r\n \"metadata\": {},\r\n \"request\": {\r\n \"appId\": \"ida\",\r\n \"clientId\": \"mosip-admin-client\",\r\n \"secretKey\": \"{{admin-client-secret}}\"\r\n },\r\n \"requesttime\": \"{{requesttime}}\",\r\n \"version\": \"string\"\r\n}", + "options": { + "raw": { + "language": "json" + } + } + }, + "url": { + "raw": "{{url}}/v1/authmanager/authenticate/clientidsecretkey", + "host": [ + "{{url}}" + ], + "path": [ + "v1", + "authmanager", + "authenticate", + "clientidsecretkey" + ] + } + }, + "response": [] + }, + { + "name": "GET RESIDENT Root Certificate", + "event": [ + { + "listen": "test", + "script": { + "exec": [ + "var jsonData = JSON.parse(responseBody);\r", + "var data = JSON.stringify(jsonData.response.certificate);\r", + "console.log(data);\r", + "pm.environment.set(\"Resrootcert\",data);\r", + "\r", + "var jsonData = JSON.parse(responseBody);\r", + "pm.test(\"Got RESIDENT-ROOT-cert\", function () {\r", + " var jsonData = pm.response.json();\r", + " pm.expect(jsonData.errors).to.eql(null);\r", + "});" + ], + "type": "text/javascript" + } + } + ], + "request": { + "method": "GET", + "header": [], + "url": { + "raw": "{{url}}/v1/keymanager/getCertificate?applicationId=ROOT", + "host": [ + "{{url}}" + ], + "path": [ + "v1", + "keymanager", + "getCertificate" + ], + "query": [ + { + "key": "applicationId", + "value": "ROOT" + } + ] + } + }, + "response": [] + }, + { + "name": "POST RESIDENT_Root certificate", + "event": [ + { + "listen": "test", + "script": { + "exec": [ + "var jsonData = JSON.parse(responseBody);\r", + "var jsonData = JSON.stringify(jsonData.errors);\r", + "if (jsonData==\"[]\"){\r", + " pm.test(\"Posted RESIDENT-ROOT-Cert\", function () {\r", + " var jsonData = pm.response.json();\r", + " pm.expect(jsonData.errors).to.eql([]);\r", + " });\r", + "}\r", + "else{\r", + " pm.test(\"Certificate already exists in DB\", function () {\r", + " pm.expect(pm.response.text()).to.include(\"Certificate already exists \");\r", + " });\r", + "}" + ], + "type": "text/javascript" + } + }, + { + "listen": "prerequest", + "script": { + "exec": [ + "postman.setGlobalVariable('requesttime', (new Date()).toISOString());" + ], + "type": "text/javascript" + } + } + ], + "request": { + "method": "POST", + "header": [], + "body": { + "mode": "raw", + "raw": "{\r\n \"id\": \"string\",\r\n \"metadata\": {},\r\n \"request\": {\r\n \"certificateData\":{{Resrootcert}},\r\n \"partnerDomain\": \"AUTH\"\r\n },\r\n \"requesttime\": \"{{requesttime}}\",\r\n \"version\": \"string\"\r\n}\r\n", + "options": { + "raw": { + "language": "json" + } + } + }, + "url": { + "raw": "{{url}}/v1/partnermanager/partners/certificate/ca/upload", + "host": [ + "{{url}}" + ], + "path": [ + "v1", + "partnermanager", + "partners", + "certificate", + "ca", + "upload" + ] + } + }, + "response": [] + }, + { + "name": "GET resident certificate", + "event": [ + { + "listen": "test", + "script": { + "exec": [ + "var jsonData = JSON.parse(responseBody);\r", + "var data = JSON.stringify(jsonData.response.certificate);\r", + "console.log(data);\r", + "pm.environment.set(\"Rescert\",data);\r", + "var jsonData = JSON.parse(responseBody);\r", + "pm.test(\"Got Resident-cert\", function () {\r", + " var jsonData = pm.response.json();\r", + " pm.expect(jsonData.errors).to.eql(null);\r", + "});" + ], + "type": "text/javascript" + } + } + ], + "request": { + "method": "GET", + "header": [], + "url": { + "raw": "{{url}}/v1/keymanager/getCertificate?applicationId=RESIDENT", + "host": [ + "{{url}}" + ], + "path": [ + "v1", + "keymanager", + "getCertificate" + ], + "query": [ + { + "key": "applicationId", + "value": "RESIDENT" + } + ] + } + }, + "response": [] + }, + { + "name": "POST Resident certificate", + "event": [ + { + "listen": "test", + "script": { + "exec": [ + "var jsonData = JSON.parse(responseBody);\r", + "var jsonData = JSON.stringify(jsonData.errors);\r", + "if (jsonData==\"[]\"){\r", + " pm.test(\"Posted RESIDENT cert\", function () {\r", + " var jsonData = pm.response.json();\r", + " pm.expect(jsonData.errors).to.eql([]);;\r", + " });\r", + "}\r", + "else{\r", + " pm.test(\"Certificate already exists in DB\", function () {\r", + " pm.expect(pm.response.text()).to.include(\"Certificate already exists \");\r", + " });\r", + "}" + ], + "type": "text/javascript" + } + }, + { + "listen": "prerequest", + "script": { + "exec": [ + "postman.setGlobalVariable('requesttime', (new Date()).toISOString());" + ], + "type": "text/javascript" + } + } + ], + "request": { + "method": "POST", + "header": [], + "body": { + "mode": "raw", + "raw": "{\r\n \"id\": \"string\",\r\n \"metadata\": {},\r\n \"request\": {\r\n \"certificateData\":{{Rescert}},\r\n \"partnerDomain\": \"AUTH\"\r\n },\r\n \"requesttime\": \"{{requesttime}}\",\r\n \"version\": \"string\"\r\n}\r\n", + "options": { + "raw": { + "language": "json" + } + } + }, + "url": { + "raw": "{{url}}/v1/partnermanager/partners/certificate/ca/upload", + "host": [ + "{{url}}" + ], + "path": [ + "v1", + "partnermanager", + "partners", + "certificate", + "ca", + "upload" + ] + } + }, + "response": [] + }, + { + "name": "GET Mpartner default resident cert", + "event": [ + { + "listen": "test", + "script": { + "exec": [ + "var jsonData = JSON.parse(responseBody);\r", + "var data = JSON.stringify(jsonData.response.certificate);\r", + "console.log(data);\r", + "pm.environment.set(\"MPDRcert\",data);\r", + "var jsonData = JSON.parse(responseBody);\r", + "pm.test(\"Got mpartner-default-resident-cert\", function () {\r", + " var jsonData = pm.response.json();\r", + " pm.expect(jsonData.errors).to.eql(null);\r", + "});" + ], + "type": "text/javascript" + } + } + ], + "request": { + "method": "GET", + "header": [], + "url": { + "raw": "{{url}}/v1/keymanager/getCertificate?applicationId=RESIDENT&referenceId=mpartner-default-resident", + "host": [ + "{{url}}" + ], + "path": [ + "v1", + "keymanager", + "getCertificate" + ], + "query": [ + { + "key": "applicationId", + "value": "RESIDENT" + }, + { + "key": "referenceId", + "value": "mpartner-default-resident" + } + ] + } + }, + "response": [] + }, + { + "name": "POST mpartner default resident cert", + "event": [ + { + "listen": "prerequest", + "script": { + "exec": [ + "postman.setGlobalVariable('requesttime', (new Date()).toISOString());" + ], + "type": "text/javascript" + } + }, + { + "listen": "test", + "script": { + "exec": [ + "var jsonData = JSON.parse(responseBody);\r", + "var jsonData = JSON.stringify(jsonData.errors);\r", + "if (jsonData==\"[]\"){\r", + " pm.test(\"Posted Mpartner-default-resident cert\", function () {\r", + " var jsonData = pm.response.json();\r", + " pm.expect(jsonData.errors).to.eql([]);\r", + " });\r", + "}\r", + "else{\r", + " pm.test(\"Certificate already exists in DB\", function () {\r", + " pm.expect(pm.response.text()).to.include(\"Certificate already exists \");\r", + " });\r", + "}\r", + "var jsonData = JSON.parse(responseBody);\r", + "var data = JSON.stringify(jsonData.response.signedCertificateData);\r", + "pm.environment.set(\"signedmpartnerdefaultresidentcert\",data);\r", + "var jsonData = JSON.parse(responseBody);\r", + "pm.test(\"Got signed-certificate\", function () {\r", + " var jsonData = pm.response.json();\r", + " pm.expect(jsonData.errors).to.eql([]);\r", + "});" + ], + "type": "text/javascript" + } + } + ], + "request": { + "method": "POST", + "header": [], + "body": { + "mode": "raw", + "raw": "{\r\n \"id\": \"string\",\r\n \"metadata\": {},\r\n \"request\": {\r\n \"certificateData\":{{MPDRcert}},\r\n \"partnerDomain\": \"AUTH\",\r\n \"partnerId\": \"mpartner-default-resident\"\r\n },\r\n \"requesttime\": \"{{requesttime}}\",\r\n \"version\": \"string\"\r\n}", + "options": { + "raw": { + "language": "json" + } + } + }, + "url": { + "raw": "{{url}}/v1/partnermanager/partners/certificate/upload", + "host": [ + "{{url}}" + ], + "path": [ + "v1", + "partnermanager", + "partners", + "certificate", + "upload" + ] + } + }, + "response": [] + }, + { + "name": "Upload Signed Certificate Copy", + "event": [ + { + "listen": "test", + "script": { + "exec": [ + "\r", + "pm.test(\"Posted Signed certificate\", function () {\r", + " var jsonData = pm.response.json();\r", + " pm.expect(jsonData.errors).to.eql(null);\r", + "});" + ], + "type": "text/javascript" + } + } + ], + "request": { + "method": "POST", + "header": [], + "body": { + "mode": "raw", + "raw": "{\r\n \"id\": \"string\",\r\n \"metadata\": {},\r\n \"request\": {\r\n \"applicationId\": \"RESIDENT\",\r\n \"certificateData\":{{signedmpartnerdefaultresidentcert}},\r\n \"referenceId\": \"mpartner-default-resident\"\r\n },\r\n \"requesttime\": \"{{requesttime}}\",\r\n \"version\": \"string\"\r\n}", + "options": { + "raw": { + "language": "json" + } + } + }, + "url": { + "raw": "{{url}}/v1/keymanager/uploadCertificate", + "host": [ + "{{url}}" + ], + "path": [ + "v1", + "keymanager", + "uploadCertificate" + ] + } + }, + "response": [] + } + ] +} diff --git a/deploy/resident-ui/certs_upload/postman/env.json b/deploy/resident-ui/certs_upload/postman/env.json new file mode 100644 index 00000000..5df9b0ec --- /dev/null +++ b/deploy/resident-ui/certs_upload/postman/env.json @@ -0,0 +1,29 @@ +{ + "id": "97f5ce5c-9a16-432d-be16-dcb1feeb5669", + "name": "Automated Cert Upload for Resident", + "values": [ + { + "key": "Resrootcert", + "value": "", + "enabled": true + }, + { + "key": "Rescert", + "value": "", + "enabled": true + }, + { + "key": "MPDRcert", + "value": "", + "enabled": true + }, + { + "key": "signedmpartnerdefaultresidentcert", + "value": "", + "enabled": true + } + ], + "_postman_variable_scope": "environment", + "_postman_exported_at": "2021-11-10T10:15:11.999Z", + "_postman_exported_using": "Postman/8.12.5" +} diff --git a/deploy/delete.sh b/deploy/resident-ui/delete.sh similarity index 100% rename from deploy/delete.sh rename to deploy/resident-ui/delete.sh diff --git a/deploy/install.sh b/deploy/resident-ui/install.sh similarity index 75% rename from deploy/install.sh rename to deploy/resident-ui/install.sh index 1b489710..b550c2f5 100755 --- a/deploy/install.sh +++ b/deploy/resident-ui/install.sh @@ -7,7 +7,8 @@ if [ $# -ge 1 ] ; then fi NS=resident -RESIDENT_UI_CHART_VERSION=0.9.0-develop +RESIDENT_UI_CHART_VERSION=0.0.1-develop +COPY_UTIL=../copy_cm_func.sh echo Create $NS namespace kubectl create ns $NS @@ -18,12 +19,16 @@ function installing_resident() { helm repo update echo Copy configmaps - sed -i 's/\r$//' copy_cm.sh - ./copy_cm.sh + $COPY_UTIL configmap global default $NS + $COPY_UTIL configmap artifactory-share artifactory $NS + $COPY_UTIL configmap config-server-share config-server $NS echo Copy secrets - sed -i 's/\r$//' copy_secrets.sh - ./copy_secrets.sh + $COPY_UTIL secret keycloak-client-secrets keycloak $NS + + echo Setting up dummy values for Resident OIDC Client ID + kubectl create secret generic resident-oidc-onboarder-key -n $NS --from-literal=resident-oidc-clientid='' --dry-run=client -o yaml | kubectl apply -f - + ./copy_cm_func.sh secret resident-oidc-onboarder-key resident config-server echo "Do you have public domain & valid SSL? (Y/n) " echo "Y: if you have public domain & valid ssl certificate" diff --git a/deploy/restart.sh b/deploy/resident-ui/restart.sh similarity index 100% rename from deploy/restart.sh rename to deploy/resident-ui/restart.sh diff --git a/deploy/resident-uitestrig/README.md b/deploy/resident-uitestrig/README.md new file mode 100644 index 00000000..00b2177f --- /dev/null +++ b/deploy/resident-uitestrig/README.md @@ -0,0 +1,32 @@ +# UITESTRIG + +## Introduction +UITESTRIG will test end-to-end functional flows involving multiple UI modules. + +## Install +* Install +```sh +./install.sh +``` + +## Uninstall +* To uninstall UITESTRIG, run `delete.sh` script. +```sh +./delete.sh +``` + +## Run UITESTRIG manually + +#### CLI +* Download Kubernetes cluster `kubeconfig` file from `rancher dashboard` to your local. +* Install `kubectl` package to your local machine. +* Run UITESTRIG manually via CLI by creating a new job from an existing k8s cronjob. + ``` + kubectl --kubeconfig= -n UITESTRIG create job --from=cronjob/ + ``` + example: + ``` + kubectl --kubeconfig=/home/xxx/Downloads/qa4.config -n UITESTRIG create job --from=cronjob/cronjob-uitestrig cronjob-uitestrig + ``` + + diff --git a/deploy/resident-uitestrig/delete.sh b/deploy/resident-uitestrig/delete.sh new file mode 100755 index 00000000..850ba22b --- /dev/null +++ b/deploy/resident-uitestrig/delete.sh @@ -0,0 +1,30 @@ +#!/bin/bash +# Uninstalls uitestrig +## Usage: ./delete.sh [kubeconfig] + +if [ $# -ge 1 ] ; then + export KUBECONFIG=$1 +fi + +function deleting_uitestrig() { + NS=resident + while true; do + read -p "Are you sure you want to delete uitestrig helm charts?(Y/n) " yn + if [ $yn = "Y" ] + then + helm -n $NS delete resident-uitestrig + break + else + break + fi + done + return 0 +} + +# set commands for error handling. +set -e +set -o errexit ## set -e : exit the script if any statement returns a non-true return value +set -o nounset ## set -u : exit the script if you try to use an uninitialised variable +set -o errtrace # trace ERR through 'time command' and other functions +set -o pipefail # trace ERR through pipes +deleting_uitestrig # calling function \ No newline at end of file diff --git a/deploy/resident-uitestrig/install.sh b/deploy/resident-uitestrig/install.sh new file mode 100755 index 00000000..de469b06 --- /dev/null +++ b/deploy/resident-uitestrig/install.sh @@ -0,0 +1,97 @@ +#!/bin/bash +# Installs uitestrig automation +## Usage: ./install.sh [kubeconfig] + +if [ $# -ge 1 ] ; then + export KUBECONFIG=$1 +fi + +NS=resident +CHART_VERSION=0.0.1-develop +COPY_UTIL=../copy_cm_func.sh + +echo Create $NS namespace +kubectl create ns $NS + +function installing_uitestrig() { + ENV_NAME=$( kubectl -n default get cm global -o json |jq -r '.data."installation-domain"') + + read -p "Please enter the time(hr) to run the cronjob every day (time: 0-23) : " time + if [ -z "$time" ]; then + echo "ERROR: Time cannot be empty; EXITING;"; + exit 1; + fi + if ! [ $time -eq $time ] 2>/dev/null; then + echo "ERROR: Time $time is not a number; EXITING;"; + exit 1; + fi + if [ $time -gt 23 ] || [ $time -lt 0 ] ; then + echo "ERROR: Time should be in range ( 0-23 ); EXITING;"; + exit 1; + fi + + echo "Do you have public domain & valid SSL? (Y/n) " + echo "Y: if you have public domain & valid ssl certificate" + echo "n: if you don't have public domain & valid ssl certificate" + read -p "" flag + + if [ -z "$flag" ]; then + echo "'flag' was provided; EXITING;" + exit 1; + fi + ENABLE_INSECURE='' + if [ "$flag" = "n" ]; then + ENABLE_INSECURE='--set uitestrig.configmaps.uitestrig.ENABLE_INSECURE=true'; + fi + + echo Istio label + kubectl label ns $NS istio-injection=disabled --overwrite + helm repo update + + echo Copy configmaps + $COPY_UTIL configmap global default $NS + $COPY_UTIL configmap keycloak-host keycloak $NS + $COPY_UTIL configmap artifactory-share artifactory $NS + $COPY_UTIL configmap config-server-share config-server $NS + + echo Copy secrets + $COPY_UTIL secret keycloak-client-secrets keycloak $NS + $COPY_UTIL secret s3 s3 $NS + $COPY_UTIL secret postgres-postgresql postgres $NS + + DB_HOST=$( kubectl -n default get cm global -o json |jq -r '.data."mosip-api-internal-host"' ) + PMP_HOST=$(kubectl -n default get cm global -o json |jq -r '.data."mosip-pmp-host"') + ADMIN_HOST=$(kubectl -n default get cm global -o json |jq -r '.data."mosip-admin-host"') + RESIDENT_HOST=$(kubectl -n default get cm global -o json |jq -r '.data."mosip-resident-host"') + API_INTERNAL_HOST=$( kubectl -n default get cm global -o json |jq -r '.data."mosip-api-internal-host"' ) + + echo Installing resident uitestrig + helm -n $NS install resident-uitestrig mosip/uitestrig \ + --set crontime="0 $time * * *" \ + -f values.yaml \ + --version $CHART_VERSION \ + --set uitestrig.configmaps.s3.s3-host='http://minio.minio:9000' \ + --set uitestrig.configmaps.s3.s3-user-key='admin' \ + --set uitestrig.configmaps.s3.s3-region='' \ + --set uitestrig.configmaps.db.db-server="$DB_HOST" \ + --set uitestrig.configmaps.db.db-su-user="postgres" \ + --set uitestrig.configmaps.db.db-port="5432" \ + --set uitestrig.configmaps.uitestrig.apiInternalEndPoint="https://$API_INTERNAL_HOST" \ + --set uitestrig.configmaps.uitestrig.apiEnvUser="$API_INTERNAL_HOST" \ + --set uitestrig.configmaps.uitestrig.PmpPortalPath="https://$PMP_HOST" \ + --set uitestrig.configmaps.uitestrig.adminPortalPath="https://$ADMIN_HOST" \ + --set uitestrig.configmaps.uitestrig.residentPortalPath="https://$RESIDENT_HOST" \ + --set uitestrig.configmaps.uitestrig.NS="$NS" \ + $ENABLE_INSECURE + + echo Installed resident uitestrig + return 0 +} + +# set commands for error handling. +set -e +set -o errexit ## set -e : exit the script if any statement returns a non-true return value +set -o nounset ## set -u : exit the script if you try to use an uninitialised variable +set -o errtrace # trace ERR through 'time command' and other functions +set -o pipefail # trace ERR through pipes +installing_uitestrig # calling function \ No newline at end of file diff --git a/deploy/resident-uitestrig/values.yaml b/deploy/resident-uitestrig/values.yaml new file mode 100644 index 00000000..9e02676b --- /dev/null +++ b/deploy/resident-uitestrig/values.yaml @@ -0,0 +1,7 @@ +modules: + - name: residentui + enabled: true + image: + registry: docker.io + repository: mosipqa/residenttest + tag: develop diff --git a/helm/resident-ui/templates/deployment.yaml b/helm/resident-ui/templates/deployment.yaml index 9855b858..54f0d0d2 100644 --- a/helm/resident-ui/templates/deployment.yaml +++ b/helm/resident-ui/templates/deployment.yaml @@ -105,8 +105,10 @@ spec: {{- end }} {{- end }} {{- if .Values.extraEnvVarsSecret }} + {{- range .Values.extraEnvVarsSecret }} - secretRef: - name: {{ include "common.tplvalues.render" (dict "value" .Values.extraEnvVarsSecret "context" $) }} + name: {{ . }} + {{- end }} {{- end }} volumeMounts: - name: ui-config diff --git a/helm/resident-ui/values.yaml b/helm/resident-ui/values.yaml index ca50afb3..c2aa4450 100644 --- a/helm/resident-ui/values.yaml +++ b/helm/resident-ui/values.yaml @@ -248,7 +248,7 @@ extraEnvVarsCM: ## Secret with extra environment variables ## -extraEnvVarsSecret: +extraEnvVarsSecret: [] ## Extra volumes to add to the deployment ## diff --git a/resident-ui/src/app/app-config.service.ts b/resident-ui/src/app/app-config.service.ts index f99b008f..3bad2215 100644 --- a/resident-ui/src/app/app-config.service.ts +++ b/resident-ui/src/app/app-config.service.ts @@ -8,76 +8,76 @@ export class AppConfigService { appConfig: any; constructor(public http: HttpClient) { } - async loadAppConfig() { - localStorage.setItem("isDataLoaded", 'false') - this.appConfig = await this.http.get('./assets/config.json').toPromise(); - this.http.get(this.appConfig.baseUrl + '/proxy/config/ui-properties').subscribe( - (response) => { - let responseData = response["response"]; - this.appConfig["supportedLanguages"] = responseData["mosip.mandatory-languages"]+","+responseData["mosip.optional-languages"]; - this.appConfig["mosip.iam.adapter.clientid"] = responseData["mosip.iam.adapter.clientid"]; - this.appConfig["mosip.resident.api.id.otp.request"] = responseData["mosip.resident.api.id.otp.request"]; - this.appConfig["mosip.resident.api.version.otp.request"] = responseData["mosip.resident.api.version.otp.request"]; - this.appConfig["resident.vid.id"] = responseData["resident.vid.id"]; - this.appConfig["resident.vid.version"] = responseData["resident.vid.version"]; - this.appConfig["mosip.resident.request.response.version"] = responseData["mosip.resident.request.response.version"]; - this.appConfig["resident.revokevid.id"] = responseData["resident.revokevid.id"]; - this.appConfig["mosip-prereg-host"] = responseData["mosip-prereg-host"]; - this.appConfig["mosip-prereg-ui-url"] = responseData["mosip-prereg-ui-url"]; - this.appConfig["auth.types.allowed"] = responseData["auth.types.allowed"]; - this.appConfig["resident.view.history.serviceType.filters"] = responseData["resident.view.history.serviceType.filters"]; - this.appConfig["resident.view.history.status.filters"] = responseData["resident.view.history.status.filters"]; - this.appConfig["mosip.resident.grievance.url"] = responseData["mosip.resident.grievance.url"]; - this.appConfig["resident.vid.id.generate"] = responseData["resident.vid.id.generate"]; - this.appConfig["resident.vid.version.new"] = responseData["resident.vid.version.new"]; - this.appConfig["mosip.resident.revokevid.id"] = responseData["mosip.resident.revokevid.id"]; - this.appConfig["resident.revokevid.version.new"] = responseData["resident.revokevid.version.new"]; - this.appConfig["mosip.resident.download.personalized.card.id"] = responseData["mosip.resident.download.personalized.card.id"] - this.appConfig["mosip.resident.download.registration.centre.file.name.convention"] = responseData["mosip.resident.download.registration.centre.file.name.convention"]; - this.appConfig["mosip.resident.download.supporting.document.file.name.convention"] = responseData["mosip.resident.download.supporting.document.file.name.convention"]; - this.appConfig["mosip.resident.download.personalized.card.naming.convention"] = responseData["mosip.resident.download.personalized.card.naming.convention"]; - this.appConfig["mosip.resident.ack.manage_my_vid.name.convention"] = responseData["mosip.resident.ack.manage_my_vid.name.convention"]; - this.appConfig["mosip.resident.ack.secure_my_id.name.convention"] = responseData["mosip.resident.ack.secure_my_id.name.convention"]; - this.appConfig["mosip.resident.ack.personalised_card.name.convention"] = responseData["mosip.resident.ack.personalised_card.name.convention"]; - this.appConfig["mosip.resident.ack.update_my_data.name.convention"] = responseData["mosip.resident.ack.update_my_data.name.convention"]; - this.appConfig["mosip.resident.ack.share_credential.name.convention"] = responseData["mosip.resident.ack.share_credential.name.convention"]; - this.appConfig["mosip.resident.ack.order_physical_card.name.convention"] = responseData["mosip.resident.ack.order_physical_card.name.convention"]; - this.appConfig["mosip.resident.ack.name.convention"] = responseData["mosip.resident.ack.name.convention"]; - this.appConfig["mosip.resident.uin.card.name.convention"] = responseData["mosip.resident.uin.card.name.convention"]; - this.appConfig["mosip.resident.vid.card.name.convention"] = responseData["mosip.resident.vid.card.name.convention"]; - this.appConfig["mosip.resident.download.service.history.file.name.convention"] = responseData["mosip.resident.download.service.history.file.name.convention"]; - this.appConfig["mosip.resident.download.nearest.registration.centre.file.name.convention"] = responseData["mosip.resident.download.nearest.registration.centre.file.name.convention"]; - this.appConfig["resident.nearby.centers.distance.meters"] = responseData["resident.nearby.centers.distance.meters"]; - this.appConfig["mosip.resident.captcha.sitekey"] = responseData["mosip.resident.captcha.sitekey"]; - this.appConfig["mosip.resident.captcha.secretkey"] = responseData["mosip.resident.captcha.secretkey"]; - this.appConfig["mosip.webui.auto.logout.idle"] = responseData["mosip.webui.auto.logout.idle"]; - this.appConfig["mosip.webui.auto.logout.ping"] = responseData["mosip.webui.auto.logout.ping"]; - this.appConfig["mosip.webui.auto.logout.timeout"] = responseData["mosip.webui.auto.logout.timeout"]; - this.appConfig["resident.updateuin.id"] = responseData["resident.updateuin.id"]; - this.appConfig["resident.ui.notification.update.interval.seconds"] = responseData["resident.ui.notification.update.interval.seconds"]; - this.appConfig["mosip.kernel.otp.expiry-time"] = responseData["mosip.kernel.otp.expiry-time"]; - this.appConfig["resident.grievance-redressal.comments.chars.limit"] = responseData["resident.grievance-redressal.comments.chars.limit"]; - this.appConfig["resident.grievance-redressal.alt-email.chars.limit"] = responseData["resident.grievance-redressal.alt-email.chars.limit"]; - this.appConfig["resident.grievance-redressal.alt-phone.chars.limit"] = responseData["resident.grievance-redressal.alt-phone.chars.limit"]; - this.appConfig["resident.validation.event-id.regex"] = responseData["resident.validation.event-id.regex"]; - this.appConfig["resident.purpose.allowed.special.char.regex"] = responseData["resident.purpose.allowed.special.char.regex"]; - this.appConfig["mosip.resident.captcha.enable"] = responseData["mosip.resident.captcha.enable"]; - this.appConfig["mosip.kernel.vid.length"] = responseData["mosip.kernel.vid.length"]; - this.appConfig["mosip.kernel.uin.length"] = responseData["mosip.kernel.uin.length"]; - this.appConfig["mosip.kernel.rid.length"] = responseData["mosip.kernel.rid.length"]; - this.appConfig["mosip.resident.transliteration.transliterate.id"] = responseData["mosip.resident.transliteration.transliterate.id"]; - this.appConfig["resident.contact.details.update.id"] = responseData["resident.contact.details.update.id"]; - this.appConfig["mosip.resident.zoom"] = responseData["mosip.resident.zoom"]; - this.appConfig["mosip.resident.maxZoom"] = responseData["mosip.resident.maxZoom"]; - this.appConfig["mosip.resident.minZoom"] = responseData["mosip.resident.minZoom"]; - this.appConfig["resident.update-uin.machine-zone-code"] = responseData["resident.update-uin.machine-zone-code"]; - this.appConfig["resident-multi-language-enable"] = responseData["resident-multi-language-enable"]; - localStorage.setItem("isDataLoaded", 'true') - }, - (error) => { - console.log(error); - } - ); + async loadAppConfig(): Promise { + try { + // Load local config.json + this.appConfig = await this.http.get('./assets/config.json').toPromise(); + // Load additional config from remote endpoint + const response = await this.http.get(this.appConfig.baseUrl + '/proxy/config/ui-properties').toPromise(); + const responseData = response["response"]; + localStorage.setItem("langCode", responseData["mosip.mandatory-languages"]); + this.appConfig["supportedLanguages"] = responseData["mosip.mandatory-languages"] + ","+ responseData["mosip.optional-languages"]; + this.appConfig["mosip.iam.adapter.clientid"] = responseData["mosip.iam.adapter.clientid"]; + this.appConfig["mosip.resident.api.id.otp.request"] = responseData["mosip.resident.api.id.otp.request"]; + this.appConfig["mosip.resident.api.version.otp.request"] = responseData["mosip.resident.api.version.otp.request"]; + this.appConfig["resident.vid.id"] = responseData["resident.vid.id"]; + this.appConfig["resident.vid.version"] = responseData["resident.vid.version"]; + this.appConfig["mosip.resident.request.response.version"] = responseData["mosip.resident.request.response.version"]; + this.appConfig["resident.revokevid.id"] = responseData["resident.revokevid.id"]; + this.appConfig["mosip-prereg-host"] = responseData["mosip-prereg-host"]; + this.appConfig["mosip-prereg-ui-url"] = responseData["mosip-prereg-ui-url"]; + this.appConfig["auth.types.allowed"] = responseData["auth.types.allowed"]; + this.appConfig["resident.view.history.serviceType.filters"] = responseData["resident.view.history.serviceType.filters"]; + this.appConfig["resident.view.history.status.filters"] = responseData["resident.view.history.status.filters"]; + this.appConfig["mosip.resident.grievance.url"] = responseData["mosip.resident.grievance.url"]; + this.appConfig["resident.vid.id.generate"] = responseData["resident.vid.id.generate"]; + this.appConfig["resident.vid.version.new"] = responseData["resident.vid.version.new"]; + this.appConfig["mosip.resident.revokevid.id"] = responseData["mosip.resident.revokevid.id"]; + this.appConfig["resident.revokevid.version.new"] = responseData["resident.revokevid.version.new"]; + this.appConfig["mosip.resident.download.personalized.card.id"] = responseData["mosip.resident.download.personalized.card.id"] + this.appConfig["mosip.resident.download.registration.centre.file.name.convention"] = responseData["mosip.resident.download.registration.centre.file.name.convention"]; + this.appConfig["mosip.resident.download.supporting.document.file.name.convention"] = responseData["mosip.resident.download.supporting.document.file.name.convention"]; + this.appConfig["mosip.resident.download.personalized.card.naming.convention"] = responseData["mosip.resident.download.personalized.card.naming.convention"]; + this.appConfig["mosip.resident.ack.manage_my_vid.name.convention"] = responseData["mosip.resident.ack.manage_my_vid.name.convention"]; + this.appConfig["mosip.resident.ack.secure_my_id.name.convention"] = responseData["mosip.resident.ack.secure_my_id.name.convention"]; + this.appConfig["mosip.resident.ack.personalised_card.name.convention"] = responseData["mosip.resident.ack.personalised_card.name.convention"]; + this.appConfig["mosip.resident.ack.update_my_data.name.convention"] = responseData["mosip.resident.ack.update_my_data.name.convention"]; + this.appConfig["mosip.resident.ack.share_credential.name.convention"] = responseData["mosip.resident.ack.share_credential.name.convention"]; + this.appConfig["mosip.resident.ack.order_physical_card.name.convention"] = responseData["mosip.resident.ack.order_physical_card.name.convention"]; + this.appConfig["mosip.resident.ack.name.convention"] = responseData["mosip.resident.ack.name.convention"]; + this.appConfig["mosip.resident.uin.card.name.convention"] = responseData["mosip.resident.uin.card.name.convention"]; + this.appConfig["mosip.resident.vid.card.name.convention"] = responseData["mosip.resident.vid.card.name.convention"]; + this.appConfig["mosip.resident.download.service.history.file.name.convention"] = responseData["mosip.resident.download.service.history.file.name.convention"]; + this.appConfig["mosip.resident.download.nearest.registration.centre.file.name.convention"] = responseData["mosip.resident.download.nearest.registration.centre.file.name.convention"]; + this.appConfig["resident.nearby.centers.distance.meters"] = responseData["resident.nearby.centers.distance.meters"]; + this.appConfig["mosip.resident.captcha.sitekey"] = responseData["mosip.resident.captcha.sitekey"]; + this.appConfig["mosip.resident.captcha.secretkey"] = responseData["mosip.resident.captcha.secretkey"]; + this.appConfig["mosip.webui.auto.logout.idle"] = responseData["mosip.webui.auto.logout.idle"]; + this.appConfig["mosip.webui.auto.logout.ping"] = responseData["mosip.webui.auto.logout.ping"]; + this.appConfig["mosip.webui.auto.logout.timeout"] = responseData["mosip.webui.auto.logout.timeout"]; + this.appConfig["resident.updateuin.id"] = responseData["resident.updateuin.id"]; + this.appConfig["resident.ui.notification.update.interval.seconds"] = responseData["resident.ui.notification.update.interval.seconds"]; + this.appConfig["mosip.kernel.otp.expiry-time"] = responseData["mosip.kernel.otp.expiry-time"]; + this.appConfig["resident.grievance-redressal.comments.chars.limit"] = responseData["resident.grievance-redressal.comments.chars.limit"]; + this.appConfig["resident.grievance-redressal.alt-email.chars.limit"] = responseData["resident.grievance-redressal.alt-email.chars.limit"]; + this.appConfig["resident.grievance-redressal.alt-phone.chars.limit"] = responseData["resident.grievance-redressal.alt-phone.chars.limit"]; + this.appConfig["resident.validation.event-id.regex"] = responseData["resident.validation.event-id.regex"]; + this.appConfig["resident.purpose.allowed.special.char.regex"] = responseData["resident.purpose.allowed.special.char.regex"]; + this.appConfig["mosip.resident.captcha.enable"] = responseData["mosip.resident.captcha.enable"]; + this.appConfig["mosip.kernel.vid.length"] = responseData["mosip.kernel.vid.length"]; + this.appConfig["mosip.kernel.uin.length"] = responseData["mosip.kernel.uin.length"]; + this.appConfig["mosip.kernel.rid.length"] = responseData["mosip.kernel.rid.length"]; + this.appConfig["mosip.resident.transliteration.transliterate.id"] = responseData["mosip.resident.transliteration.transliterate.id"]; + this.appConfig["resident.contact.details.update.id"] = responseData["resident.contact.details.update.id"]; + this.appConfig["mosip.resident.zoom"] = responseData["mosip.resident.zoom"]; + this.appConfig["mosip.resident.maxZoom"] = responseData["mosip.resident.maxZoom"]; + this.appConfig["mosip.resident.minZoom"] = responseData["mosip.resident.minZoom"]; + this.appConfig["resident.update-uin.machine-zone-code"] = responseData["resident.update-uin.machine-zone-code"]; + this.appConfig["mosip.mandatory-languages"] = responseData["mosip.mandatory-languages"]; + } catch (error) { + console.error("Error loading configuration", error); + throw error; + } } getConfig() { diff --git a/resident-ui/src/app/app.component.ts b/resident-ui/src/app/app.component.ts index 40513493..a7b07fab 100644 --- a/resident-ui/src/app/app.component.ts +++ b/resident-ui/src/app/app.component.ts @@ -168,10 +168,7 @@ export class AppComponent { if(window.location.href.includes('error=invalid_transaction')){ this.router.navigate(['error']); } - - if(!localStorage.getItem("langCode")){ - localStorage.setItem("langCode", "eng"); - } + this.subscriptions.push(this.autoLogout.currentMessageAutoLogout.subscribe(() => {})); this.autoLogout.changeMessage({ timerFired: false }); this.routerType(); diff --git a/resident-ui/src/app/core/services/data-storage.service.ts b/resident-ui/src/app/core/services/data-storage.service.ts index c3afd58c..45f91016 100644 --- a/resident-ui/src/app/core/services/data-storage.service.ts +++ b/resident-ui/src/app/core/services/data-storage.service.ts @@ -171,7 +171,7 @@ export class DataStorageService { return this.httpClient.post(this.BASE_URL + '/auth-lock-unlock', request, { observe: 'response'}); } - getProfileInfo(langCode: any) { + getProfileInfo(langCode:any) { return this.httpClient.get(this.BASE_URL + '/profile' + '?languageCode=' + langCode); } diff --git a/resident-ui/src/app/feature/getuin/getuin/getuin.component.ts b/resident-ui/src/app/feature/getuin/getuin/getuin.component.ts index 4d29b46a..b4ec8cc1 100644 --- a/resident-ui/src/app/feature/getuin/getuin/getuin.component.ts +++ b/resident-ui/src/app/feature/getuin/getuin/getuin.component.ts @@ -84,20 +84,13 @@ export class GetuinComponent implements OnInit { } getConfigData(){ - if(localStorage.getItem('isDataLoaded') === 'true'){ - this.siteKey = this.appConfigService.getConfig()["mosip.resident.captcha.sitekey"]; - this.captchaEnable = JSON.parse(this.appConfigService.getConfig()["mosip.resident.captcha.enable"]); - this.vidLength = this.appConfigService.getConfig()["mosip.kernel.vid.length"]; - this.uinLength = this.appConfigService.getConfig()["mosip.kernel.uin.length"]; - this.aidLength = this.appConfigService.getConfig()["mosip.kernel.rid.length"]; - this.getLangData() - this.isLoading = false; - return - }else{ - setTimeout(()=>{ - this.getConfigData() - },500) - } + this.siteKey = this.appConfigService.getConfig()["mosip.resident.captcha.sitekey"]; + this.captchaEnable = JSON.parse(this.appConfigService.getConfig()["mosip.resident.captcha.enable"]); + this.vidLength = this.appConfigService.getConfig()["mosip.kernel.vid.length"]; + this.uinLength = this.appConfigService.getConfig()["mosip.kernel.uin.length"]; + this.aidLength = this.appConfigService.getConfig()["mosip.kernel.rid.length"]; + this.getLangData() + this.isLoading = false; } getLangData(){ diff --git a/resident-ui/src/app/feature/uinservices/personalisedcard/personalisedcard.component.ts b/resident-ui/src/app/feature/uinservices/personalisedcard/personalisedcard.component.ts index 77618b88..e95b2ad4 100644 --- a/resident-ui/src/app/feature/uinservices/personalisedcard/personalisedcard.component.ts +++ b/resident-ui/src/app/feature/uinservices/personalisedcard/personalisedcard.component.ts @@ -298,10 +298,10 @@ export class PersonalisedcardComponent implements OnInit, OnDestroy { }) if (type.value === data.attributeName) { - value = this.createDefaultValue(data) data.formatOption[this.langCode].forEach(item => { item.checked = true }) + value = this.createDefaultValue(data); } else { value = this.createCheckedVal(data); this.checkDefaultVal(data, $event); diff --git a/resident-ui/src/app/feature/uinservices/updatedemographic/updatedemographic.component.html b/resident-ui/src/app/feature/uinservices/updatedemographic/updatedemographic.component.html index 644a9ae0..7193c439 100644 --- a/resident-ui/src/app/feature/uinservices/updatedemographic/updatedemographic.component.html +++ b/resident-ui/src/app/feature/uinservices/updatedemographic/updatedemographic.component.html @@ -990,9 +990,9 @@

{{'updatedem {{field.labelName[langCode][1]}}
@@ -1001,9 +1001,9 @@

{{'updatedem

diff --git a/resident-ui/src/app/feature/uinservices/updatedemographic/updatedemographic.component.ts b/resident-ui/src/app/feature/uinservices/updatedemographic/updatedemographic.component.ts index 4223f97d..b34ea64f 100644 --- a/resident-ui/src/app/feature/uinservices/updatedemographic/updatedemographic.component.ts +++ b/resident-ui/src/app/feature/uinservices/updatedemographic/updatedemographic.component.ts @@ -790,14 +790,16 @@ export class UpdatedemographicComponent implements OnInit, OnDestroy { } captureContactValue(event: any, formControlName: any) { - if(event.target.value.length){ + this.userId = event.target.value.trim(); + this.contactTye = formControlName.attributeName; + + if(new RegExp(formControlName.validators[0].validator).test(this.userId)){ this.sendOtpDisable = false; }else{ this.sendOtpDisable = true; } - this.userId = event.target.value.trim(); - this.contactTye = formControlName; - if(formControlName === "email"){ + + if(formControlName.attributeName === "email"){ this.userIdEmail = this.userId }else{ this.userIdPhone = this.userId diff --git a/resident-ui/src/app/feature/verify/verify/verify.component.ts b/resident-ui/src/app/feature/verify/verify/verify.component.ts index 0f7909ee..d1ee53d3 100644 --- a/resident-ui/src/app/feature/verify/verify/verify.component.ts +++ b/resident-ui/src/app/feature/verify/verify/verify.component.ts @@ -428,7 +428,7 @@ export class VerifyComponent implements OnInit, OnDestroy { onItemSelected(item: any) { if (item === "home") { this.router.navigate(["dashboard"]); - } else if ("back") { + } else if (item === "back") { this.showOtpPanel = false; this.resetBtnDisable = true; this.submitBtnDisable = true; diff --git a/resident-ui/src/app/shared/header/header.component.html b/resident-ui/src/app/shared/header/header.component.html index 2875c4db..caf038ae 100644 --- a/resident-ui/src/app/shared/header/header.component.html +++ b/resident-ui/src/app/shared/header/header.component.html @@ -21,13 +21,13 @@ {{item.label}} - + - diff --git a/resident-ui/src/app/shared/header/header.component.ts b/resident-ui/src/app/shared/header/header.component.ts index cc9bb13a..19282d32 100644 --- a/resident-ui/src/app/shared/header/header.component.ts +++ b/resident-ui/src/app/shared/header/header.component.ts @@ -78,42 +78,30 @@ export class HeaderComponent implements OnInit, OnDestroy { } getConfigData(){ - if(localStorage.getItem('isDataLoaded') === 'true'){ - let supportedLanguages = this.appConfigService.getConfig()['supportedLanguages'].split(','); - this.showLangDropDown = this.appConfigService.getConfig()['resident-multi-language-enable']; + let allSupportedLanguages = this.appConfigService.getConfig()['supportedLanguages'].split(','); + let uniqueSupportedLanguages = allSupportedLanguages.filter((item, index) => allSupportedLanguages.indexOf(item) === index); + this.showLangDropDown = uniqueSupportedLanguages.length > 1 ? true : false; - if(supportedLanguages.length > 1){ - supportedLanguages.forEach((language) => { + if(uniqueSupportedLanguages.length > 1){ + uniqueSupportedLanguages.forEach((language) => { this.selectLanguagesArr.push({ code: language.trim(), value: defaultJson.languages[language.trim()].nativeName, }); }); } - + this.translateService.use(localStorage.getItem("langCode")); this.textDir = localStorage.getItem("dir"); return - }else{ - setTimeout(()=>{ - this.getConfigData() - },400) - } } - - async ngOnInit() { + async ngOnInit() { this.defaultJsonValue = defaultJson; let self = this; this.getConfigData(); - if(!localStorage.getItem("langCode")){ - localStorage.setItem("langCode", "eng"); - this.selectedLanguage = defaultJson["languages"]['eng'].nativeName; - }else{ - let key = localStorage.getItem("langCode") - this.selectedLanguage = defaultJson["languages"][key].nativeName; - } + this.selectedLanguage = defaultJson["languages"][this.langCode].nativeName; self.getProfileInfo(); await this.translateService diff --git a/resident-ui/src/assets/config.json b/resident-ui/src/assets/config.json index 2aadc93b..fa1f4bc2 100644 --- a/resident-ui/src/assets/config.json +++ b/resident-ui/src/assets/config.json @@ -1,5 +1,5 @@ { - "baseUrl": "https://api-internal.dev1.mosip.net/resident/v1", + "baseUrl": "https://api-internal.qa-plan.mosip.net/resident/v1", "version": "v1", "validateToken": "admin/authorize/admin/validateToken", "login": "/login/", diff --git a/residenttest/Dockerfile b/residenttest/Dockerfile index 458f9801..5475b9d4 100644 --- a/residenttest/Dockerfile +++ b/residenttest/Dockerfile @@ -1,8 +1,18 @@ -FROM selenium/standalone-chrome:latest +# Start with a base image that includes Java 21 +FROM openjdk:21-slim +# Install additional dependencies, such as Selenium, Chrome, and kubectl USER root -# Define build-time arguments +RUN apt-get update && \ + apt-get install -y wget curl unzip xvfb libxi6 libgconf-2-4 chromium chromium-driver + +# Install kubectl +RUN curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl" && \ + chmod +x kubectl && \ + mv kubectl /usr/local/bin/kubectl + +# Define build-time arguments and labels ARG SOURCE ARG COMMIT_HASH ARG COMMIT_ID @@ -23,28 +33,21 @@ ARG container_user_gid=1001 # Set working directory for the user ENV work_dir=/home/${container_user}/ -ARG KUBECTL_VERSION=1.22.9 - -# install packages and create user +# Create a new user with specified permissions RUN groupadd -g ${container_user_gid} ${container_user_group} \ && useradd -u ${container_user_uid} -g ${container_user_group} -s /bin/bash -m ${container_user} -d ${work_dir} \ - && chown -R ${container_user}:${container_user} /home/${container_user}/ \ - && curl -LO "https://storage.googleapis.com/kubernetes-release/release/v${KUBECTL_VERSION}/bin/linux/amd64/kubectl" \ - && chmod +x kubectl \ - && mv kubectl /usr/local/bin/ + && chown -R ${container_user}:${container_user} /home/${container_user}/ # Switch to the specified user for the subsequent commands USER ${container_user_uid}:${container_user_gid} -# Copy files +# Copy your application files into the container COPY --chown=${container_user_uid}:${container_user} --chmod=771 ./entrypoint.sh ${work_dir}/entrypoint.sh COPY --chown=${container_user}:${container_user} ./src/main/resources/ ${work_dir}/resources/ COPY --chown=${container_user_uid}:${container_user} ./target/*.jar ${work_dir} -# Set working directory +# Set the working directory WORKDIR /home/${container_user}/ - - # Entrypoint for the container ENTRYPOINT ["/bin/bash", "-c", "./entrypoint.sh"] diff --git a/residenttest/entrypoint.sh b/residenttest/entrypoint.sh index 4c67b85d..839850b5 100644 --- a/residenttest/entrypoint.sh +++ b/residenttest/entrypoint.sh @@ -1,4 +1,4 @@ #!/bin/bash java --version -java -jar residentui-*-jar-with-dependencies.jar +java -jar uitest-resident-*-jar-with-dependencies.jar diff --git a/residenttest/pom.xml b/residenttest/pom.xml index b5709ae7..952d6788 100644 --- a/residenttest/pom.xml +++ b/residenttest/pom.xml @@ -1,10 +1,10 @@ 4.0.0 io.mosip.test - residentui - 0.9.0 - resident-ui-automation - resident-ui-automation + uitest-resident + 1.2.1-SNAPSHOT + uitest-resident + Parent project of uitest-resident https://github.com/mosip/resident-ui @@ -29,148 +29,9 @@ - - UTF-8 - - - 11 - 11 - 3.7.0 - 3.0.2 - 3.1.0 - 2.9 - 0.8.1 - 3.2 - 3.0.1 - 2.3 - true - 3.7.0.1746 - - 2.0.2.RELEASE - 2.0.7.RELEASE - 5.0.5.RELEASE - 2.0.0.RELEASE - - 2.0.7 - 1.5.20 - 2.9.2 - - 3.6.2 - 3.7.0 - - - - 1.2 - 3.0.0 - 1.3 - 2.2 - 2.0.1.Final - 2.2.6 - - - 1.4.197 - 5.1.46 - 42.2.2 - 2.5.0 - 6.0.12.Final - - - 1.10.19 - 1.7.4 - 2.0.0-beta.5 - - - 1.2.3 - 1.7.19 - 2.16.0 - 1.7.25 - - - 2.9.5 - 20180130 - 2.2.10 - 20180130 - - - 3.6.1 - 3.7 - 2.6 - 1.11 - 4.3 + 31.1-jre + 7.10.1 1.9.2 - 2.2 - 4.5.6 - 19.0 - 1.18.8 - 0.1.54 - 1.4.0 - 7.1.0 - 2.0.0 - 5.5.13 - 2.3.23 - 1.7 - 2.0 - 1.5.2 - 2.1.1 - 1.60 - 63.1 - 1.0.0 - 3.3.3 - 2.8.1 - 4.1.0-incubating - 1.11.368 - 0.2.4 - 2.3.0 - 3.0.1 - 1.9.12 - 0.6.0 - 2.0.0.AM2 - - - - - - - - 0.8.2 - 2.2 - 3.2 - UTF-8 - 3.7.0 - 3.0.1 - - - 1.1.6 - 1.7.19 - 1.10.19 - - - 1.4.6 - - - 5.0.6.RELEASE - - - 5.4.2.Final - - - 2.1.1 - - - 10.13.1.1 - - - 3.4.0 - - - 1.3.5 - - - 0.3.12 - - - 0.3.0 - 1.1.2-incubating 1.2.0.1-B1 @@ -182,15 +43,190 @@ 3.0.7 6.11 1.13 - residentui-0.9.0-jar-with-dependencies - + uitest-resident-1.2.1-SNAPSHOT-jar-with-dependencies + + + 21 + 21 + 3.8.0 + 3.0.2 + 3.1.0 + 3.7.0.1746 + + + + io.mosip.kernel + kernel-bom + 1.2.1-SNAPSHOT + pom + import + + + + + + + + org.seleniumhq.selenium + selenium-java + + + com.google.guava + guava + + + + + org.json + json + + + com.fasterxml.jackson.core + jackson-core + + + com.fasterxml.jackson.core + jackson-databind + + + com.amazonaws + aws-java-sdk-s3 + 1.12.470 + + + org.awaitility + awaitility + + + ch.qos.logback + logback-core + + + org.slf4j + slf4j-api + + + ch.qos.logback + logback-classic + + + com.paulhammant + ngwebdriver + 1.1.5 + + + com.aventstack + extentreports + 5.0.9 + + + io.github.bonigarcia + webdrivermanager + 5.1.0 + + + com.google.guava + guava + + + + + commons-io + commons-io + + + org.jboss.resteasy + resteasy-jaxrs + 3.15.0.Final + + + junit + junit + test + + + org.testng + testng + ${testng.version} + + + io.rest-assured + rest-assured + + + org.apache.logging.log4j + log4j-api + + + org.slf4j + slf4j-log4j12 + + + javax.ws.rs + javax.ws.rs-api + 2.1.1 + + + org.keycloak + keycloak-admin-client + 17.0.1 + + + com.google.guava + guava + + + + + commons-beanutils + commons-beanutils + ${commons.beanutils.version} + + + com.googlecode.json-simple + json-simple + + + org.apache.commons + commons-collections4 + + + commons-lang + commons-lang + 2.6 + + + com.google.guava + guava + ${guava.version} + + + org.apache.httpcomponents.client5 + httpclient5 + 5.1.3 + + + org.apache.httpcomponents.core5 + httpcore5 + 5.1.3 + + + com.github.jknack + handlebars + 3.0.0 + + + com.github.mifmif + generex + 1.0.2 + + - - + @@ -219,58 +255,33 @@ 3.0.1 - get-the-git-infos + populate-git-commit-information revision - validate + + true + MM/dd/yyyy HH:mm:ss Z + 8 + true + ${project.build.outputDirectory}/git.properties + - true - ${project.build.outputDirectory}/git.properties - - ^git.build.(time|version)$ - ^git.commit.id.(abbrev|full)$ - - full ${project.basedir}/.git - + org.apache.maven.plugins maven-compiler-plugin - 3.5.1 + ${maven.compiler.version} - 11 - 11 + ${maven.compiler.source} + ${maven.compiler.target} -Dfile.encoding=UTF-8 - org.apache.maven.plugins maven-shade-plugin @@ -283,16 +294,11 @@ ${fileName} - - - - + + io.mosip.testrig.residentui.utility.TestRunner - *:* @@ -320,8 +326,7 @@ - - + @@ -330,7 +335,6 @@ - selenium-tests @@ -400,176 +404,4 @@ - - - - - - - org.seleniumhq.selenium - selenium-java - 4.14.1 - - - - - - org.json - json - 20210307 - - - - - com.fasterxml.jackson.core - jackson-core - 2.12.5 - - - - com.fasterxml.jackson.core - jackson-databind - 2.12.5 - - - com.amazonaws - aws-java-sdk-s3 - 1.12.470 - - - - - org.awaitility - awaitility - 4.0.3 - - - ch.qos.logback - logback-core - 1.2.6 - - - org.slf4j - slf4j-api - 1.7.30 - - - - - ch.qos.logback - logback-classic - 1.2.6 - - - com.paulhammant - ngwebdriver - 1.1.5 - - - - - com.aventstack - extentreports - 5.0.9 - - - - - - io.github.bonigarcia - webdrivermanager - 5.1.0 - - - - org.testng - testng - 7.1.0 - - - - - - commons-io - commons-io - 2.6 - - - - - - org.jboss.resteasy - resteasy-jaxrs - 3.15.0.Final - - - - - - - junit - junit - 3.8.1 - test - - - org.testng - testng - ${testng.version} - - - io.rest-assured - rest-assured - ${rest.assured.version} - - - org.apache.logging.log4j - log4j-api - 2.11.1 - - - org.slf4j - slf4j-log4j12 - 1.6.2 - - - javax.ws.rs - javax.ws.rs-api - 2.1.1 - - - org.json - json - ${json.version} - - - org.keycloak - keycloak-admin-client - 17.0.1 - - - commons-beanutils - commons-beanutils - ${commons.beanutils.version} - - - com.googlecode.json-simple - json-simple - 1.1.1 - - - org.apache.commons - commons-collections4 - ${commons-collections4.version} - - - commons-lang - commons-lang - 2.6 - - - diff --git a/residenttest/src/main/java/io/mosip/testrig/residentui/fw/util/AdminTestUtil.java b/residenttest/src/main/java/io/mosip/testrig/residentui/fw/util/AdminTestUtil.java index 95845a16..8c80b92a 100644 --- a/residenttest/src/main/java/io/mosip/testrig/residentui/fw/util/AdminTestUtil.java +++ b/residenttest/src/main/java/io/mosip/testrig/residentui/fw/util/AdminTestUtil.java @@ -4,11 +4,13 @@ import java.io.File; import java.io.FileReader; import java.io.IOException; +import java.math.BigDecimal; import java.text.DateFormat; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; import java.util.HashMap; +import java.util.Map; import java.util.TimeZone; import javax.ws.rs.core.MediaType; @@ -41,6 +43,9 @@ public class AdminTestUtil extends BaseTestCase { public static String propsHealthCheckURL = TestRunner.getResourcePath() + "/" + "config/healthCheckEndpoint.properties"; private static String serverComponentsCommitDetails; + private static final Map actuatorValueCache = new HashMap<>(); + public static JSONArray authActuatorResponseArray = null; + public static String getUnUsedUIN(String role){ return JsonPrecondtion @@ -117,11 +122,18 @@ public static void genrateCredentialRequest(String rid,String role) { } public static String buildaddIdentityRequestBody(String schemaJson, String uin, String rid) { - org.json.JSONObject schemaresponseJson = new org.json.JSONObject(schemaJson); + JSONObject schemaresponseJson = new JSONObject(schemaJson); - org.json.JSONObject schemaData = (org.json.JSONObject) schemaresponseJson.get("response"); - Double schemaVersion = (Double) schemaData.get("idVersion"); - String schemaJsonData = schemaData.getString("schemaJson"); + JSONObject schemaData = (JSONObject) schemaresponseJson.get("response"); + Double schemaVersion = null; + Object idVersion = schemaData.get("idVersion"); + if (idVersion instanceof BigDecimal) { + schemaVersion = ((BigDecimal) idVersion).doubleValue(); + } else if (idVersion instanceof Double) { + schemaVersion = (Double) idVersion; + } else { + throw new ClassCastException("Unsupported type for idVersion: " + idVersion.getClass().getName()); + } String schemaJsonData = schemaData.getString("schemaJson"); String schemaFile = schemaJsonData.toString(); JSONObject schemaFileJson = new JSONObject(schemaFile); // jObj @@ -379,4 +391,40 @@ public static void closeFileReader(FileReader fileReader) { } } } + + public static String getValueFromAuthActuator(String section, String key) { + String url = ApplnURI + propsKernel.getProperty("actuatorIDAEndpoint"); + String actuatorCacheKey = url + section + key; + String value = actuatorValueCache.get(actuatorCacheKey); + if (value != null && !value.isEmpty()) + return value; + try { + if (authActuatorResponseArray == null) { + Response response = null; + JSONObject responseJson = null; + response = RestClient.getRequest(url, MediaType.APPLICATION_JSON, MediaType.APPLICATION_JSON); + + responseJson = new JSONObject(response.getBody().asString()); + authActuatorResponseArray = responseJson.getJSONArray("propertySources"); + } + + for (int i = 0, size = authActuatorResponseArray.length(); i < size; i++) { + JSONObject eachJson = authActuatorResponseArray.getJSONObject(i); + if (eachJson.get("name").toString().contains(section)) { + value = eachJson.getJSONObject(GlobalConstants.PROPERTIES).getJSONObject(key) + .get(GlobalConstants.VALUE).toString(); + if (ConfigManager.IsDebugEnabled()) + logger.info("Actuator: " + url + " key: " + key + " value: " + value); + break; + } + } + actuatorValueCache.put(actuatorCacheKey, value); + + return value; + } catch (Exception e) { + logger.error(GlobalConstants.EXCEPTION_STRING_2 + e); + return value; + } + + } } \ No newline at end of file diff --git a/residenttest/src/main/java/io/mosip/testrig/residentui/kernel/util/ConfigManager.java b/residenttest/src/main/java/io/mosip/testrig/residentui/kernel/util/ConfigManager.java index 13939769..4f045697 100644 --- a/residenttest/src/main/java/io/mosip/testrig/residentui/kernel/util/ConfigManager.java +++ b/residenttest/src/main/java/io/mosip/testrig/residentui/kernel/util/ConfigManager.java @@ -123,7 +123,9 @@ public class ConfigManager { private static String PACKET_UTILITY_BASE_URL = "packetUtilityBaseUrl"; private static String Testcases = "residentscenariosToExecute"; + private static String Image = "image"; + private static String image; private static String testcases; private static String pms_client_secret; private static String pms_client_id; @@ -417,6 +419,9 @@ public static void init() { testcases =System.getenv(Testcases) == null ? propsKernel.getProperty(Testcases) : System.getenv(Testcases); propsKernel.setProperty(Testcases, testcases); + + image =System.getenv(Image) == null ? propsKernel.getProperty(Image) : System.getenv(Image); + propsKernel.setProperty(Image, image); } @@ -426,6 +431,10 @@ public static int packetUpdateWait() { return wait; } + public static String getimagename() { + return image; + } + public static String gettestcases() { return testcases; } @@ -814,6 +823,7 @@ private static Properties getproperty(String path) { return prop; } + public static String getAuthDemoServiceUrl() { return ConfigManager.getAuthDemoServiceBaseUrl() + ":" + ConfigManager.getAuthDemoServicePort(); } diff --git a/residenttest/src/main/java/io/mosip/testrig/residentui/testcase/LoginTest.java b/residenttest/src/main/java/io/mosip/testrig/residentui/testcase/LoginTest.java index 36d5521a..54cdcd9c 100644 --- a/residenttest/src/main/java/io/mosip/testrig/residentui/testcase/LoginTest.java +++ b/residenttest/src/main/java/io/mosip/testrig/residentui/testcase/LoginTest.java @@ -13,10 +13,11 @@ @Test(groups = "LG") public class LoginTest extends BaseClass { - + public static int run=0; @Test(priority = 0) public static void loginTest() throws Exception { + String envPath = ConfigManager.getiam_residentportal_path(); String otp = ""; String externalemail = ConfigManager.getexternalemail(); driver.get(envPath); @@ -25,7 +26,7 @@ public static void loginTest() throws Exception { Commons.enter( driver, By.id("Otp_mosip-vid"), TestRunner.perpetualVid); Commons.click( driver, By.id("get_otp")); if(!Commons.isDisplayed(driver, By.id("otp_verify_input"))) { - Commons.wait(60000); + Commons.wait(120000); Commons.click( driver, By.id("get_otp")); } otp = MockSMTPListener.getOtp(externalemail); @@ -36,13 +37,14 @@ public static void loginTest() throws Exception { } Commons.click( driver, By.id("verify_otp")); Commons.wait(2000); - if(Commons.isDisplayed(driver, By.id("dismissBtn"))) - Commons.click(driver, By.id("dismissBtn")); - else { + if(run==0) { Commons.click(driver, By.id("authorize_scope")); Commons.click(driver, By.id("voluntary_claims")); Commons.click(driver, By.id("continue")); Commons.click(driver, By.id("dismissBtn")); + run=1; + }else if(run==1) { + Commons.click(driver, By.id("dismissBtn")); } Commons.assertCheck(By.id("uinservices/viewhistory"),"verify if uin services login using perpetual vid"); diff --git a/residenttest/src/main/java/io/mosip/testrig/residentui/testcase/ShareMyData.java b/residenttest/src/main/java/io/mosip/testrig/residentui/testcase/ShareMyData.java index 36c3bd6f..1bf5a6f3 100644 --- a/residenttest/src/main/java/io/mosip/testrig/residentui/testcase/ShareMyData.java +++ b/residenttest/src/main/java/io/mosip/testrig/residentui/testcase/ShareMyData.java @@ -14,8 +14,12 @@ public void shareMyData() throws Exception { LoginTest.loginTest(); Commons.clickWebelement( driver, By.id("uinservices/sharewithpartner")); + try { + Commons.clickWebelement( driver, By.id("fullName")); + }catch(Exception e) { + Commons.clickWebelement( driver, By.id("name")); - Commons.clickWebelement( driver, By.id("name")); + } Commons.clickWebelement( driver, By.id("dateOfBirth")); Commons.clickWebelement( driver, By.id("UIN")); Commons.dropdown( driver, By.id("partnerDetails")); @@ -27,13 +31,18 @@ public void shareMyData() throws Exception { Commons.clickWebelement( driver, By.id("dismissBtn")); Commons.clickWebelement( driver, By.id("uinservices/sharewithpartner")); - Commons.clickWebelement( driver, By.id("name")); + try { + Commons.clickWebelement( driver, By.id("fullName")); + }catch(Exception e) { + Commons.clickWebelement( driver, By.id("name")); + + } Commons.clickWebelement( driver, By.id("dateOfBirth")); Commons.clickWebelement( driver, By.id("UIN")); Commons.clickWebelement( driver, By.id("shareBtn")); Commons.clickWebelement( driver, By.id("dismissBtn")); - // without partner name + // without partner fullName Commons.enter( driver, By.id("sharingReasonPlaceholder"), data); Commons.clickWebelement( driver, By.id("shareBtn")); Commons.clickWebelement( driver, By.id("dismissBtn")); @@ -58,7 +67,12 @@ public void shareMyData() throws Exception { Commons.clickWebelement( driver, By.id("dismissBtn")); Commons.clickWebelement( driver, By.id("uinservices/sharewithpartner")); - Commons.clickWebelement( driver, By.id("name")); + try { + Commons.clickWebelement( driver, By.id("fullName")); + }catch(Exception e) { + Commons.clickWebelement( driver, By.id("name")); + + } Commons.clickWebelement( driver, By.id("dateOfBirth")); Commons.clickWebelement( driver, By.id("UIN")); Commons.clickWebelement( driver, By.id("perpetualVID")); diff --git a/residenttest/src/main/java/io/mosip/testrig/residentui/testcase/UpdateMyData.java b/residenttest/src/main/java/io/mosip/testrig/residentui/testcase/UpdateMyData.java index e3fd955f..db1f5947 100644 --- a/residenttest/src/main/java/io/mosip/testrig/residentui/testcase/UpdateMyData.java +++ b/residenttest/src/main/java/io/mosip/testrig/residentui/testcase/UpdateMyData.java @@ -4,6 +4,7 @@ import org.openqa.selenium.By; import org.testng.annotations.Test; +import io.mosip.testrig.residentui.fw.util.AdminTestUtil; import io.mosip.testrig.residentui.kernel.util.ConfigManager; import io.mosip.testrig.residentui.utility.BaseClass; import io.mosip.testrig.residentui.utility.Commons; @@ -17,7 +18,12 @@ public class UpdateMyData extends BaseClass { public void updateMyDataName() throws Exception { LoginTest.loginTest(); Commons.clickWebelement( driver, By.id("uinservices/updatedemographic")); - Commons.enter( driver, By.id("fullName"+BaseClass.envsupportlang()), Commons.generateRandomAlphabetString()); + String name = AdminTestUtil.getValueFromAuthActuator("json-property", "name"); + name = name.replace("[", "").replace("]", "").replace("\"", ""); + String[] names=name.split(","); + for(String Name:names) { + Commons.enter( driver, By.id(Name+BaseClass.envsupportlang()), Commons.generateRandomAlphabetString()); + } Commons.dropdown( driver, By.id("gender")); Commons.enter( driver, By.id("proofOfIdentityvalue"), data); Commons.dropdown( driver, By.id("proofOfIdentity")); diff --git a/residenttest/src/main/java/io/mosip/testrig/residentui/utility/Commons.java b/residenttest/src/main/java/io/mosip/testrig/residentui/utility/Commons.java index 9afee49b..be5ba2f8 100644 --- a/residenttest/src/main/java/io/mosip/testrig/residentui/utility/Commons.java +++ b/residenttest/src/main/java/io/mosip/testrig/residentui/utility/Commons.java @@ -6,6 +6,7 @@ import java.time.format.DateTimeFormatter; import java.util.NoSuchElementException; import java.util.Random; + import org.apache.log4j.Logger; import org.openqa.selenium.By; import org.openqa.selenium.JavascriptExecutor; @@ -16,6 +17,8 @@ import org.testng.Assert; import org.testng.Reporter; +import io.mosip.testrig.residentui.kernel.util.ConfigManager; + public class Commons extends BaseClass{ private static final Logger logger = Logger.getLogger(Commons.class); @@ -198,22 +201,30 @@ public static void wait(int wait) { public static void assertCheck(By by,String message) throws IOException { try { + if(!ConfigManager.getimagename().equals("0.9.0")) { wait(2000); WebDriverWait wait = new WebDriverWait(driver, Duration.ofSeconds(20)); wait.until(ExpectedConditions.presenceOfElementLocated(by)); boolean isDisplayed = Commons.isDisplayed(driver, by); Assert.assertTrue(isDisplayed,message); + } - } catch (AssertionError e) { + }catch (Exception te) { + Reporter.log("

"); + throw te; + + } catch (AssertionError e) { Reporter.log("

"); throw e; } } - + public static void assertCheckString(String text,String message) throws IOException { try { + if(!ConfigManager.getimagename().equals("0.9.0")) { wait(2000); Assert.assertNotNull(text,message); + } } catch (AssertionError e) { Reporter.log("

"); diff --git a/residenttest/src/main/java/io/mosip/testrig/residentui/utility/EmailableReport.java b/residenttest/src/main/java/io/mosip/testrig/residentui/utility/EmailableReport.java index b09bf9a6..1178da8a 100644 --- a/residenttest/src/main/java/io/mosip/testrig/residentui/utility/EmailableReport.java +++ b/residenttest/src/main/java/io/mosip/testrig/residentui/utility/EmailableReport.java @@ -10,6 +10,8 @@ import java.io.PrintWriter; import java.lang.reflect.Field; import java.text.NumberFormat; +import java.time.LocalDate; +import java.time.format.DateTimeFormatter; import java.util.Collections; import java.util.Comparator; import java.util.Iterator; @@ -111,16 +113,10 @@ public void generateReport(List xmlSuites, List suites, String boolean isStoreSuccess = false; boolean isStoreSuccess2 = false; try { - isStoreSuccess = s3Adapter.putObject(ConfigManager.getS3Account(), BaseTestCase.testLevel, null, + isStoreSuccess = s3Adapter.putObject(ConfigManager.getS3Account(),"Residentui", null, null, newString, newReportFile); logger.info("isStoreSuccess:: " + isStoreSuccess); - /* Need to figure how to handle EXTENT report handling */ - - - - - } catch (Exception e) { logger.error("error occured while pushing the object" + e.getMessage()); } @@ -142,16 +138,12 @@ private String getCommitId() { Properties properties = new Properties(); try (InputStream is = EmailableReport.class.getClassLoader().getResourceAsStream("git.properties")) { properties.load(is); - Process process = Runtime.getRuntime().exec("git rev-parse --abbrev-ref HEAD"); - // Read the output of the command - BufferedReader reader = new BufferedReader(new InputStreamReader(process.getInputStream())); - String branch = reader.readLine(); return "Commit Id is: " + properties.getProperty("git.commit.id.abbrev") + " & Branch Name is:" - + branch; + + properties.getProperty("git.branch"); - } catch (IOException io) { - logger.error(io.getMessage()); + } catch (IOException e) { + logger.error(e.getMessage()); return ""; } @@ -181,24 +173,31 @@ protected void writeHead() { protected void writeStylesheet() { writer.print(""); + writer.print("table {margin-bottom:10px;border-collapse:collapse;empty-cells:show;width: 100%;}"); + writer.print("th,td {border:1px solid #009;padding:.25em .5em;width: 25%;}"); // Set a fixed width for uniform cell sizes + writer.print("th {vertical-align:bottom}"); + writer.print("td {vertical-align:top}"); + writer.print("table a {font-weight:bold}"); + writer.print(".stripe td {background-color: #E6EBF9}"); + writer.print(".num {text-align:center}"); + writer.print(".orange-bg {background-color: #FFA500}"); + writer.print(".grey-bg {background-color: #808080}"); + writer.print(".thich-orange-bg {background-color: #CC5500}"); + writer.print(".green-bg {background-color: #0A0}"); + writer.print(".attn {background-color: #D00}"); + writer.print(".passedodd td {background-color: #3F3}"); + writer.print(".passedeven td {background-color: #0A0}"); + writer.print(".skippedodd td {background-color: #FFA500}"); + writer.print(".skippedeven td,.stripe {background-color: #FFA500}"); + writer.print(".failedodd td {background-color: #F33}"); + writer.print(".failedeven td,.stripe {background-color: #D00}"); + writer.print(".ignoredodd td {background-color: #808080}"); + writer.print(".ignoredeven td {background-color: #808080}"); + writer.print(".known_issuesodd td {background-color: #CC5500}"); + writer.print(".known_issueseven td {background-color: #CC5500}"); + writer.print(".stacktrace {white-space:pre;font-family:monospace}"); + writer.print(".totop {font-size:85%;text-align:center;border-bottom:2px solid #000}"); + writer.print(""); } protected void writeBody() { @@ -216,7 +215,21 @@ protected void writeDocumentEnd() { protected void writeSuiteSummary() { NumberFormat integerFormat = NumberFormat.getIntegerInstance(); NumberFormat decimalFormat = NumberFormat.getNumberInstance(); - + String formattedDate =null; + LocalDate currentDate = LocalDate.now(); + String branch = null; + + try { + + DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd"); + formattedDate = currentDate.format(formatter); + Process process = Runtime.getRuntime().exec("git rev-parse --abbrev-ref HEAD"); + BufferedReader reader = new BufferedReader(new InputStreamReader(process.getInputStream())); + branch = reader.readLine(); + } + catch (Exception e) { + // TODO: handle exception + } totalPassedTests = 0; totalSkippedTests = 0; totalFailedTests = 0; @@ -226,13 +239,15 @@ protected void writeSuiteSummary() { for (SuiteResult suiteResult : suiteResults) { writer.print(""); - writer.print(Utils.escapeHtml(suiteResult.getSuiteName() + "-" + getCommitId())); - writer.print(""); + writer.print(Utils.escapeHtml(suiteResult.getSuiteName() + " ---- " + "Report Date: " + formattedDate + + " ---- " + "Tested Environment: " + + ConfigManager.getiam_apienvuser().replaceAll(".*?\\.([^\\.]+)\\..*", "$1") + " ---- " + + getCommitId())); writer.print(""); writer.print("
");
 			writer.print(Utils.escapeHtml("Server Component Details " + AdminTestUtil.getServerComponentsDetails()));
 			writer.print("
"); - // writer.print(GlobalConstants.TRTR); + writer.print(""); writer.print(""); // writer.print("Test Suite"); diff --git a/residenttest/src/main/java/io/mosip/testrig/residentui/utility/TestRunner.java b/residenttest/src/main/java/io/mosip/testrig/residentui/utility/TestRunner.java index 925d6da9..3762af14 100644 --- a/residenttest/src/main/java/io/mosip/testrig/residentui/utility/TestRunner.java +++ b/residenttest/src/main/java/io/mosip/testrig/residentui/utility/TestRunner.java @@ -60,7 +60,7 @@ public static void startTestRunner() throws Exception { TestNG runner = new TestNG(); if(!ConfigManager.gettestcases().equals("")) { XmlSuite suite = new XmlSuite(); - suite.setName("MySuite"); + suite.setName("RESIDENT-UI-AUTOMATION-RUN"); suite.addListener("io.mosip.testrig.residentui.utility.EmailableReport"); XmlClass getInformation = new XmlClass("io.mosip.testrig.residentui.testcase.GetInformation"); diff --git a/residenttest/src/main/resources/config/Kernel.properties b/residenttest/src/main/resources/config/Kernel.properties index bc48173c..9f73c0af 100644 --- a/residenttest/src/main/resources/config/Kernel.properties +++ b/residenttest/src/main/resources/config/Kernel.properties @@ -266,3 +266,4 @@ postalcode=14080 headless=yes docker=yes packetUpdateWait=2 +image=develop