diff --git a/bundle/manifests/compliance.openshift.io_compliancescans.yaml b/bundle/manifests/compliance.openshift.io_compliancescans.yaml index d512ae913..e19777afa 100644 --- a/bundle/manifests/compliance.openshift.io_compliancescans.yaml +++ b/bundle/manifests/compliance.openshift.io_compliancescans.yaml @@ -95,6 +95,12 @@ spec: rawResultStorage: description: Specifies settings that pertain to raw result storage. properties: + disabled: + default: false + description: Specifies if the raw result storage is disabled. + This is useful in case the raw results are not needed. Defaults + to false. + type: boolean nodeSelector: additionalProperties: type: string diff --git a/bundle/manifests/compliance.openshift.io_compliancesuites.yaml b/bundle/manifests/compliance.openshift.io_compliancesuites.yaml index bd2eaaec3..ab989eab4 100644 --- a/bundle/manifests/compliance.openshift.io_compliancesuites.yaml +++ b/bundle/manifests/compliance.openshift.io_compliancesuites.yaml @@ -116,6 +116,12 @@ spec: rawResultStorage: description: Specifies settings that pertain to raw result storage. properties: + disabled: + default: false + description: Specifies if the raw result storage is disabled. + This is useful in case the raw results are not needed. + Defaults to false. + type: boolean nodeSelector: additionalProperties: type: string diff --git a/bundle/manifests/compliance.openshift.io_scansettings.yaml b/bundle/manifests/compliance.openshift.io_scansettings.yaml index 1855401c2..fe01aac51 100644 --- a/bundle/manifests/compliance.openshift.io_scansettings.yaml +++ b/bundle/manifests/compliance.openshift.io_scansettings.yaml @@ -69,6 +69,11 @@ spec: rawResultStorage: description: Specifies settings that pertain to raw result storage. properties: + disabled: + default: false + description: Specifies if the raw result storage is disabled. This + is useful in case the raw results are not needed. Defaults to false. + type: boolean nodeSelector: additionalProperties: type: string diff --git a/cmd/manager/common.go b/cmd/manager/common.go index 206745f0c..88ec0da6e 100644 --- a/cmd/manager/common.go +++ b/cmd/manager/common.go @@ -2,11 +2,12 @@ package manager import ( "fmt" - metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" - "k8s.io/client-go/discovery" "os" "path/filepath" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + "k8s.io/client-go/discovery" + ocpcfgv1 "github.com/openshift/api/config/v1" mcfgv1 "github.com/openshift/machine-config-operator/pkg/apis/machineconfiguration.openshift.io/v1" "github.com/spf13/cobra" diff --git a/cmd/manager/resultcollector.go b/cmd/manager/resultcollector.go index 54b69b081..986eb1963 100644 --- a/cmd/manager/resultcollector.go +++ b/cmd/manager/resultcollector.go @@ -64,20 +64,21 @@ func init() { } type scapresultsConfig struct { - ArfFile string - XccdfFile string - ExitCodeFile string - CmdOutputFile string - WarningsOutputFile string - ScanName string - ConfigMapName string - NodeName string - Namespace string - ResultServerURI string - Timeout int64 - Cert string - Key string - CA string + ArfFile string + XccdfFile string + ExitCodeFile string + CmdOutputFile string + WarningsOutputFile string + ScanName string + ConfigMapName string + NodeName string + Namespace string + ResultServerURI string + Timeout int64 + Cert string + Key string + CA string + DisableRawResultUpload bool } func defineResultcollectorFlags(cmd *cobra.Command) { @@ -95,7 +96,7 @@ func defineResultcollectorFlags(cmd *cobra.Command) { cmd.Flags().String("tls-client-cert", "", "The path to the client and CA PEM cert bundle.") cmd.Flags().String("tls-client-key", "", "The path to the client PEM key.") cmd.Flags().String("tls-ca", "", "The path to the CA certificate.") - + cmd.Flags().Bool("disable-raw-upload", false, "Setting to true to disable upload raw arf result") flags := cmd.Flags() // Add flags registered by imported packages (e.g. glog and @@ -117,6 +118,7 @@ func parseConfig(cmd *cobra.Command) *scapresultsConfig { conf.CA = getValidStringArg(cmd, "tls-ca") conf.Timeout, _ = cmd.Flags().GetInt64("timeout") conf.ResultServerURI, _ = cmd.Flags().GetString("resultserveruri") + conf.DisableRawResultUpload, _ = cmd.Flags().GetBool("disable-raw-upload") // Set default if needed if conf.ResultServerURI == "" { conf.ResultServerURI = "http://" + conf.ScanName + "-rs:8080/" @@ -370,31 +372,36 @@ func uploadErrorConfigMap(errorMsg *resultFileContents, exitcode string, } func handleCompleteSCAPResults(exitcode string, scapresultsconf *scapresultsConfig, client *complianceCrClient) { - arfContents, err := readResultsFile(scapresultsconf.ArfFile, scapresultsconf.Timeout) - if err != nil { - cmdLog.Error(err, "Failed to read ARF file") - os.Exit(1) - } - defer arfContents.close() - xccdfContents, err := readResultsFile(scapresultsconf.XccdfFile, scapresultsconf.Timeout) if err != nil { cmdLog.Error(err, "Failed to read XCCDF file") os.Exit(1) } defer xccdfContents.close() - var wg sync.WaitGroup - wg.Add(2) - go func() { - serverUploadErr := uploadToResultServer(arfContents, scapresultsconf) - if serverUploadErr != nil { - cmdLog.Error(serverUploadErr, "Failed to upload results to server") + numWG := 1 + if !scapresultsconf.DisableRawResultUpload { + numWG++ + } + wg.Add(numWG) + + if !scapresultsconf.DisableRawResultUpload { + arfContents, err := readResultsFile(scapresultsconf.ArfFile, scapresultsconf.Timeout) + if err != nil { + cmdLog.Error(err, "Failed to read ARF file") os.Exit(1) } - cmdLog.Info("Uploaded to resultserver") - wg.Done() - }() + defer arfContents.close() + go func() { + serverUploadErr := uploadToResultServer(arfContents, scapresultsconf) + if serverUploadErr != nil { + cmdLog.Error(serverUploadErr, "Failed to upload results to server") + os.Exit(1) + } + cmdLog.Info("Uploaded to resultserver") + wg.Done() + }() + } go func() { cmUploadErr := uploadResultConfigMap(xccdfContents, exitcode, scapresultsconf, client) diff --git a/config/crd/bases/compliance.openshift.io_compliancescans.yaml b/config/crd/bases/compliance.openshift.io_compliancescans.yaml index 58dd9ca32..6df39db8e 100644 --- a/config/crd/bases/compliance.openshift.io_compliancescans.yaml +++ b/config/crd/bases/compliance.openshift.io_compliancescans.yaml @@ -95,6 +95,12 @@ spec: rawResultStorage: description: Specifies settings that pertain to raw result storage. properties: + disabled: + default: false + description: Specifies if the raw result storage is disabled. + This is useful in case the raw results are not needed. Defaults + to false. + type: boolean nodeSelector: additionalProperties: type: string diff --git a/config/crd/bases/compliance.openshift.io_compliancesuites.yaml b/config/crd/bases/compliance.openshift.io_compliancesuites.yaml index aa8f09567..859650ae1 100644 --- a/config/crd/bases/compliance.openshift.io_compliancesuites.yaml +++ b/config/crd/bases/compliance.openshift.io_compliancesuites.yaml @@ -116,6 +116,12 @@ spec: rawResultStorage: description: Specifies settings that pertain to raw result storage. properties: + disabled: + default: false + description: Specifies if the raw result storage is disabled. + This is useful in case the raw results are not needed. + Defaults to false. + type: boolean nodeSelector: additionalProperties: type: string diff --git a/config/crd/bases/compliance.openshift.io_scansettings.yaml b/config/crd/bases/compliance.openshift.io_scansettings.yaml index b997c7a67..ab0ec771e 100644 --- a/config/crd/bases/compliance.openshift.io_scansettings.yaml +++ b/config/crd/bases/compliance.openshift.io_scansettings.yaml @@ -69,6 +69,11 @@ spec: rawResultStorage: description: Specifies settings that pertain to raw result storage. properties: + disabled: + default: false + description: Specifies if the raw result storage is disabled. This + is useful in case the raw results are not needed. Defaults to false. + type: boolean nodeSelector: additionalProperties: type: string diff --git a/pkg/apis/compliance/v1alpha1/complianceremediation_types_test.go b/pkg/apis/compliance/v1alpha1/complianceremediation_types_test.go index c0320ab7c..c9fbd5b70 100644 --- a/pkg/apis/compliance/v1alpha1/complianceremediation_types_test.go +++ b/pkg/apis/compliance/v1alpha1/complianceremediation_types_test.go @@ -1,13 +1,14 @@ package v1alpha1 import ( + "reflect" + . "github.com/onsi/ginkgo" . "github.com/onsi/gomega" corev1 "k8s.io/api/core/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/apis/meta/v1/unstructured" "k8s.io/apimachinery/pkg/runtime" - "reflect" ) var _ = Describe("Testing ComplianceRemediation API", func() { diff --git a/pkg/apis/compliance/v1alpha1/compliancescan_types.go b/pkg/apis/compliance/v1alpha1/compliancescan_types.go index 219345372..1ca7c4e54 100644 --- a/pkg/apis/compliance/v1alpha1/compliancescan_types.go +++ b/pkg/apis/compliance/v1alpha1/compliancescan_types.go @@ -132,6 +132,11 @@ type ComplianceScanType string // When changing the defaults, remember to change also the DefaultRawStorageSize and // DefaultStorageRotation constants type RawResultStorageSettings struct { + // Specifies if the raw result storage is disabled. This is useful in case + // the raw results are not needed. Defaults to false. + // +kubebuilder:validation:Default=false + // +kubebuilder:default=false + Disabled bool `json:"disabled,omitempty"` // Specifies the amount of storage to ask for storing the raw results. Note that // if re-scans happen, the new results will also need to be stored. Defaults to 1Gi. // +kubebuilder:validation:Default=1Gi diff --git a/pkg/controller/compliancescan/compliancescan_controller.go b/pkg/controller/compliancescan/compliancescan_controller.go index 4195fd41b..7627eca22 100644 --- a/pkg/controller/compliancescan/compliancescan_controller.go +++ b/pkg/controller/compliancescan/compliancescan_controller.go @@ -335,26 +335,29 @@ func (r *ReconcileComplianceScan) phaseLaunchingHandler(h scanTypeHandler, logge return reconcile.Result{}, err } - if err = r.handleResultServerSecret(scan, logger); err != nil { - logger.Error(err, "Cannot create result server cert secret") - return reconcile.Result{}, err - } + if !scan.Spec.RawResultStorage.Disabled { + if err = r.handleResultServerSecret(scan, logger); err != nil { + logger.Error(err, "Cannot create result server cert secret") + return reconcile.Result{}, err + } - if err = r.handleResultClientSecret(scan, logger); err != nil { - logger.Error(err, "Cannot create result Client cert secret") - return reconcile.Result{}, err - } + if err = r.handleResultClientSecret(scan, logger); err != nil { + logger.Error(err, "Cannot create result Client cert secret") + return reconcile.Result{}, err + } - if resume, err := r.handleRawResultsForScan(scan, logger); err != nil || !resume { - if err != nil { - logger.Error(err, "Cannot create the PersistentVolumeClaims") + if resume, err := r.handleRawResultsForScan(scan, logger); err != nil || !resume { + if err != nil { + logger.Error(err, "Cannot create the PersistentVolumeClaims") + } + return reconcile.Result{}, err + } + + if err = r.createResultServer(scan, logger); err != nil { + logger.Error(err, "Cannot create result server") + return reconcile.Result{}, err } - return reconcile.Result{}, err - } - if err = r.createResultServer(scan, logger); err != nil { - logger.Error(err, "Cannot create result server") - return reconcile.Result{}, err } if err = r.handleRuntimeKubeletConfig(scan, logger); err != nil { @@ -745,11 +748,12 @@ func (r *ReconcileComplianceScan) phaseDoneHandler(h scanTypeHandler, instance * } } else { // If we're done with the scan but we're not cleaning up just yet. - - // scale down resultserver so it's not still listening for requests. - if err := r.scaleDownResultServer(instance, logger); err != nil { - logger.Error(err, "Cannot scale down result server") - return reconcile.Result{}, err + if !instance.Spec.RawResultStorage.Disabled { + // scale down resultserver so it's not still listening for requests. + if err := r.scaleDownResultServer(instance, logger); err != nil { + logger.Error(err, "Cannot scale down result server") + return reconcile.Result{}, err + } } } diff --git a/pkg/controller/compliancescan/resultserver.go b/pkg/controller/compliancescan/resultserver.go index e7b18aa1d..388504608 100644 --- a/pkg/controller/compliancescan/resultserver.go +++ b/pkg/controller/compliancescan/resultserver.go @@ -282,3 +282,161 @@ func getResultServerName(instance *compv1alpha1.ComplianceScan) string { func getResultServerURI(instance *compv1alpha1.ComplianceScan) string { return "https://" + getResultServerName(instance) + fmt.Sprintf(":%d/", ResultServerPort) } + +func getDisableRawResultUploadValue(instance *compv1alpha1.ComplianceScan) string { + if instance.Spec.RawResultStorage.Disabled { + return "true" + } else { + return "false" + } +} + +func getLogCollectorVolumeMounts(instance *compv1alpha1.ComplianceScan) []corev1.VolumeMount { + if instance.Spec.RawResultStorage.Disabled { + return []corev1.VolumeMount{ + { + Name: "report-dir", + MountPath: "/reports", + ReadOnly: true, + }, + } + } else { + return []corev1.VolumeMount{ + { + Name: "report-dir", + MountPath: "/reports", + }, + { + Name: "tls", + MountPath: "/etc/pki/tls", + ReadOnly: true, + }, + } + } + +} + +func getPlatformScannerPodVolumes(instance *compv1alpha1.ComplianceScan) []corev1.Volume { + mode := int32(0755) + volumeList := []corev1.Volume{ + { + Name: "report-dir", + VolumeSource: corev1.VolumeSource{ + EmptyDir: &corev1.EmptyDirVolumeSource{}, + }, + }, + { + Name: "content-dir", + VolumeSource: corev1.VolumeSource{ + EmptyDir: &corev1.EmptyDirVolumeSource{}, + }, + }, + { + Name: "tmp-dir", + VolumeSource: corev1.VolumeSource{ + EmptyDir: &corev1.EmptyDirVolumeSource{}, + }, + }, + { + Name: "fetch-results", + VolumeSource: corev1.VolumeSource{ + EmptyDir: &corev1.EmptyDirVolumeSource{}, + }, + }, + { + Name: scriptCmForScan(instance), + VolumeSource: corev1.VolumeSource{ + ConfigMap: &corev1.ConfigMapVolumeSource{ + LocalObjectReference: corev1.LocalObjectReference{ + Name: scriptCmForScan(instance), + }, + DefaultMode: &mode, + }, + }, + }, + } + if instance.Spec.RawResultStorage.Disabled { + return volumeList + } else { + volumeList = append(volumeList, corev1.Volume{ + Name: "tls", + VolumeSource: corev1.VolumeSource{ + Secret: &corev1.SecretVolumeSource{ + SecretName: ClientCertPrefix + instance.Name, + }, + }, + }, + ) + return volumeList + } +} + +func getNodeScannerPodVolumes(instance *compv1alpha1.ComplianceScan, node *corev1.Node) []corev1.Volume { + mode := int32(0744) + kubeMode := int32(0600) + volumesList := []corev1.Volume{ + { + Name: "host", + VolumeSource: corev1.VolumeSource{ + HostPath: &corev1.HostPathVolumeSource{ + Path: "/", + Type: &hostPathDir, + }, + }, + }, + { + Name: "report-dir", + VolumeSource: corev1.VolumeSource{ + EmptyDir: &corev1.EmptyDirVolumeSource{}, + }, + }, + { + Name: "content-dir", + VolumeSource: corev1.VolumeSource{ + EmptyDir: &corev1.EmptyDirVolumeSource{}, + }, + }, + { + Name: "tmp-dir", + VolumeSource: corev1.VolumeSource{ + EmptyDir: &corev1.EmptyDirVolumeSource{}, + }, + }, + { + Name: scriptCmForScan(instance), + VolumeSource: corev1.VolumeSource{ + ConfigMap: &corev1.ConfigMapVolumeSource{ + LocalObjectReference: corev1.LocalObjectReference{ + Name: scriptCmForScan(instance), + }, + DefaultMode: &mode, + }, + }, + }, + { + Name: "kubeletconfig", + VolumeSource: corev1.VolumeSource{ + ConfigMap: &corev1.ConfigMapVolumeSource{ + LocalObjectReference: corev1.LocalObjectReference{ + Name: getKubeletCMNameForScan(instance, node), + }, + DefaultMode: &kubeMode, + }, + }, + }, + } + if instance.Spec.RawResultStorage.Disabled { + return volumesList + } else { + volumesList = append(volumesList, corev1.Volume{ + Name: "tls", + VolumeSource: corev1.VolumeSource{ + Secret: &corev1.SecretVolumeSource{ + SecretName: ClientCertPrefix + instance.Name, + }, + }, + }, + ) + return volumesList + } +} diff --git a/pkg/controller/compliancescan/scan.go b/pkg/controller/compliancescan/scan.go index 3b703eb45..0657339a5 100644 --- a/pkg/controller/compliancescan/scan.go +++ b/pkg/controller/compliancescan/scan.go @@ -67,9 +67,6 @@ func scanLimits(scanInstance *compv1alpha1.ComplianceScan, defaultMem, defaultCp } func newScanPodForNode(scanInstance *compv1alpha1.ComplianceScan, node *corev1.Node, logger logr.Logger) *corev1.Pod { - mode := int32(0744) - - kubeMode := int32(0600) podName := getPodForNodeName(scanInstance.Name, node.Name) cmName := getConfigMapForNodeName(scanInstance.Name, node.Name) @@ -182,6 +179,7 @@ func newScanPodForNode(scanInstance *compv1alpha1.ComplianceScan, node *corev1.N "--tls-client-cert=/etc/pki/tls/tls.crt", "--tls-client-key=/etc/pki/tls/tls.key", "--tls-ca=/etc/pki/tls/ca.crt", + "--disable-raw-upload=" + getDisableRawResultUploadValue(scanInstance), }, ImagePullPolicy: corev1.PullAlways, SecurityContext: &corev1.SecurityContext{ @@ -201,18 +199,7 @@ func newScanPodForNode(scanInstance *compv1alpha1.ComplianceScan, node *corev1.N corev1.ResourceCPU: resource.MustParse("100m"), }, }, - VolumeMounts: []corev1.VolumeMount{ - { - Name: "report-dir", - MountPath: "/reports", - ReadOnly: true, - }, - { - Name: "tls", - MountPath: "/etc/pki/tls", - ReadOnly: true, - }, - }, + VolumeMounts: getLogCollectorVolumeMounts(scanInstance), }, { Name: OpenSCAPScanContainerName, @@ -292,71 +279,12 @@ func newScanPodForNode(scanInstance *compv1alpha1.ComplianceScan, node *corev1.N HostNetwork: true, DNSPolicy: "ClusterFirstWithHostNet", RestartPolicy: corev1.RestartPolicyOnFailure, - Volumes: []corev1.Volume{ - { - Name: "host", - VolumeSource: corev1.VolumeSource{ - HostPath: &corev1.HostPathVolumeSource{ - Path: "/", - Type: &hostPathDir, - }, - }, - }, - { - Name: "report-dir", - VolumeSource: corev1.VolumeSource{ - EmptyDir: &corev1.EmptyDirVolumeSource{}, - }, - }, - { - Name: "content-dir", - VolumeSource: corev1.VolumeSource{ - EmptyDir: &corev1.EmptyDirVolumeSource{}, - }, - }, - { - Name: "tmp-dir", - VolumeSource: corev1.VolumeSource{ - EmptyDir: &corev1.EmptyDirVolumeSource{}, - }, - }, - { - Name: scriptCmForScan(scanInstance), - VolumeSource: corev1.VolumeSource{ - ConfigMap: &corev1.ConfigMapVolumeSource{ - LocalObjectReference: corev1.LocalObjectReference{ - Name: scriptCmForScan(scanInstance), - }, - DefaultMode: &mode, - }, - }, - }, - { - Name: "kubeletconfig", - VolumeSource: corev1.VolumeSource{ - ConfigMap: &corev1.ConfigMapVolumeSource{ - LocalObjectReference: corev1.LocalObjectReference{ - Name: getKubeletCMNameForScan(scanInstance, node), - }, - DefaultMode: &kubeMode, - }, - }, - }, - { - Name: "tls", - VolumeSource: corev1.VolumeSource{ - Secret: &corev1.SecretVolumeSource{ - SecretName: ClientCertPrefix + scanInstance.Name, - }, - }, - }, - }, + Volumes: getNodeScannerPodVolumes(scanInstance, node), }, } } func (r *ReconcileComplianceScan) newPlatformScanPod(scanInstance *compv1alpha1.ComplianceScan, logger logr.Logger) *corev1.Pod { - mode := int32(0755) podName := getPodForNodeName(scanInstance.Name, PlatformScanName) cmName := getConfigMapForNodeName(scanInstance.Name, PlatformScanName) podLabels := map[string]string{ @@ -508,6 +436,7 @@ func (r *ReconcileComplianceScan) newPlatformScanPod(scanInstance *compv1alpha1. "--tls-client-cert=/etc/pki/tls/tls.crt", "--tls-client-key=/etc/pki/tls/tls.key", "--tls-ca=/etc/pki/tls/ca.crt", + "--disable-raw-upload=" + getDisableRawResultUploadValue(scanInstance), }, ImagePullPolicy: corev1.PullAlways, SecurityContext: &corev1.SecurityContext{ @@ -527,18 +456,7 @@ func (r *ReconcileComplianceScan) newPlatformScanPod(scanInstance *compv1alpha1. corev1.ResourceCPU: resource.MustParse("100m"), }, }, - VolumeMounts: []corev1.VolumeMount{ - { - Name: "report-dir", - MountPath: "/reports", - ReadOnly: true, - }, - { - Name: "tls", - MountPath: "/etc/pki/tls", - ReadOnly: true, - }, - }, + VolumeMounts: getLogCollectorVolumeMounts(scanInstance), }, { Name: OpenSCAPScanContainerName, @@ -598,51 +516,7 @@ func (r *ReconcileComplianceScan) newPlatformScanPod(scanInstance *compv1alpha1. NodeSelector: r.schedulingInfo.Selector, Tolerations: r.schedulingInfo.Tolerations, RestartPolicy: corev1.RestartPolicyOnFailure, - Volumes: []corev1.Volume{ - { - Name: "report-dir", - VolumeSource: corev1.VolumeSource{ - EmptyDir: &corev1.EmptyDirVolumeSource{}, - }, - }, - { - Name: "content-dir", - VolumeSource: corev1.VolumeSource{ - EmptyDir: &corev1.EmptyDirVolumeSource{}, - }, - }, - { - Name: "tmp-dir", - VolumeSource: corev1.VolumeSource{ - EmptyDir: &corev1.EmptyDirVolumeSource{}, - }, - }, - { - Name: "fetch-results", - VolumeSource: corev1.VolumeSource{ - EmptyDir: &corev1.EmptyDirVolumeSource{}, - }, - }, - { - Name: scriptCmForScan(scanInstance), - VolumeSource: corev1.VolumeSource{ - ConfigMap: &corev1.ConfigMapVolumeSource{ - LocalObjectReference: corev1.LocalObjectReference{ - Name: scriptCmForScan(scanInstance), - }, - DefaultMode: &mode, - }, - }, - }, - { - Name: "tls", - VolumeSource: corev1.VolumeSource{ - Secret: &corev1.SecretVolumeSource{ - SecretName: ClientCertPrefix + scanInstance.Name, - }, - }, - }, - }, + Volumes: getPlatformScannerPodVolumes(scanInstance), }, } } diff --git a/tests/e2e/parallel/main_test.go b/tests/e2e/parallel/main_test.go index 8707611f5..cb2427e46 100644 --- a/tests/e2e/parallel/main_test.go +++ b/tests/e2e/parallel/main_test.go @@ -19,6 +19,7 @@ import ( "k8s.io/apimachinery/pkg/apis/meta/v1/unstructured" "k8s.io/apimachinery/pkg/types" "k8s.io/apimachinery/pkg/util/wait" + "sigs.k8s.io/controller-runtime/pkg/client" ) @@ -1833,6 +1834,72 @@ func TestScheduledSuitePriorityClass(t *testing.T) { } } +func TestScheduledSuiteNoStorage(t *testing.T) { + t.Parallel() + f := framework.Global + suiteName := "test-scheduled-suite-no-storage" + workerScanName := fmt.Sprintf("%s-workers-scan", suiteName) + selectWorkers := map[string]string{ + "node-role.kubernetes.io/worker": "", + } + + testSuite := &compv1alpha1.ComplianceSuite{ + ObjectMeta: metav1.ObjectMeta{ + Name: suiteName, + Namespace: f.OperatorNamespace, + }, + Spec: compv1alpha1.ComplianceSuiteSpec{ + ComplianceSuiteSettings: compv1alpha1.ComplianceSuiteSettings{ + AutoApplyRemediations: false, + }, + Scans: []compv1alpha1.ComplianceScanSpecWrapper{ + { + Name: workerScanName, + ComplianceScanSpec: compv1alpha1.ComplianceScanSpec{ + ContentImage: contentImagePath, + Profile: "xccdf_org.ssgproject.content_profile_moderate", + Content: framework.RhcosContentFile, + Rule: "xccdf_org.ssgproject.content_rule_no_netrc_files", + NodeSelector: selectWorkers, + ComplianceScanSettings: compv1alpha1.ComplianceScanSettings{ + RawResultStorage: compv1alpha1.RawResultStorageSettings{ + Disabled: true, + }, + Debug: true, + }, + }, + }, + }, + }, + } + + err := f.Client.Create(context.TODO(), testSuite, nil) + if err != nil { + t.Fatal(err) + } + defer f.Client.Delete(context.TODO(), testSuite) + + pvcList := &corev1.PersistentVolumeClaimList{} + err = f.Client.List(context.TODO(), pvcList, client.InNamespace(f.OperatorNamespace), client.MatchingLabels(map[string]string{ + compv1alpha1.ComplianceScanLabel: workerScanName, + })) + if err != nil { + t.Fatal(err) + } + if len(pvcList.Items) > 0 { + for _, pvc := range pvcList.Items { + t.Fatalf("Found unexpected PVC %s", pvc.Name) + } + t.Fatal("Expected not to find PVC associated with the scan.") + } + + // Ensure that all the scans in the suite have finished and are marked as Done + err = f.WaitForSuiteScansStatus(f.OperatorNamespace, suiteName, compv1alpha1.PhaseDone, compv1alpha1.ResultCompliant) + if err != nil { + t.Fatal(err) + } +} + func TestScheduledSuiteInvalidPriorityClass(t *testing.T) { t.Parallel() f := framework.Global