From 3bd5d2c13b06ba6191126111aaa7a2e95d172d3c Mon Sep 17 00:00:00 2001 From: aabughosh <88486034+aabughosh@users.noreply.github.com> Date: Thu, 19 Oct 2023 17:43:02 +0300 Subject: [PATCH] website for our cnf to run need to call ./run-cnf-suites.sh -l lifecycle -s true -s new filed mean if i want to run that from the website --- cnf-certification-test/amalpro/index.html | 247 ++++++++++++++ cnf-certification-test/amalpro/logs.js | 13 + cnf-certification-test/amalpro/submit.js | 48 +++ cnf-certification-test/amalpro/toast.js | 53 +++ cnf-certification-test/index.html | 260 ++++++++++++++ cnf-certification-test/log.log | 395 ++++++++++++++++++++++ cnf-certification-test/suite_test.go | 353 +++++++++++++++++-- 7 files changed, 1340 insertions(+), 29 deletions(-) create mode 100644 cnf-certification-test/amalpro/index.html create mode 100644 cnf-certification-test/amalpro/logs.js create mode 100644 cnf-certification-test/amalpro/submit.js create mode 100644 cnf-certification-test/amalpro/toast.js create mode 100644 cnf-certification-test/index.html create mode 100644 cnf-certification-test/log.log diff --git a/cnf-certification-test/amalpro/index.html b/cnf-certification-test/amalpro/index.html new file mode 100644 index 000000000..14b632651 --- /dev/null +++ b/cnf-certification-test/amalpro/index.html @@ -0,0 +1,247 @@ + + + + + + CNF Certification Test + + + + + + + + + + + + +
+ Red Hat +
+ +
+

CNF Certification Test

+ +
+ + +
+ Environment Configuration + + +
+ +
+ TNF Configuration + + + + + + +
+ +
+ Select a Test + + + +
+ + Run Certification Test +
+ Show Log +
+ + +

Logs

+ No Logs Found + Close +
+ + + + + + © 2022 Red Hat, Inc. + + + + + ({ ...acc, + [key]: key in acc ? [acc[key], val] : val + }), {}); + + delete fields.submit; + console.log(fields); + + // Send an HTTP request to the server to run the function + let heading; + let message; + let state = 'success'; + + try { + const data = await fetch('/runFunction', { + method: 'POST', + headers: { 'Content-Type': 'application/json', }, + body: JSON.stringify(fields), + }).then(response => { + if (response.ok) { + return response.json(); + } else { + throw new Error(response.statusText); + } + }); + + heading = 'Success'; + message = data.Message; + + console.log(data); + } catch (error) { + console.error(error); + heading = 'Error' + message = error.message; + state = 'danger'; + } finally { + form.elements.submit.disabled = false; + for (const el of form.elements) if (el instanceof HTMLFieldSetElement) el.disabled = false + } + + return { heading, message, state }; + } \ No newline at end of file diff --git a/cnf-certification-test/amalpro/toast.js b/cnf-certification-test/amalpro/toast.js new file mode 100644 index 000000000..1516826de --- /dev/null +++ b/cnf-certification-test/amalpro/toast.js @@ -0,0 +1,53 @@ +import '@rhds/elements/rh-alert/rh-alert.js'; + +export async function toast({ + heading, + message, + state = 'info', + timeout = 8_000, +}) { + await import('@rhds/elements/rh-alert/rh-alert.js'); + const h2 = document.createElement('h2'); + h2.textContent = heading; + h2.slot = 'header'; + const alert = document.createElement('rh-alert'); + alert.setAttribute('aria-live', 'polite'); + alert.dismissable = true; + alert.state = state; + alert.classList.add('toast'); + alert.style.position = 'fixed'; + alert.style.margin = '0'; + alert.style.setProperty('z-index', '1000'); + alert.style.setProperty('inset-inline-end', 'var(--rh-space-xl, 24px)'); + alert.style.setProperty('inset-block-start', 'var(--rh-space-xl, 24px)'); + alert.append(h2); + if (message) { + const p = document.createElement('p'); + p.textContent = message; + alert.append(message); + } + + alert.animate({ translate: ['100% 0', '0 0'] }, { duration: 200 }); + + await Promise.all(Array.from(document.querySelectorAll('rh-alert.toast'), toast => + // TODO: handle more than 2 toasts + toast.animate({ + translate: [ + '0 auto', + '0 calc(100% + 20px)', + ], + }, { + duration: 200, + composite: 'accumulate', + rangeEnd: '100%', + fill: 'forwards', + }).finished)); + + setTimeout(() => { + if (alert.isConnected) { + alert.remove(); + } + }, timeout); + + document.body.append(alert); +} \ No newline at end of file diff --git a/cnf-certification-test/index.html b/cnf-certification-test/index.html new file mode 100644 index 000000000..f4e096447 --- /dev/null +++ b/cnf-certification-test/index.html @@ -0,0 +1,260 @@ + + + + + + + + + + + Run Function + + + + + + + + + Red Hat logo +

CNF CERTIFICATION TEST WEBPAGE

+
+
+
+ + +

Environment Configuration

+
+ + + + + +

TNF Configuration

+
+ + + + + + + +

Selecet a Test

+
+ +
+
+ + + +
+
+
+
+ +

Click Run Certification Test

+ Run Certification Test +

Show Certification Test log

+ Show Log + + +
+

Log Output

+

+		X
+    
+ + + + + + + © 2022 Red Hat, Inc. + + + \ No newline at end of file diff --git a/cnf-certification-test/log.log b/cnf-certification-test/log.log new file mode 100644 index 000000000..f68b6425e --- /dev/null +++ b/cnf-certification-test/log.log @@ -0,0 +1,395 @@ +INFO [Oct 19 17:05:52.390][suite_test.go: 398] KUBECONFIG : /Users/amal/Downloads/kubeconfig.3nodes +INFO [Oct 19 17:05:52.390][suite_test.go: 400] Labels filter : lifecycle +INFO [Oct 19 17:05:52.390][suite_test.go: 436] /Users/amal/Downloads/kubeconfig.3nodes +INFO [Oct 19 17:05:52.390][utils.go: 66] Saving environment variables & parameters. +INFO [Oct 19 17:05:52.390][utils.go: 71] Environment: {Home:/Users/amal Kubeconfig:/Users/amal/Downloads/kubeconfig.3nodes ConfigurationPath:tnf_config.yml NonIntrusiveOnly:false LogLevel:debug OfflineDB: AllowPreflightInsecure:false PfltDockerconfig: IncludeWebFilesInOutputFolder:false OmitArtifactsZipFile:false EnableDataCollection:false} +INFO [Oct 19 17:05:52.390][suite_test.go: 122] Log level set to: debug +INFO [Oct 19 17:05:52.391][suite_test.go: 452] Ginkgo Version : 2.12.1 +INFO [Oct 19 17:05:52.391][suite_test.go: 453] Labels filter : lifecycle +INFO [Oct 19 17:05:52.391][suite_test.go: 128] &{/Users/amal /Users/amal/Downloads/kubeconfig.3nodes tnf_config.yml false debug false false false false} +INFO [Oct 19 17:05:52.391][clientsholder.go: 169] Creating k8s go-clients holder. +INFO [Oct 19 17:05:53.857][utils.go: 42] Loading config from file: tnf_config.yml +WARNING[Oct 19 17:05:53.858][utils.go: 55] No namespace configured for the debug DaemonSet. Defaulting to namespace cnf-suite +INFO [Oct 19 17:06:05.785][main.go: 436] namespace cnf-suite deleted +INFO [Oct 19 17:06:06.411][main.go: 175] Checking if the daemonset exists +INFO [Oct 19 17:06:06.566][main.go: 178] daemonset tnf-debug does not exist, err=daemonsets.apps "tnf-debug" not found +INFO [Oct 19 17:06:06.566][main.go: 226] Creating daemonset tnf-debug +INFO [Oct 19 17:06:07.344][main.go: 264] Waiting for (3) daemonset pods to be ready: {CurrentNumberScheduled:3 NumberMisscheduled:0 DesiredNumberScheduled:3 NumberReady:0 ObservedGeneration:1 UpdatedNumberScheduled:3 NumberAvailable:0 NumberUnavailable:3 CollisionCount: Conditions:[]} +INFO [Oct 19 17:06:12.502][main.go: 264] Waiting for (3) daemonset pods to be ready: {CurrentNumberScheduled:3 NumberMisscheduled:0 DesiredNumberScheduled:3 NumberReady:3 ObservedGeneration:1 UpdatedNumberScheduled:3 NumberAvailable:3 NumberUnavailable:0 CollisionCount: Conditions:[]} +INFO [Oct 19 17:06:12.502][main.go: 281] All the debug pods are ready. +INFO [Oct 19 17:06:12.502][main.go: 237] Daemonset is ready +INFO [Oct 19 17:06:12.811][main.go: 243] Successfully created daemonset tnf-debug +INFO [Oct 19 17:06:13.283][main.go: 264] Waiting for (3) daemonset pods to be ready: {CurrentNumberScheduled:3 NumberMisscheduled:0 DesiredNumberScheduled:3 NumberReady:3 ObservedGeneration:1 UpdatedNumberScheduled:3 NumberAvailable:3 NumberUnavailable:0 CollisionCount: Conditions:[]} +INFO [Oct 19 17:06:13.283][main.go: 281] All the debug pods are ready. +INFO [Oct 19 17:06:13.441][autodiscover.go: 154] parsed pods under test labels: [{LabelKey:test-network-function.com/generic LabelValue:target}] +INFO [Oct 19 17:06:13.441][autodiscover.go: 155] parsed operators under test labels: [{LabelKey:test-network-function.com/operator1 LabelValue:new} {LabelKey:test-network-function.com/operator LabelValue:}] +DEBUG [Oct 19 17:06:13.609][autodiscover_operators.go: 135] Searching subscriptions in namespace All Namespaces +INFO [Oct 19 17:06:13.764][autodiscover_operators.go: 144] Found 2 subscriptions in the target namespaces +INFO [Oct 19 17:06:13.764][autodiscover_operators.go: 146] Subscriptions name: lvms-operator (ns: openshift-storage) +INFO [Oct 19 17:06:13.764][autodiscover_operators.go: 146] Subscriptions name: test-subscription (ns: tnf) +DEBUG [Oct 19 17:06:13.764][autodiscover_operators.go: 112] Searching CSVs in namespace All +INFO [Oct 19 17:06:13.932][autodiscover_operators.go: 121] Found 2 CSVs: +INFO [Oct 19 17:06:13.932][autodiscover_operators.go: 123] CSV name: packageserver (ns: openshift-operator-lifecycle-manager) +INFO [Oct 19 17:06:13.932][autodiscover_operators.go: 123] CSV name: lvms-operator.v4.13.1 (ns: openshift-storage) +DEBUG [Oct 19 17:06:14.253][autodiscover_pods.go: 34] Searching Pods with label test-network-function.com/generic=target +DEBUG [Oct 19 17:06:14.583][autodiscover_pods.go: 34] Searching Pods with label test-network-function.com/app=tnf-debug +INFO [Oct 19 17:06:16.090][autodiscover_scales.go: 40] Target CRD crdexamples.test-network-function.com is not scalable. Skipping search of scalable CRs. +DEBUG [Oct 19 17:06:16.090][autodiscover_operators.go: 69] Searching CSVs in namespace {tnf} +DEBUG [Oct 19 17:06:16.090][autodiscover_operators.go: 76] Searching CSVs with label test-network-function.com/operator1=new +DEBUG [Oct 19 17:06:16.243][autodiscover_operators.go: 76] Searching CSVs with label test-network-function.com/operator +INFO [Oct 19 17:06:16.398][autodiscover_operators.go: 91] Found 0 CSVs: +DEBUG [Oct 19 17:06:16.398][autodiscover_operators.go: 135] Searching subscriptions in namespace tnf +INFO [Oct 19 17:06:16.551][autodiscover_operators.go: 144] Found 1 subscriptions in the target namespaces +INFO [Oct 19 17:06:16.551][autodiscover_operators.go: 146] Subscriptions name: test-subscription (ns: tnf) +INFO [Oct 19 17:06:17.018][autodiscover.go: 276] OpenShift Version found: 4.13.0 +INFO [Oct 19 17:06:17.324][autodiscover_podset.go: 80] Deployment test found in ns tnf +INFO [Oct 19 17:06:17.478][autodiscover_podset.go: 113] StatefulSet test found in ns tnf +INFO [Oct 19 17:06:18.760][operators.go: 130] Found 2 unique CSVs +INFO [Oct 19 17:06:18.760][operators.go: 132] CSV: packageserver +INFO [Oct 19 17:06:18.761][operators.go: 132] CSV: lvms-operator.v4.13.1 +INFO [Oct 19 17:06:18.914][operators.go: 185] Getting installplans for op lvms-operator.v4.13.1 (subs lvms-operator ns openshift-storage) +WARNING[Oct 19 17:06:18.914][operators.go: 183] Subscription not found for CSV: packageserver (ns openshift-operator-lifecycle-manager) +INFO [Oct 19 17:06:18.914][operators.go: 185] Getting installplans for op packageserver (subs ns ) +INFO [Oct 19 17:06:18.914][provider.go: 566] Node clus0-0 - mc name: rendered-master-87e86cb409fb5f914d4c94bee99ef373 +INFO [Oct 19 17:06:19.091][provider.go: 566] Node clus0-1 - mc name: rendered-master-87e86cb409fb5f914d4c94bee99ef373 +INFO [Oct 19 17:06:19.265][provider.go: 566] Node clus0-2 - mc name: rendered-master-87e86cb409fb5f914d4c94bee99ef373 +DEBUG [Oct 19 17:06:19.436][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:19.436][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:19.436][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:19.436][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:19.436][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:19.436][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:19.436][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:19.436][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:19.436][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:19.436][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:19.436][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:19.436][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +INFO [Oct 19 17:06:19.437][operators.go: 130] Found 0 unique CSVs +INFO [Oct 19 17:06:19.437][provider.go: 299] Operators found: 0 +INFO [Oct 19 17:06:19.437][provider.go: 311] Completed the test environment build process in 25.58 seconds +This will be written to the log file. +DEBUG [Oct 19 17:06:36.971][utils.go: 38] config file already loaded, return previous element +INFO [Oct 19 17:06:37.282][autodiscover.go: 154] parsed pods under test labels: [{LabelKey:test-network-function.com/generic LabelValue:target}] +INFO [Oct 19 17:06:37.282][autodiscover.go: 155] parsed operators under test labels: [{LabelKey:test-network-function.com/operator1 LabelValue:new} {LabelKey:test-network-function.com/operator LabelValue:}] +DEBUG [Oct 19 17:06:37.601][autodiscover_operators.go: 135] Searching subscriptions in namespace All Namespaces +INFO [Oct 19 17:06:37.757][autodiscover_operators.go: 144] Found 2 subscriptions in the target namespaces +INFO [Oct 19 17:06:37.757][autodiscover_operators.go: 146] Subscriptions name: lvms-operator (ns: openshift-storage) +INFO [Oct 19 17:06:37.757][autodiscover_operators.go: 146] Subscriptions name: test-subscription (ns: tnf) +DEBUG [Oct 19 17:06:37.757][autodiscover_operators.go: 112] Searching CSVs in namespace All +INFO [Oct 19 17:06:38.081][autodiscover_operators.go: 121] Found 2 CSVs: +INFO [Oct 19 17:06:38.081][autodiscover_operators.go: 123] CSV name: packageserver (ns: openshift-operator-lifecycle-manager) +INFO [Oct 19 17:06:38.081][autodiscover_operators.go: 123] CSV name: lvms-operator.v4.13.1 (ns: openshift-storage) +DEBUG [Oct 19 17:06:38.398][autodiscover_pods.go: 34] Searching Pods with label test-network-function.com/generic=target +DEBUG [Oct 19 17:06:38.727][autodiscover_pods.go: 34] Searching Pods with label test-network-function.com/app=tnf-debug +INFO [Oct 19 17:06:40.202][autodiscover_scales.go: 40] Target CRD crdexamples.test-network-function.com is not scalable. Skipping search of scalable CRs. +DEBUG [Oct 19 17:06:40.202][autodiscover_operators.go: 69] Searching CSVs in namespace {tnf} +DEBUG [Oct 19 17:06:40.202][autodiscover_operators.go: 76] Searching CSVs with label test-network-function.com/operator1=new +DEBUG [Oct 19 17:06:40.396][autodiscover_operators.go: 76] Searching CSVs with label test-network-function.com/operator +INFO [Oct 19 17:06:40.554][autodiscover_operators.go: 91] Found 0 CSVs: +DEBUG [Oct 19 17:06:40.554][autodiscover_operators.go: 135] Searching subscriptions in namespace tnf +INFO [Oct 19 17:06:40.712][autodiscover_operators.go: 144] Found 1 subscriptions in the target namespaces +INFO [Oct 19 17:06:40.712][autodiscover_operators.go: 146] Subscriptions name: test-subscription (ns: tnf) +INFO [Oct 19 17:06:41.179][autodiscover.go: 276] OpenShift Version found: 4.13.0 +INFO [Oct 19 17:06:41.497][autodiscover_podset.go: 80] Deployment test found in ns tnf +INFO [Oct 19 17:06:41.652][autodiscover_podset.go: 113] StatefulSet test found in ns tnf +INFO [Oct 19 17:06:42.947][operators.go: 130] Found 2 unique CSVs +INFO [Oct 19 17:06:42.947][operators.go: 132] CSV: packageserver +INFO [Oct 19 17:06:42.948][operators.go: 132] CSV: lvms-operator.v4.13.1 +INFO [Oct 19 17:06:43.101][operators.go: 185] Getting installplans for op lvms-operator.v4.13.1 (subs lvms-operator ns openshift-storage) +WARNING[Oct 19 17:06:43.101][operators.go: 183] Subscription not found for CSV: packageserver (ns openshift-operator-lifecycle-manager) +INFO [Oct 19 17:06:43.101][operators.go: 185] Getting installplans for op packageserver (subs ns ) +INFO [Oct 19 17:06:43.101][provider.go: 566] Node clus0-0 - mc name: rendered-master-87e86cb409fb5f914d4c94bee99ef373 +INFO [Oct 19 17:06:43.269][provider.go: 566] Node clus0-1 - mc name: rendered-master-87e86cb409fb5f914d4c94bee99ef373 +INFO [Oct 19 17:06:43.438][provider.go: 566] Node clus0-2 - mc name: rendered-master-87e86cb409fb5f914d4c94bee99ef373 +DEBUG [Oct 19 17:06:43.613][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:43.614][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:43.614][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:43.614][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:43.614][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:43.614][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:43.614][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:43.614][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:43.614][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:43.614][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:43.614][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:06:43.614][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +INFO [Oct 19 17:06:43.614][operators.go: 130] Found 0 unique CSVs +INFO [Oct 19 17:06:43.614][provider.go: 299] Operators found: 0 +INFO [Oct 19 17:06:43.614][provider.go: 311] Completed the test environment build process in 6.64 seconds +DEBUG [Oct 19 17:06:43.614][suite.go: 60] Entering access-control suite +DEBUG [Oct 19 17:06:43.614][suite.go: 46] Entering affiliated-certification suite +DEBUG [Oct 19 17:06:43.614][suite.go: 54] Entering lifecycle suite +DEBUG [Oct 19 17:06:43.615][suite.go: 34] Entering manageability suite +DEBUG [Oct 19 17:06:43.615][suite.go: 52] Entering networking suite +DEBUG [Oct 19 17:06:43.615][suite.go: 40] Entering observability suite +DEBUG [Oct 19 17:06:43.615][suite.go: 35] Entering operator suite +DEBUG [Oct 19 17:06:43.615][suite.go: 49] Entering platform-alteration suite +DEBUG [Oct 19 17:06:43.615][suite.go: 34] Entering preflight suite +DEBUG [Oct 19 17:06:43.615][suite.go: 43] Skipping the preflight suite because the Docker Config file is not provided. +DEBUG [Oct 19 17:06:43.615][suite.go: 44] Entering performance suite +DEBUG [Oct 19 17:06:43.616][suite.go: 204] check container container: test pod: test-0 ns: tnf pre stop lifecycle +DEBUG [Oct 19 17:06:43.616][suite.go: 204] check container container: test pod: test-1 ns: tnf pre stop lifecycle +DEBUG [Oct 19 17:06:43.616][suite.go: 204] check container container: test pod: test-d78fbf8d6-2fk6c ns: tnf pre stop lifecycle +DEBUG [Oct 19 17:06:43.616][suite.go: 204] check container container: test pod: test-d78fbf8d6-wmj2m ns: tnf pre stop lifecycle +DEBUG [Oct 19 17:06:43.616][suite.go: 220] check container container: test pod: test-0 ns: tnf post start lifecycle +DEBUG [Oct 19 17:06:43.616][suite.go: 220] check container container: test pod: test-1 ns: tnf post start lifecycle +DEBUG [Oct 19 17:06:43.616][suite.go: 220] check container container: test pod: test-d78fbf8d6-2fk6c ns: tnf post start lifecycle +DEBUG [Oct 19 17:06:43.616][suite.go: 220] check container container: test pod: test-d78fbf8d6-wmj2m ns: tnf post start lifecycle +DEBUG [Oct 19 17:06:43.616][suite.go: 237] check container container: test pod: test-0 ns: tnf pull policy, should be IfNotPresent +DEBUG [Oct 19 17:06:43.616][suite.go: 237] check container container: test pod: test-1 ns: tnf pull policy, should be IfNotPresent +DEBUG [Oct 19 17:06:43.617][suite.go: 237] check container container: test pod: test-d78fbf8d6-2fk6c ns: tnf pull policy, should be IfNotPresent +DEBUG [Oct 19 17:06:43.617][suite.go: 237] check container container: test pod: test-d78fbf8d6-wmj2m ns: tnf pull policy, should be IfNotPresent +DEBUG [Oct 19 17:06:43.617][suite.go: 252] check container container: test pod: test-0 ns: tnf readiness probe +DEBUG [Oct 19 17:06:43.617][suite.go: 252] check container container: test pod: test-1 ns: tnf readiness probe +DEBUG [Oct 19 17:06:43.617][suite.go: 252] check container container: test pod: test-d78fbf8d6-2fk6c ns: tnf readiness probe +DEBUG [Oct 19 17:06:43.617][suite.go: 252] check container container: test pod: test-d78fbf8d6-wmj2m ns: tnf readiness probe +DEBUG [Oct 19 17:06:43.617][suite.go: 267] check container container: test pod: test-0 ns: tnf liveness probe +DEBUG [Oct 19 17:06:43.617][suite.go: 267] check container container: test pod: test-1 ns: tnf liveness probe +DEBUG [Oct 19 17:06:43.617][suite.go: 267] check container container: test pod: test-d78fbf8d6-2fk6c ns: tnf liveness probe +DEBUG [Oct 19 17:06:43.617][suite.go: 267] check container container: test pod: test-d78fbf8d6-wmj2m ns: tnf liveness probe +DEBUG [Oct 19 17:06:43.617][suite.go: 282] check container container: test pod: test-0 ns: tnf startup probe +DEBUG [Oct 19 17:06:43.617][suite.go: 282] check container container: test pod: test-1 ns: tnf startup probe +DEBUG [Oct 19 17:06:43.617][suite.go: 282] check container container: test pod: test-d78fbf8d6-2fk6c ns: tnf startup probe +DEBUG [Oct 19 17:06:43.617][suite.go: 282] check container container: test pod: test-d78fbf8d6-wmj2m ns: tnf startup probe +DEBUG [Oct 19 17:06:43.618][suite.go: 298] check pod tnf test-0 owner reference +DEBUG [Oct 19 17:06:43.618][suite.go: 298] check pod tnf test-1 owner reference +DEBUG [Oct 19 17:06:43.618][suite.go: 298] check pod tnf test-d78fbf8d6-2fk6c owner reference +DEBUG [Oct 19 17:06:43.618][suite.go: 298] check pod tnf test-d78fbf8d6-wmj2m owner reference +INFO [Oct 19 17:06:43.618][podsets.go: 190] Waiting 9m0s for 2 podsets to be ready. +INFO [Oct 19 17:06:43.618][podsets.go: 192] Checking Deployments readiness of Deployments [tnf:test] +DEBUG [Oct 19 17:06:43.773][podsets.go: 152] deployment: test ns: tnf is ready. +INFO [Oct 19 17:06:43.773][podsets.go: 195] Checking StatefulSets readiness of StatefulSets [tnf:test] +DEBUG [Oct 19 17:06:43.933][podsets.go: 175] statefulset: test ns: tnf is ready. +INFO [Oct 19 17:06:43.933][podsets.go: 198] Not ready Deployments: [] +INFO [Oct 19 17:06:43.933][podsets.go: 199] Not ready StatefulSets: [] +DEBUG [Oct 19 17:06:43.933][loghelper.go: 40] Not ready Deployments: [] +DEBUG [Oct 19 17:06:43.933][loghelper.go: 40] Not ready StatefulSets: [] +INFO [Oct 19 17:06:43.933][podrecreation.go: 51] Performing cordon operation on node clus0-2 +DEBUG [Oct 19 17:06:44.405][suite.go: 570] node: clus0-2 cordoned +DEBUG [Oct 19 17:06:44.406][suite.go: 576] draining node: clus0-2 with timeout: 8m0s +DEBUG [Oct 19 17:06:44.406][podrecreation.go: 113] deleting ns=tnf pod=test-0 with deleteForeground mode +DEBUG [Oct 19 17:06:45.574][podrecreation.go: 159] ns=tnf pod=test-0 deleted +INFO [Oct 19 17:06:45.574][podsets.go: 190] Waiting 8m0s for 2 podsets to be ready. +INFO [Oct 19 17:06:45.575][podsets.go: 192] Checking Deployments readiness of Deployments [tnf:test] +DEBUG [Oct 19 17:06:45.730][podsets.go: 152] deployment: test ns: tnf is ready. +INFO [Oct 19 17:06:45.730][podsets.go: 195] Checking StatefulSets readiness of StatefulSets [tnf:test] +INFO [Oct 19 17:06:45.888][podsets.go: 198] Not ready Deployments: [] +INFO [Oct 19 17:06:45.888][podsets.go: 199] Not ready StatefulSets: [tnf:test] +INFO [Oct 19 17:07:00.888][podsets.go: 192] Checking Deployments readiness of Deployments [] +INFO [Oct 19 17:07:00.889][podsets.go: 195] Checking StatefulSets readiness of StatefulSets [tnf:test] +DEBUG [Oct 19 17:07:01.055][podsets.go: 175] statefulset: test ns: tnf is ready. +INFO [Oct 19 17:07:01.056][podsets.go: 198] Not ready Deployments: [] +INFO [Oct 19 17:07:01.056][podsets.go: 199] Not ready StatefulSets: [] +DEBUG [Oct 19 17:07:01.056][loghelper.go: 40] Not ready Deployments: [] +DEBUG [Oct 19 17:07:01.056][loghelper.go: 40] Not ready StatefulSets: [] +INFO [Oct 19 17:07:01.056][podrecreation.go: 51] Performing uncordon operation on node clus0-2 +INFO [Oct 19 17:07:02.642][podrecreation.go: 51] Performing cordon operation on node clus0-0 +DEBUG [Oct 19 17:07:03.963][suite.go: 570] node: clus0-0 cordoned +DEBUG [Oct 19 17:07:03.964][suite.go: 576] draining node: clus0-0 with timeout: 9m0s +DEBUG [Oct 19 17:07:03.964][podrecreation.go: 113] deleting ns=tnf pod=test-1 with deleteForeground mode +DEBUG [Oct 19 17:07:04.299][podrecreation.go: 113] deleting ns=tnf pod=test-d78fbf8d6-wmj2m with deleteForeground mode +DEBUG [Oct 19 17:07:06.065][podrecreation.go: 159] ns=tnf pod=test-d78fbf8d6-wmj2m deleted +DEBUG [Oct 19 17:07:06.233][podrecreation.go: 159] ns=tnf pod=test-1 deleted +INFO [Oct 19 17:07:06.233][podsets.go: 190] Waiting 9m0s for 2 podsets to be ready. +INFO [Oct 19 17:07:06.233][podsets.go: 192] Checking Deployments readiness of Deployments [tnf:test] +INFO [Oct 19 17:07:06.400][podsets.go: 195] Checking StatefulSets readiness of StatefulSets [tnf:test] +INFO [Oct 19 17:07:06.572][podsets.go: 198] Not ready Deployments: [tnf:test] +INFO [Oct 19 17:07:06.572][podsets.go: 199] Not ready StatefulSets: [tnf:test] +INFO [Oct 19 17:07:21.573][podsets.go: 192] Checking Deployments readiness of Deployments [tnf:test] +DEBUG [Oct 19 17:07:21.738][podsets.go: 152] deployment: test ns: tnf is ready. +INFO [Oct 19 17:07:21.738][podsets.go: 195] Checking StatefulSets readiness of StatefulSets [tnf:test] +DEBUG [Oct 19 17:07:21.907][podsets.go: 175] statefulset: test ns: tnf is ready. +INFO [Oct 19 17:07:21.907][podsets.go: 198] Not ready Deployments: [] +INFO [Oct 19 17:07:21.907][podsets.go: 199] Not ready StatefulSets: [] +DEBUG [Oct 19 17:07:21.907][loghelper.go: 40] Not ready Deployments: [] +DEBUG [Oct 19 17:07:21.907][loghelper.go: 40] Not ready StatefulSets: [] +INFO [Oct 19 17:07:21.907][podrecreation.go: 51] Performing uncordon operation on node clus0-0 +INFO [Oct 19 17:07:22.734][podrecreation.go: 51] Performing cordon operation on node clus0-1 +DEBUG [Oct 19 17:07:24.042][suite.go: 570] node: clus0-1 cordoned +DEBUG [Oct 19 17:07:24.054][suite.go: 576] draining node: clus0-1 with timeout: 8m0s +DEBUG [Oct 19 17:07:24.054][podrecreation.go: 113] deleting ns=tnf pod=test-d78fbf8d6-2fk6c with deleteForeground mode +DEBUG [Oct 19 17:07:26.465][podrecreation.go: 159] ns=tnf pod=test-d78fbf8d6-2fk6c deleted +INFO [Oct 19 17:07:26.465][podsets.go: 190] Waiting 8m0s for 2 podsets to be ready. +INFO [Oct 19 17:07:26.465][podsets.go: 192] Checking Deployments readiness of Deployments [tnf:test] +INFO [Oct 19 17:07:26.631][podsets.go: 195] Checking StatefulSets readiness of StatefulSets [tnf:test] +DEBUG [Oct 19 17:07:26.797][podsets.go: 175] statefulset: test ns: tnf is ready. +INFO [Oct 19 17:07:26.797][podsets.go: 198] Not ready Deployments: [tnf:test] +INFO [Oct 19 17:07:26.797][podsets.go: 199] Not ready StatefulSets: [] +INFO [Oct 19 17:07:41.798][podsets.go: 192] Checking Deployments readiness of Deployments [tnf:test] +DEBUG [Oct 19 17:07:41.957][podsets.go: 152] deployment: test ns: tnf is ready. +INFO [Oct 19 17:07:41.957][podsets.go: 195] Checking StatefulSets readiness of StatefulSets [] +INFO [Oct 19 17:07:41.957][podsets.go: 198] Not ready Deployments: [] +INFO [Oct 19 17:07:41.957][podsets.go: 199] Not ready StatefulSets: [] +DEBUG [Oct 19 17:07:41.957][loghelper.go: 40] Not ready Deployments: [] +DEBUG [Oct 19 17:07:41.957][loghelper.go: 40] Not ready StatefulSets: [] +INFO [Oct 19 17:07:41.957][podrecreation.go: 51] Performing uncordon operation on node clus0-1 +INFO [Oct 19 17:07:43.096][podrecreation.go: 51] Performing uncordon operation on node clus0-1 +INFO [Oct 19 17:07:43.579][podrecreation.go: 51] Performing uncordon operation on node clus0-0 +INFO [Oct 19 17:07:44.056][podrecreation.go: 51] Performing uncordon operation on node clus0-2 +DEBUG [Oct 19 17:07:44.692][utils.go: 38] config file already loaded, return previous element +INFO [Oct 19 17:07:45.020][autodiscover.go: 154] parsed pods under test labels: [{LabelKey:test-network-function.com/generic LabelValue:target}] +INFO [Oct 19 17:07:45.020][autodiscover.go: 155] parsed operators under test labels: [{LabelKey:test-network-function.com/operator1 LabelValue:new} {LabelKey:test-network-function.com/operator LabelValue:}] +DEBUG [Oct 19 17:07:45.193][autodiscover_operators.go: 135] Searching subscriptions in namespace All Namespaces +INFO [Oct 19 17:07:45.355][autodiscover_operators.go: 144] Found 2 subscriptions in the target namespaces +INFO [Oct 19 17:07:45.355][autodiscover_operators.go: 146] Subscriptions name: lvms-operator (ns: openshift-storage) +INFO [Oct 19 17:07:45.355][autodiscover_operators.go: 146] Subscriptions name: test-subscription (ns: tnf) +DEBUG [Oct 19 17:07:45.355][autodiscover_operators.go: 112] Searching CSVs in namespace All +INFO [Oct 19 17:07:45.678][autodiscover_operators.go: 121] Found 2 CSVs: +INFO [Oct 19 17:07:45.678][autodiscover_operators.go: 123] CSV name: packageserver (ns: openshift-operator-lifecycle-manager) +INFO [Oct 19 17:07:45.678][autodiscover_operators.go: 123] CSV name: lvms-operator.v4.13.1 (ns: openshift-storage) +DEBUG [Oct 19 17:07:46.004][autodiscover_pods.go: 34] Searching Pods with label test-network-function.com/generic=target +DEBUG [Oct 19 17:07:46.340][autodiscover_pods.go: 34] Searching Pods with label test-network-function.com/app=tnf-debug +INFO [Oct 19 17:07:47.722][autodiscover_scales.go: 40] Target CRD crdexamples.test-network-function.com is not scalable. Skipping search of scalable CRs. +DEBUG [Oct 19 17:07:47.723][autodiscover_operators.go: 69] Searching CSVs in namespace {tnf} +DEBUG [Oct 19 17:07:47.723][autodiscover_operators.go: 76] Searching CSVs with label test-network-function.com/operator1=new +DEBUG [Oct 19 17:07:47.881][autodiscover_operators.go: 76] Searching CSVs with label test-network-function.com/operator +INFO [Oct 19 17:07:48.038][autodiscover_operators.go: 91] Found 0 CSVs: +DEBUG [Oct 19 17:07:48.055][autodiscover_operators.go: 135] Searching subscriptions in namespace tnf +INFO [Oct 19 17:07:48.213][autodiscover_operators.go: 144] Found 1 subscriptions in the target namespaces +INFO [Oct 19 17:07:48.213][autodiscover_operators.go: 146] Subscriptions name: test-subscription (ns: tnf) +INFO [Oct 19 17:07:48.678][autodiscover.go: 276] OpenShift Version found: 4.13.0 +INFO [Oct 19 17:07:48.997][autodiscover_podset.go: 80] Deployment test found in ns tnf +INFO [Oct 19 17:07:49.152][autodiscover_podset.go: 113] StatefulSet test found in ns tnf +INFO [Oct 19 17:07:50.462][operators.go: 130] Found 2 unique CSVs +INFO [Oct 19 17:07:50.463][operators.go: 132] CSV: packageserver +INFO [Oct 19 17:07:50.463][operators.go: 132] CSV: lvms-operator.v4.13.1 +INFO [Oct 19 17:07:50.630][operators.go: 185] Getting installplans for op lvms-operator.v4.13.1 (subs lvms-operator ns openshift-storage) +WARNING[Oct 19 17:07:50.630][operators.go: 183] Subscription not found for CSV: packageserver (ns openshift-operator-lifecycle-manager) +INFO [Oct 19 17:07:50.630][operators.go: 185] Getting installplans for op packageserver (subs ns ) +INFO [Oct 19 17:07:50.630][provider.go: 566] Node clus0-0 - mc name: rendered-master-87e86cb409fb5f914d4c94bee99ef373 +INFO [Oct 19 17:07:50.810][provider.go: 566] Node clus0-1 - mc name: rendered-master-87e86cb409fb5f914d4c94bee99ef373 +INFO [Oct 19 17:07:51.020][provider.go: 566] Node clus0-2 - mc name: rendered-master-87e86cb409fb5f914d4c94bee99ef373 +DEBUG [Oct 19 17:07:51.390][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:07:51.391][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:07:51.391][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:07:51.391][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:07:51.391][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:07:51.391][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:07:51.391][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:07:51.391][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:07:51.391][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:07:51.391][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:07:51.391][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:07:51.391][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +INFO [Oct 19 17:07:51.391][operators.go: 130] Found 0 unique CSVs +INFO [Oct 19 17:07:51.391][provider.go: 299] Operators found: 0 +INFO [Oct 19 17:07:51.391][provider.go: 311] Completed the test environment build process in 6.70 seconds +INFO [Oct 19 17:07:53.160][podsets.go: 44] deployment: test ns: tnf is not ready yet +INFO [Oct 19 17:07:54.315][podsets.go: 44] deployment: test ns: tnf is not ready yet +INFO [Oct 19 17:07:55.476][podsets.go: 44] deployment: test ns: tnf is not ready yet +INFO [Oct 19 17:07:56.632][podsets.go: 44] deployment: test ns: tnf is not ready yet +INFO [Oct 19 17:07:57.841][podsets.go: 44] deployment: test ns: tnf is not ready yet +INFO [Oct 19 17:07:59.000][podsets.go: 44] deployment: test ns: tnf is not ready yet +INFO [Oct 19 17:08:00.160][podsets.go: 44] deployment: test ns: tnf is not ready yet +INFO [Oct 19 17:08:01.317][podsets.go: 44] deployment: test ns: tnf is not ready yet +INFO [Oct 19 17:08:02.473][podsets.go: 44] deployment: test ns: tnf is not ready yet +INFO [Oct 19 17:08:03.631][podsets.go: 44] deployment: test ns: tnf is not ready yet +INFO [Oct 19 17:08:04.789][podsets.go: 44] deployment: test ns: tnf is not ready yet +INFO [Oct 19 17:08:05.945][podsets.go: 44] deployment: test ns: tnf is not ready yet +INFO [Oct 19 17:08:07.100][podsets.go: 44] deployment: test ns: tnf is not ready yet +DEBUG [Oct 19 17:08:08.254][utils.go: 38] config file already loaded, return previous element +INFO [Oct 19 17:08:08.561][autodiscover.go: 154] parsed pods under test labels: [{LabelKey:test-network-function.com/generic LabelValue:target}] +INFO [Oct 19 17:08:08.561][autodiscover.go: 155] parsed operators under test labels: [{LabelKey:test-network-function.com/operator1 LabelValue:new} {LabelKey:test-network-function.com/operator LabelValue:}] +DEBUG [Oct 19 17:08:08.725][autodiscover_operators.go: 135] Searching subscriptions in namespace All Namespaces +INFO [Oct 19 17:08:08.880][autodiscover_operators.go: 144] Found 2 subscriptions in the target namespaces +INFO [Oct 19 17:08:08.880][autodiscover_operators.go: 146] Subscriptions name: lvms-operator (ns: openshift-storage) +INFO [Oct 19 17:08:08.880][autodiscover_operators.go: 146] Subscriptions name: test-subscription (ns: tnf) +DEBUG [Oct 19 17:08:08.881][autodiscover_operators.go: 112] Searching CSVs in namespace All +INFO [Oct 19 17:08:09.199][autodiscover_operators.go: 121] Found 2 CSVs: +INFO [Oct 19 17:08:09.200][autodiscover_operators.go: 123] CSV name: packageserver (ns: openshift-operator-lifecycle-manager) +INFO [Oct 19 17:08:09.200][autodiscover_operators.go: 123] CSV name: lvms-operator.v4.13.1 (ns: openshift-storage) +DEBUG [Oct 19 17:08:09.526][autodiscover_pods.go: 34] Searching Pods with label test-network-function.com/generic=target +DEBUG [Oct 19 17:08:09.880][autodiscover_pods.go: 34] Searching Pods with label test-network-function.com/app=tnf-debug +INFO [Oct 19 17:08:11.375][autodiscover_scales.go: 40] Target CRD crdexamples.test-network-function.com is not scalable. Skipping search of scalable CRs. +DEBUG [Oct 19 17:08:11.375][autodiscover_operators.go: 69] Searching CSVs in namespace {tnf} +DEBUG [Oct 19 17:08:11.375][autodiscover_operators.go: 76] Searching CSVs with label test-network-function.com/operator1=new +DEBUG [Oct 19 17:08:11.531][autodiscover_operators.go: 76] Searching CSVs with label test-network-function.com/operator +INFO [Oct 19 17:08:11.687][autodiscover_operators.go: 91] Found 0 CSVs: +DEBUG [Oct 19 17:08:11.687][autodiscover_operators.go: 135] Searching subscriptions in namespace tnf +INFO [Oct 19 17:08:11.842][autodiscover_operators.go: 144] Found 1 subscriptions in the target namespaces +INFO [Oct 19 17:08:11.842][autodiscover_operators.go: 146] Subscriptions name: test-subscription (ns: tnf) +INFO [Oct 19 17:08:12.314][autodiscover.go: 276] OpenShift Version found: 4.13.0 +INFO [Oct 19 17:08:12.622][autodiscover_podset.go: 80] Deployment test found in ns tnf +INFO [Oct 19 17:08:12.776][autodiscover_podset.go: 113] StatefulSet test found in ns tnf +INFO [Oct 19 17:08:14.078][operators.go: 130] Found 2 unique CSVs +INFO [Oct 19 17:08:14.079][operators.go: 132] CSV: packageserver +INFO [Oct 19 17:08:14.079][operators.go: 132] CSV: lvms-operator.v4.13.1 +INFO [Oct 19 17:08:14.236][operators.go: 185] Getting installplans for op lvms-operator.v4.13.1 (subs lvms-operator ns openshift-storage) +WARNING[Oct 19 17:08:14.236][operators.go: 183] Subscription not found for CSV: packageserver (ns openshift-operator-lifecycle-manager) +INFO [Oct 19 17:08:14.236][operators.go: 185] Getting installplans for op packageserver (subs ns ) +INFO [Oct 19 17:08:14.236][provider.go: 566] Node clus0-0 - mc name: rendered-master-87e86cb409fb5f914d4c94bee99ef373 +INFO [Oct 19 17:08:14.408][provider.go: 566] Node clus0-1 - mc name: rendered-master-87e86cb409fb5f914d4c94bee99ef373 +INFO [Oct 19 17:08:14.580][provider.go: 566] Node clus0-2 - mc name: rendered-master-87e86cb409fb5f914d4c94bee99ef373 +DEBUG [Oct 19 17:08:14.783][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:14.783][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:14.783][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:14.783][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:14.783][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:14.783][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:14.783][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:14.783][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:14.783][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:14.784][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:14.784][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:14.784][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +INFO [Oct 19 17:08:14.784][operators.go: 130] Found 0 unique CSVs +INFO [Oct 19 17:08:14.784][provider.go: 299] Operators found: 0 +INFO [Oct 19 17:08:14.784][provider.go: 311] Completed the test environment build process in 6.53 seconds +DEBUG [Oct 19 17:08:16.369][utils.go: 38] config file already loaded, return previous element +INFO [Oct 19 17:08:16.678][autodiscover.go: 154] parsed pods under test labels: [{LabelKey:test-network-function.com/generic LabelValue:target}] +INFO [Oct 19 17:08:16.678][autodiscover.go: 155] parsed operators under test labels: [{LabelKey:test-network-function.com/operator1 LabelValue:new} {LabelKey:test-network-function.com/operator LabelValue:}] +DEBUG [Oct 19 17:08:16.844][autodiscover_operators.go: 135] Searching subscriptions in namespace All Namespaces +INFO [Oct 19 17:08:17.001][autodiscover_operators.go: 144] Found 2 subscriptions in the target namespaces +INFO [Oct 19 17:08:17.001][autodiscover_operators.go: 146] Subscriptions name: lvms-operator (ns: openshift-storage) +INFO [Oct 19 17:08:17.001][autodiscover_operators.go: 146] Subscriptions name: test-subscription (ns: tnf) +DEBUG [Oct 19 17:08:17.001][autodiscover_operators.go: 112] Searching CSVs in namespace All +INFO [Oct 19 17:08:17.169][autodiscover_operators.go: 121] Found 2 CSVs: +INFO [Oct 19 17:08:17.169][autodiscover_operators.go: 123] CSV name: packageserver (ns: openshift-operator-lifecycle-manager) +INFO [Oct 19 17:08:17.169][autodiscover_operators.go: 123] CSV name: lvms-operator.v4.13.1 (ns: openshift-storage) +DEBUG [Oct 19 17:08:17.485][autodiscover_pods.go: 34] Searching Pods with label test-network-function.com/generic=target +DEBUG [Oct 19 17:08:17.810][autodiscover_pods.go: 34] Searching Pods with label test-network-function.com/app=tnf-debug +INFO [Oct 19 17:08:19.152][autodiscover_scales.go: 40] Target CRD crdexamples.test-network-function.com is not scalable. Skipping search of scalable CRs. +DEBUG [Oct 19 17:08:19.152][autodiscover_operators.go: 69] Searching CSVs in namespace {tnf} +DEBUG [Oct 19 17:08:19.152][autodiscover_operators.go: 76] Searching CSVs with label test-network-function.com/operator1=new +DEBUG [Oct 19 17:08:19.305][autodiscover_operators.go: 76] Searching CSVs with label test-network-function.com/operator +INFO [Oct 19 17:08:19.458][autodiscover_operators.go: 91] Found 0 CSVs: +DEBUG [Oct 19 17:08:19.458][autodiscover_operators.go: 135] Searching subscriptions in namespace tnf +INFO [Oct 19 17:08:19.614][autodiscover_operators.go: 144] Found 1 subscriptions in the target namespaces +INFO [Oct 19 17:08:19.614][autodiscover_operators.go: 146] Subscriptions name: test-subscription (ns: tnf) +INFO [Oct 19 17:08:20.082][autodiscover.go: 276] OpenShift Version found: 4.13.0 +INFO [Oct 19 17:08:20.391][autodiscover_podset.go: 80] Deployment test found in ns tnf +INFO [Oct 19 17:08:20.547][autodiscover_podset.go: 113] StatefulSet test found in ns tnf +INFO [Oct 19 17:08:21.850][operators.go: 130] Found 2 unique CSVs +INFO [Oct 19 17:08:21.850][operators.go: 132] CSV: packageserver +INFO [Oct 19 17:08:21.850][operators.go: 132] CSV: lvms-operator.v4.13.1 +INFO [Oct 19 17:08:22.004][operators.go: 185] Getting installplans for op lvms-operator.v4.13.1 (subs lvms-operator ns openshift-storage) +WARNING[Oct 19 17:08:22.004][operators.go: 183] Subscription not found for CSV: packageserver (ns openshift-operator-lifecycle-manager) +INFO [Oct 19 17:08:22.004][operators.go: 185] Getting installplans for op packageserver (subs ns ) +INFO [Oct 19 17:08:22.004][provider.go: 566] Node clus0-0 - mc name: rendered-master-87e86cb409fb5f914d4c94bee99ef373 +INFO [Oct 19 17:08:22.179][provider.go: 566] Node clus0-1 - mc name: rendered-master-87e86cb409fb5f914d4c94bee99ef373 +INFO [Oct 19 17:08:22.351][provider.go: 566] Node clus0-2 - mc name: rendered-master-87e86cb409fb5f914d4c94bee99ef373 +DEBUG [Oct 19 17:08:22.530][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:22.530][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:22.530][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:22.530][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:22.530][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:22.530][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:22.530][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:22.530][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:22.530][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:22.530][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:22.531][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +DEBUG [Oct 19 17:08:22.531][provider.go: 424] parsed image, repo: quay.io, name:testnetworkfunction/cnf-test-partner, tag: latest, digest: sha256:cca46b755479e1ca7390c9b824ca50057e14375405c2294efb7907d7a0a20c6d +INFO [Oct 19 17:08:22.531][operators.go: 130] Found 0 unique CSVs +INFO [Oct 19 17:08:22.531][provider.go: 299] Operators found: 0 +INFO [Oct 19 17:08:22.531][provider.go: 311] Completed the test environment build process in 6.16 seconds +DEBUG [Oct 19 17:08:22.531][isolation.go: 71] container: test pod: test-0 ns: tnf has CPU requests 250 (milli) that has to be a whole unit. +DEBUG [Oct 19 17:08:22.531][isolation.go: 71] container: test pod: test-1 ns: tnf has CPU requests 250 (milli) that has to be a whole unit. +DEBUG [Oct 19 17:08:22.531][isolation.go: 71] container: test pod: test-d78fbf8d6-rtxbr ns: tnf has CPU requests 250 (milli) that has to be a whole unit. +DEBUG [Oct 19 17:08:22.531][isolation.go: 71] container: test pod: test-d78fbf8d6-vvlwx ns: tnf has CPU requests 250 (milli) that has to be a whole unit. +INFO [Oct 19 17:08:22.636][archiver.go: 45] Compressing results artifacts into /Users/amal/Documents/GitHub/cnf-certification-test/cnf-certification-test/20231019-170822-cnf-test-results.tar.gz +DEBUG [Oct 19 17:08:22.637][archiver.go: 59] Zipping file /Users/amal/Documents/GitHub/cnf-certification-test/cnf-certification-test/claim.json +DEBUG [Oct 19 17:08:22.666][archiver.go: 59] Zipping file /Users/amal/Documents/GitHub/cnf-certification-test/cnf-certification-test/cnf-certification-tests_junit.xml +DEBUG [Oct 19 17:08:22.667][archiver.go: 59] Zipping file /Users/amal/Documents/GitHub/cnf-certification-test/cnf-certification-test/claimjson.js +DEBUG [Oct 19 17:08:22.700][archiver.go: 59] Zipping file /Users/amal/Documents/GitHub/cnf-certification-test/cnf-certification-test/results.html diff --git a/cnf-certification-test/suite_test.go b/cnf-certification-test/suite_test.go index 22a900793..782e94368 100644 --- a/cnf-certification-test/suite_test.go +++ b/cnf-certification-test/suite_test.go @@ -17,14 +17,20 @@ package suite import ( + "bufio" _ "embed" + "encoding/json" "flag" + "fmt" + "net/http" "os" "path/filepath" "testing" "time" + "github.com/gorilla/websocket" "github.com/onsi/ginkgo/v2" + "github.com/sirupsen/logrus" log "github.com/sirupsen/logrus" "github.com/test-network-function/cnf-certification-test/cnf-certification-test/results" "github.com/test-network-function/cnf-certification-test/pkg/claimhelper" @@ -56,8 +62,10 @@ const ( defaultClaimPath = ".." defaultCliArgValue = "" junitFlagKey = "junit" + serverRun = "runserver" TNFReportKey = "cnf-certification-test" extraInfoKey = "testsExtraInfo" + defaultServerRun = false ) var ( @@ -77,13 +85,28 @@ var ( // ClaimFormat is the current version for the claim file format to be produced by the TNF test suite. // A client decoding this claim file must support decoding its specific version. ClaimFormatVersion string + serveRun *bool ) +//go:embed amalpro/index.html +var indexHTML []byte + +//go:embed amalpro/submit.js +var submit []byte + +//go:embed amalpro/logs.js +var logs []byte + +//go:embed amalpro/toast.js +var toast []byte + func init() { claimPath = flag.String(claimPathFlagKey, defaultClaimPath, "the path where the claimfile will be output") junitPath = flag.String(junitFlagKey, defaultCliArgValue, "the path for the junit format report") + serveRun = flag.Bool(serverRun, defaultServerRun, + "the path for the junit format report") } // setLogLevel sets the log level for logrus based on the "TNF_LOG_LEVEL" environment variable @@ -102,6 +125,7 @@ func setLogLevel() { func getK8sClientsConfigFileNames() []string { params := configuration.GetTestParameters() + logrus.Info(params) fileNames := []string{} if params.Kubeconfig != "" { fileNames = append(fileNames, params.Kubeconfig) @@ -126,6 +150,59 @@ func getGitVersion() string { return gitDisplayRelease + " ( " + GitCommit + " )" } +func startServer() { + log.Info("inside starting the server") + + http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) { + // Set the content type to "text/html". + w.Header().Set("Content-Type", "text/html") + // Write the embedded HTML content to the response. + _, err := w.Write(indexHTML) + if err != nil { + http.Error(w, "Failed to write response", http.StatusInternalServerError) + } + }) + + http.HandleFunc("/submit.js", func(w http.ResponseWriter, r *http.Request) { + // Set the content type to "application/javascript". + w.Header().Set("Content-Type", "application/javascript") + // Write the embedded JavaScript content to the response. + _, err := w.Write(submit) + if err != nil { + http.Error(w, "Failed to write response", http.StatusInternalServerError) + } + }) + + http.HandleFunc("/logs.js", func(w http.ResponseWriter, r *http.Request) { + // Set the content type to "application/javascript". + w.Header().Set("Content-Type", "application/javascript") + // Write the embedded JavaScript content to the response. + _, err := w.Write(logs) + if err != nil { + http.Error(w, "Failed to write response", http.StatusInternalServerError) + } + }) + + http.HandleFunc("/toast.js", func(w http.ResponseWriter, r *http.Request) { + // Set the content type to "application/javascript". + w.Header().Set("Content-Type", "application/javascript") + // Write the embedded JavaScript content to the response. + _, err := w.Write(toast) + if err != nil { + http.Error(w, "Failed to write response", http.StatusInternalServerError) + } + }) + + http.HandleFunc("/runFunction", runHandler) + // Serve the static HTML file + http.HandleFunc("/logstream", logStreamHandler) + + fmt.Println("Server is running on :8080...") + if err := http.ListenAndServe(":8080", nil); err != nil { + panic(err) + } +} + // TestTest invokes the CNF Certification Test Suite. func TestTest(t *testing.T) { // When running unit tests, skip the suite @@ -147,43 +224,55 @@ func TestTest(t *testing.T) { log.Infof("Claim Format Version: %s", ClaimFormatVersion) log.Infof("Ginkgo Version : %v", ginkgo.GINKGO_VERSION) log.Infof("Labels filter : %v", ginkgoConfig.LabelFilter) + log.Infof("*serveRun : %v", *serveRun) + log.Info("starting the server") + + go startServer() + // Keep the main program running // Diagnostic functions will run when no labels are provided. - var diagnosticMode bool - if ginkgoConfig.LabelFilter == "" { - log.Infof("TNF will run in diagnostic mode so no test case will be launched.") - diagnosticMode = true - } + if !*serveRun { + var diagnosticMode bool + if ginkgoConfig.LabelFilter == "" { + log.Infof("TNF will run in diagnostic mode so no test case will be launched.") + diagnosticMode = true + } - // Set clientsholder singleton with the filenames from the env vars. - _ = clientsholder.GetClientsHolder(getK8sClientsConfigFileNames()...) + // Set clientsholder singleton with the filenames from the env vars. + _ = clientsholder.GetClientsHolder(getK8sClientsConfigFileNames()...) - // Initialize the claim with the start time, tnf version, etc. - claimRoot := claimhelper.CreateClaimRoot() - claimData := claimRoot.Claim - claimData.Configurations = make(map[string]interface{}) - claimData.Nodes = make(map[string]interface{}) - incorporateVersions(claimData) + // Initialize the claim with the start time, tnf version, etc. + claimRoot := claimhelper.CreateClaimRoot() + claimData := claimRoot.Claim + claimData.Configurations = make(map[string]interface{}) + claimData.Nodes = make(map[string]interface{}) + incorporateVersions(claimData) - configurations, err := claimhelper.MarshalConfigurations() - if err != nil { - log.Errorf("Configuration node missing because of: %s", err) - t.FailNow() - } + configurations, err := claimhelper.MarshalConfigurations() + if err != nil { + log.Errorf("Configuration node missing because of: %s", err) + t.FailNow() + } - claimData.Nodes = claimhelper.GenerateNodes() - claimhelper.UnmarshalConfigurations(configurations, claimData.Configurations) + claimData.Nodes = claimhelper.GenerateNodes() + claimhelper.UnmarshalConfigurations(configurations, claimData.Configurations) - // initialize abort flag - testhelper.AbortTrigger = "" + // initialize abort flag + testhelper.AbortTrigger = "" - // Run tests specs only if not in diagnostic mode, otherwise all TSs would run. - var env provider.TestEnvironment - if !diagnosticMode { - env.SetNeedsRefresh() - env = provider.GetTestEnvironment() - ginkgo.RunSpecs(t, CnfCertificationTestSuiteName) + // Run tests specs only if not in diagnostic mode, otherwise all TSs would run. + var env provider.TestEnvironment + if !diagnosticMode { + env.SetNeedsRefresh() + env = provider.GetTestEnvironment() + ginkgo.RunSpecs(t, CnfCertificationTestSuiteName) + } + continueRun(t, diagnosticMode, env, claimData, claimRoot) } + select {} +} + +func continueRun(t *testing.T, diagnosticMode bool, env provider.TestEnvironment, claimData *claim.Claim, claimRoot *claim.Root) { endTime := time.Now() claimData.Metadata.EndTime = endTime.UTC().Format(claimhelper.DateTimeFormatDirective) @@ -211,7 +300,7 @@ func TestTest(t *testing.T) { // Send claim file to the collector if specified by env var if configuration.GetTestParameters().EnableDataCollection { - err = collector.SendClaimFileToCollector(env.CollectorAppEndPoint, claimOutputFile, env.ExecutedBy, env.PartnerName, env.CollectorAppPassword) + err := collector.SendClaimFileToCollector(env.CollectorAppEndPoint, claimOutputFile, env.ExecutedBy, env.PartnerName, env.CollectorAppPassword) if err != nil { log.Errorf("Failed to send post request to the collector: %v", err) } @@ -264,3 +353,209 @@ func incorporateVersions(claimData *claim.Claim) { ClaimFormat: ClaimFormatVersion, } } + +var upgrader = websocket.Upgrader{ + CheckOrigin: func(r *http.Request) bool { + return true + }, +} + +// Define an HTTP handler that triggers Ginkgo tests +func runHandler(w http.ResponseWriter, r *http.Request) { + // Run Ginkgo tests + var requestData RequestData + //var responseData ResponseData + // Parse JSON data from the request body + err := json.NewDecoder(r.Body).Decode(&requestData) + if err != nil { + http.Error(w, err.Error(), http.StatusBadRequest) + return + } + // Create or open a log file + filename := "log.log" + if _, err := os.Stat(filename); err == nil { + // If it exists, truncate it to remove the contents + file, err := os.OpenFile(filename, os.O_TRUNC, 0) + if err != nil { + // Handle the error if necessary + panic(err) + } + file.Close() + } + logFile, err := os.OpenFile(filename, os.O_WRONLY|os.O_CREATE|os.O_APPEND, 0644) + if err != nil { + panic(err) + } + logrus.SetOutput(logFile) + originalStdout := os.Stdout + os.Stdout = logFile + // Read the YAML file + defer func() { + os.Stdout = originalStdout + logFile.Close() + }() + os.Setenv("KUBECONFIG", requestData.KubeConfigPath) + logrus.Infof("KUBECONFIG : %v", requestData.KubeConfigPath) + + logrus.Infof("Labels filter : %v", requestData.SelectedOptions) + + // Set the output of the logger to the log file + + /*data, err := os.ReadFile("tnf_config.yml") + if err != nil { + log.Fatalf("Error reading YAML file: %v", err) + } + + // Unmarshal the YAML data into a Config struct + var config configuration.TestConfiguration + + err = yaml.Unmarshal(data, &config) + if err != nil { + log.Fatalf("Error unmarshaling YAML: %v", err) + } + + // Modify the configuration + var namespace []configuration.Namespace + namespace = append(namespace, configuration.Namespace{Name: requestData.Field3}) + + config.TargetNameSpaces = namespace // Change the port to a new value + + // Serialize the modified config back to YAML format + newData, err := yaml.Marshal(&config) + if err != nil { + log.Fatalf("Error marshaling YAML: %v", err) + } + + // Write the modified YAML data back to the file + err = os.WriteFile("tnf_config.yml", newData, os.ModePerm) + if err != nil { + log.Fatalf("Error writing YAML file: %v", err) + } + */ + t := testing.T{} + logrus.Infof(os.Getenv("KUBECONFIG")) + // When running unit tests, skip the suite + if os.Getenv("UNIT_TEST") != "" { + t.Skip("Skipping test suite when running unit tests") + } + + err = configuration.LoadEnvironmentVariables() + if err != nil { + log.Fatalf("could not load the environment variables, error: %v", err) + } + + // Set up logging params for logrus + loghelper.SetLogFormat() + setLogLevel() + + ginkgoConfig, _ := ginkgo.GinkgoConfiguration() + log.Infof("Ginkgo Version : %v", ginkgo.GINKGO_VERSION) + log.Infof("Labels filter : %v", ginkgoConfig.LabelFilter) + // Set clientsholder singleton with the filenames from the env vars. + _ = clientsholder.GetClientsHolder(getK8sClientsConfigFileNames()...) + + // Initialize the claim with the start time, tnf version, etc. + claimRoot := claimhelper.CreateClaimRoot() + claimData := claimRoot.Claim + claimData.Configurations = make(map[string]interface{}) + claimData.Nodes = make(map[string]interface{}) + incorporateVersions(claimData) + + configurations, err := claimhelper.MarshalConfigurations() + if err != nil { + log.Errorf("Configuration node missing because of: %s", err) + t.FailNow() + } + claimData.Nodes = claimhelper.GenerateNodes() + claimhelper.UnmarshalConfigurations(configurations, claimData.Configurations) + + // initialize abort flag + testhelper.AbortTrigger = "" + + fmt.Println("This will be written to the log file.") + var env provider.TestEnvironment + env.SetNeedsRefresh() + env = provider.GetTestEnvironment() + // fetch the current config + suiteConfig, reporterConfig := ginkgo.GinkgoConfiguration() + // adjust it + suiteConfig.SkipStrings = []string{"NEVER-RUN"} + reporterConfig.FullTrace = true + reporterConfig.JUnitReport = "cnf-certification-tests_junit.xml" + // pass it in to RunSpecs + suiteConfig.LabelFilter = requestData.SelectedOptions + ginkgo.RunSpecs(&t, CnfCertificationTestSuiteName, suiteConfig, reporterConfig) + + continueRun(&t, false, env, claimData, claimRoot) + // Return the result as JSON + response := struct { + Message string `json:"Message"` + }{ + Message: fmt.Sprintf("Sucsses to run %s", requestData.SelectedOptions), + } + // Serialize the response data to JSON + jsonResponse, err := json.Marshal(response) + if err != nil { + http.Error(w, err.Error(), http.StatusInternalServerError) + return + } + // Set the Content-Type header to specify that the response is JSON + w.Header().Set("Content-Type", "application/json") + + // Write the JSON response to the client + _, err = w.Write(jsonResponse) + if err != nil { + http.Error(w, err.Error(), http.StatusInternalServerError) + return + } + +} + +func logStreamHandler(w http.ResponseWriter, r *http.Request) { + conn, err := upgrader.Upgrade(w, r, nil) + if err != nil { + log.Printf("WebSocket upgrade error: %v", err) + return + } + defer conn.Close() + + filePath := "log.log" + + // Open the log file + file, err := os.Open(filePath) + if err != nil { + log.Println(err) + return + } + defer file.Close() + + // Create a scanner to read the log file line by line + for { + scanner := bufio.NewScanner(file) + for scanner.Scan() { + line := scanner.Text() + "\n" + // Send each log line to the client + if err := conn.WriteMessage(websocket.TextMessage, []byte(line)); err != nil { + fmt.Println(err) + //return + } + + // Sleep for a short duration to simulate real-time updates + time.Sleep(100 * time.Millisecond) + } + if err := scanner.Err(); err != nil { + log.Printf("Error reading log file: %v", err) + } + + time.Sleep(1 * time.Second) + } + +} + +type RequestData struct { + KubeConfigPath string `json:"kubeConfigPath"` + SelectedOptions string `json:"selectedOptions"` +} +type ResponseData struct { + Message string `json:"message"` +}