diff --git a/.github/workflows/gcp-experiment-pipeline.yml b/.github/workflows/gcp-experiment-pipeline.yml index dfcf0d255..23c7d7192 100644 --- a/.github/workflows/gcp-experiment-pipeline.yml +++ b/.github/workflows/gcp-experiment-pipeline.yml @@ -15,7 +15,7 @@ on: default: "Always" jobs: - GCP_VM_Instance_Stop: + GCP_VM_Instance_Stop_by_Name_And_Label: runs-on: ubuntu-latest env: KUBECONFIG: /etc/rancher/k3s/k3s.yaml @@ -70,7 +70,8 @@ jobs: run: | gcloud compute instances create litmus-e2e-first-vm-${{ github.run_number }} litmus-e2e-second-vm-${{ github.run_number }} \ --machine-type=f1-micro \ - --zone=us-central1-a + --zone=us-east1-b \ + --labels=vm=litmus-e2e-vm-${{ github.run_number }} - name: Litmus Infra Setup if: always() @@ -84,17 +85,29 @@ jobs: env: GCP_PROJECT_ID: ${{ secrets.GCP_PROJECT_ID }} VM_INSTANCE_NAMES: "litmus-e2e-first-vm-${{ github.run_number }},litmus-e2e-second-vm-${{ github.run_number }}" - INSTANCE_ZONES: "us-central1-a,us-central1-a" + INSTANCE_ZONES: "us-east1-b,us-east1-b" EXPERIMENT_IMAGE: "${{ github.event.inputs.experimentImage }}" EXPERIMENT_IMAGE_PULL_POLICY: "${{ github.event.inputs.experimentImagePullPolicy }}" CHAOS_NAMESPACE: "${{ github.event.inputs.chaosNamespace }}" run: make gcp-vm-instance-stop + - name: Run GCP VM Instance Stop By Label experiment in serial & parallel mode + if: always() + env: + GCP_PROJECT_ID: ${{ secrets.GCP_PROJECT_ID }} + INSTANCE_LABEL: "vm : litmus-e2e-vm-${{ github.run_number }}" + INSTANCE_ZONES: "us-east1-b" + INSTANCE_AFFECTED_PERC: "100" + EXPERIMENT_IMAGE: "${{ github.event.inputs.experimentImage }}" + EXPERIMENT_IMAGE_PULL_POLICY: "${{ github.event.inputs.experimentImagePullPolicy }}" + CHAOS_NAMESPACE: "${{ github.event.inputs.chaosNamespace }}" + run: make gcp-vm-instance-stop-by-label + - name: Delete target GCP VM Instances if: always() run: | gcloud compute instances delete litmus-e2e-first-vm-${{ github.run_number }} litmus-e2e-second-vm-${{ github.run_number }} \ - --zone=us-central1-a \ + --zone=us-east1-b \ --quiet - name: "[Debug]: check chaos resources" @@ -119,11 +132,11 @@ jobs: if: always() run: /usr/local/bin/k3s-uninstall.sh - GCP_VM_Disk_Loss: + GCP_VM_Disk_Loss_By_Name_And_Label: runs-on: ubuntu-latest env: KUBECONFIG: /etc/rancher/k3s/k3s.yaml - needs: GCP_VM_Instance_Stop + needs: GCP_VM_Instance_Stop_by_Name_And_Label steps: #Install and configure a k3s cluster @@ -175,9 +188,11 @@ jobs: run: | gcloud compute instances create litmus-e2e-vm-${{ github.run_number }} \ --machine-type=f1-micro \ - --zone=us-central1-a \ + --zone=us-east1-b \ --create-disk name=litmus-e2e-first-disk-${{ github.run_number }},size=1GB,device-name=litmus-e2e-first-disk-${{ github.run_number }} \ --create-disk name=litmus-e2e-second-disk-${{ github.run_number }},size=1GB,device-name=litmus-e2e-second-disk-${{ github.run_number }} + gcloud compute disks add-labels litmus-e2e-first-disk-${{ github.run_number }} --labels=disk=litmus-e2e-disk-${{ github.run_number }} --zone=us-east1-b + gcloud compute disks add-labels litmus-e2e-second-disk-${{ github.run_number }} --labels=disk=litmus-e2e-disk-${{ github.run_number }} --zone=us-east1-b - name: Litmus Infra Setup if: always() @@ -191,18 +206,30 @@ jobs: env: GCP_PROJECT_ID: ${{ secrets.GCP_PROJECT_ID }} DISK_VOLUME_NAMES: "litmus-e2e-first-disk-${{ github.run_number }},litmus-e2e-second-disk-${{ github.run_number }}" - DISK_ZONES: "us-central1-a,us-central1-a" + DISK_ZONES: "us-east1-b,us-east1-b" DEVICE_NAMES: "litmus-e2e-first-disk-${{ github.run_number }},litmus-e2e-second-disk-${{ github.run_number }}" EXPERIMENT_IMAGE: "${{ github.event.inputs.experimentImage }}" EXPERIMENT_IMAGE_PULL_POLICY: "${{ github.event.inputs.experimentImagePullPolicy }}" CHAOS_NAMESPACE: "${{ github.event.inputs.chaosNamespace }}" run: make gcp-vm-disk-loss + - name: Run GCP VM Disk Loss By Label experiment in serial & parallel mode + if: always() + env: + GCP_PROJECT_ID: ${{ secrets.GCP_PROJECT_ID }} + DISK_VOLUME_LABEL: "disk : litmus-e2e-disk-${{ github.run_number }}" + DISK_ZONES: "us-east1-b" + DISK_AFFECTED_PERC: "100" + EXPERIMENT_IMAGE: "${{ github.event.inputs.experimentImage }}" + EXPERIMENT_IMAGE_PULL_POLICY: "${{ github.event.inputs.experimentImagePullPolicy }}" + CHAOS_NAMESPACE: "${{ github.event.inputs.chaosNamespace }}" + run: make gcp-vm-disk-loss-by-label + - name: Delete the VM Instance and target Disk Volumes if: always() run: | gcloud compute instances delete litmus-e2e-vm-${{ github.run_number }} \ - --zone=us-central1-a \ + --zone=us-east1-b \ --delete-disks=all \ --quiet diff --git a/.github/workflows/nightly-gcp-experiment-pipeline.yml b/.github/workflows/nightly-gcp-experiment-pipeline.yml index e2ae5d684..a304ab5d0 100644 --- a/.github/workflows/nightly-gcp-experiment-pipeline.yml +++ b/.github/workflows/nightly-gcp-experiment-pipeline.yml @@ -5,16 +5,14 @@ on: - cron: "30 22 * * *" # Daily 02:30 AM in midnight jobs: - GCP_VM_Instance_Stop: + GCP_VM_Instance_Stop_by_Name_And_Label: runs-on: ubuntu-latest - env: + env: KUBECONFIG: /etc/rancher/k3s/k3s.yaml steps: #Install and configure a k3s cluster - name: Installing Prerequisites (K3S Cluster) - env: - KUBECONFIG: /etc/rancher/k3s/k3s.yaml run: | curl -sfL https://get.k3s.io | sh -s - --docker --write-kubeconfig-mode 664 kubectl wait node --all --for condition=ready --timeout=90s @@ -62,7 +60,8 @@ jobs: run: | gcloud compute instances create litmus-e2e-first-vm-${{ github.run_number }} litmus-e2e-second-vm-${{ github.run_number }} \ --machine-type=f1-micro \ - --zone=us-central1-a + --zone=us-east1-b \ + --labels=vm=litmus-e2e-vm-${{ github.run_number }} - name: Litmus Infra Setup if: always() @@ -73,14 +72,23 @@ jobs: env: GCP_PROJECT_ID: ${{ secrets.GCP_PROJECT_ID }} VM_INSTANCE_NAMES: "litmus-e2e-first-vm-${{ github.run_number }},litmus-e2e-second-vm-${{ github.run_number }}" - INSTANCE_ZONES: "us-central1-a,us-central1-a" + INSTANCE_ZONES: "us-east1-b,us-east1-b" run: make gcp-vm-instance-stop + - name: Run GCP VM Instance Stop By Label experiment in serial & parallel mode + if: always() + env: + GCP_PROJECT_ID: ${{ secrets.GCP_PROJECT_ID }} + INSTANCE_LABEL: "vm : litmus-e2e-vm-${{ github.run_number }}" + INSTANCE_ZONES: "us-east1-b" + INSTANCE_AFFECTED_PERC: "100" + run: make gcp-vm-instance-stop-by-label + - name: Delete target GCP VM Instances if: always() run: | gcloud compute instances delete litmus-e2e-first-vm-${{ github.run_number }} litmus-e2e-second-vm-${{ github.run_number }} \ - --zone=us-central1-a \ + --zone=us-east1-b \ --quiet - name: "[Debug]: check chaos resources" @@ -98,18 +106,18 @@ jobs: cat logs.txt - name: Litmus Cleanup - if: ${{ always() }} + if: ${{ always() }} run: make litmus-cleanup - name: Deleting K3S cluster if: always() run: /usr/local/bin/k3s-uninstall.sh - GCP_VM_Disk_Loss: + GCP_VM_Disk_Loss_By_Name_And_Label: runs-on: ubuntu-latest env: KUBECONFIG: /etc/rancher/k3s/k3s.yaml - needs: GCP_VM_Instance_Stop + needs: GCP_VM_Instance_Stop_by_Name_And_Label steps: #Install and configure a k3s cluster @@ -161,9 +169,11 @@ jobs: run: | gcloud compute instances create litmus-e2e-vm-${{ github.run_number }} \ --machine-type=f1-micro \ - --zone=us-central1-a \ + --zone=us-east1-b \ --create-disk name=litmus-e2e-first-disk-${{ github.run_number }},size=1GB,device-name=litmus-e2e-first-disk-${{ github.run_number }} \ --create-disk name=litmus-e2e-second-disk-${{ github.run_number }},size=1GB,device-name=litmus-e2e-second-disk-${{ github.run_number }} + gcloud compute disks add-labels litmus-e2e-first-disk-${{ github.run_number }} --labels=disk=litmus-e2e-disk-${{ github.run_number }} --zone=us-east1-b + gcloud compute disks add-labels litmus-e2e-second-disk-${{ github.run_number }} --labels=disk=litmus-e2e-disk-${{ github.run_number }} --zone=us-east1-b - name: Litmus Infra Setup if: always() @@ -174,15 +184,24 @@ jobs: env: GCP_PROJECT_ID: ${{ secrets.GCP_PROJECT_ID }} DISK_VOLUME_NAMES: "litmus-e2e-first-disk-${{ github.run_number }},litmus-e2e-second-disk-${{ github.run_number }}" - DISK_ZONES: "us-central1-a,us-central1-a" + DISK_ZONES: "us-east1-b,us-east1-b" DEVICE_NAMES: "litmus-e2e-first-disk-${{ github.run_number }},litmus-e2e-second-disk-${{ github.run_number }}" run: make gcp-vm-disk-loss + - name: Run GCP VM Disk Loss By Label experiment in serial & parallel mode + if: always() + env: + GCP_PROJECT_ID: ${{ secrets.GCP_PROJECT_ID }} + DISK_VOLUME_LABEL: "disk : litmus-e2e-disk-${{ github.run_number }}" + DISK_ZONES: "us-east1-b" + DISK_AFFECTED_PERC: "100" + run: make gcp-vm-disk-loss-by-label + - name: Delete the VM Instance and target Disk Volumes if: always() run: | gcloud compute instances delete litmus-e2e-vm-${{ github.run_number }} \ - --zone=us-central1-a \ + --zone=us-east1-b \ --delete-disks=all \ --quiet @@ -201,7 +220,7 @@ jobs: cat logs.txt - name: Litmus Cleanup - if: ${{ always() }} + if: ${{ always() }} run: make litmus-cleanup - name: Deleting K3S cluster diff --git a/Makefile b/Makefile index a9b3fb3bf..4a08729ea 100644 --- a/Makefile +++ b/Makefile @@ -257,6 +257,22 @@ gcp-vm-disk-loss: @echo "------------------------------------------" @go test platform/gcp/gcp-vm-disk-loss_test.go -v -count=1 -timeout=20m +.PHONY: gcp-vm-instance-stop-by-label +gcp-vm-instance-stop-by-label: + + @echo "------------------------------------------" + @echo "Running gcp-vm-instance-stop-by-label experiment" + @echo "------------------------------------------" + @go test platform/gcp/gcp-vm-instance-stop-by-label_test.go -v -count=1 -timeout=20m + +.PHONY: gcp-vm-disk-loss-by-label +gcp-vm-disk-loss-by-label: + + @echo "------------------------------------------" + @echo "Running gcp-vm-disk-loss-by-label experiment" + @echo "------------------------------------------" + @go test platform/gcp/gcp-vm-disk-loss-by-label_test.go -v -count=1 -timeout=20m + .PHONY: vm-poweroff vm-poweroff: diff --git a/pkg/environment/environment.go b/pkg/environment/environment.go index 41f0413d0..deccd9c97 100644 --- a/pkg/environment/environment.go +++ b/pkg/environment/environment.go @@ -39,6 +39,10 @@ func GetENV(testDetails *types.TestDetails, expName, engineName string) { testDetails.DiskVolumeNames = Getenv("DISK_VOLUME_NAMES", "") testDetails.DiskZones = Getenv("DISK_ZONES", "") testDetails.DeviceNames = Getenv("DEVICE_NAMES", "") + testDetails.InstanceLabel = Getenv("INSTANCE_LABEL", "") + testDetails.InstanceAffectedPercentage = Getenv("INSTANCE_AFFECTED_PERC", "") + testDetails.DiskVolumeLabel = Getenv("DISK_VOLUME_LABEL", "") + testDetails.DiskAffectedPercentage = Getenv("DISK_AFFECTED_PERC", "") testDetails.VMIds = Getenv("APP_VM_MOIDS", "") testDetails.Region = Getenv("REGION", "us-west-1") testDetails.UpdateWebsite = Getenv("UPDATE_WEBSITE", "false") diff --git a/pkg/install.go b/pkg/install.go index 0bfa08efe..cdb8b1580 100644 --- a/pkg/install.go +++ b/pkg/install.go @@ -336,6 +336,16 @@ func setEngineVar(chaosEngine *v1alpha1.ChaosEngine, testsDetails *types.TestDet SetEnv("DISK_VOLUME_NAMES", testsDetails.DiskVolumeNames). SetEnv("DISK_ZONES", testsDetails.DiskZones). SetEnv("DEVICE_NAMES", testsDetails.DeviceNames) + case "gcp-vm-instance-stop-by-label": + envDetails.SetEnv("GCP_PROJECT_ID", testsDetails.GCPProjectID). + SetEnv("INSTANCE_LABEL", testsDetails.InstanceLabel). + SetEnv("INSTANCE_ZONES", testsDetails.InstanceZones). + SetEnv("INSTANCE_AFFECTED_PERC", testsDetails.InstanceAffectedPercentage) + case "gcp-vm-disk-loss-by-label": + envDetails.SetEnv("GCP_PROJECT_ID", testsDetails.GCPProjectID). + SetEnv("DISK_VOLUME_LABEL", testsDetails.DiskVolumeLabel). + SetEnv("DISK_ZONES", testsDetails.DiskZones). + SetEnv("DISK_AFFECTED_PERC", testsDetails.DiskAffectedPercentage) case "vm-poweroff": envDetails.SetEnv("APP_VM_MOIDS", testsDetails.VMIds) case "process-kill": diff --git a/pkg/types/types.go b/pkg/types/types.go index 71bfb2185..c8cf9810f 100644 --- a/pkg/types/types.go +++ b/pkg/types/types.go @@ -2,65 +2,69 @@ package types // TestDetails is for collecting all the test-related details type TestDetails struct { - ExperimentName string - EngineName string - OperatorName string - ChaosNamespace string - RbacPath string - ExperimentPath string - EnginePath string - AnsibleRbacPath string - AnsibleExperimentPath string - AnsibleEnginePath string - AnsibleExperimentImage string - AppNS string - AppLabel string - JobCleanUpPolicy string - AnnotationCheck string - ApplicationNodeName string - ExperimentImage string - InstallLitmus string - OperatorImage string - ImagePullPolicy string - ExperimentImagePullPolicy string - RunnerImage string - ChaosDuration int - AdminRbacPath string - ChaosServiceAccount string - NewExperimentName string - NodeSelectorName string - Delay int - Duration int - TargetPod string - LibImage string - FillPercentage int - CPUKillCommand string - MemoryKillCommand string - NetworkLatency string - UpdateWebsite string - InstanceID string - InstanceTag string - EBSVolumeID string - EBSVolumeTag string - VMInstanceNames string - GCPProjectID string - InstanceZones string - DiskVolumeNames string - DiskZones string - DeviceNames string - VMIds string - Region string - Lib string - PodsAffectedPercentage string - Sequence string - Version string - TargetNodes string - NodeLabel string - AzureResourceGroup string - AzureInstanceName string - AzureDiskName string - AzureScaleSet string - ProcessIds string - Args string - Command string + ExperimentName string + EngineName string + OperatorName string + ChaosNamespace string + RbacPath string + ExperimentPath string + EnginePath string + AnsibleRbacPath string + AnsibleExperimentPath string + AnsibleEnginePath string + AnsibleExperimentImage string + AppNS string + AppLabel string + JobCleanUpPolicy string + AnnotationCheck string + ApplicationNodeName string + ExperimentImage string + InstallLitmus string + OperatorImage string + ImagePullPolicy string + ExperimentImagePullPolicy string + RunnerImage string + ChaosDuration int + AdminRbacPath string + ChaosServiceAccount string + NewExperimentName string + NodeSelectorName string + Delay int + Duration int + TargetPod string + LibImage string + FillPercentage int + CPUKillCommand string + MemoryKillCommand string + NetworkLatency string + UpdateWebsite string + InstanceID string + InstanceTag string + EBSVolumeID string + EBSVolumeTag string + VMInstanceNames string + GCPProjectID string + InstanceZones string + DiskVolumeNames string + DiskZones string + DeviceNames string + InstanceLabel string + InstanceAffectedPercentage string + DiskVolumeLabel string + DiskAffectedPercentage string + VMIds string + Region string + Lib string + PodsAffectedPercentage string + Sequence string + Version string + TargetNodes string + NodeLabel string + AzureResourceGroup string + AzureInstanceName string + AzureDiskName string + AzureScaleSet string + ProcessIds string + Args string + Command string } diff --git a/platform/gcp/gcp-vm-disk-loss-by-label_test.go b/platform/gcp/gcp-vm-disk-loss-by-label_test.go new file mode 100644 index 000000000..f0eeb0561 --- /dev/null +++ b/platform/gcp/gcp-vm-disk-loss-by-label_test.go @@ -0,0 +1,154 @@ +package tests + +import ( + "testing" + + "github.com/litmuschaos/chaos-operator/pkg/apis/litmuschaos/v1alpha1" + "github.com/litmuschaos/litmus-e2e/pkg" + "github.com/litmuschaos/litmus-e2e/pkg/environment" + "github.com/litmuschaos/litmus-e2e/pkg/log" + "github.com/litmuschaos/litmus-e2e/pkg/types" + . "github.com/onsi/ginkgo" + . "github.com/onsi/gomega" + "k8s.io/klog" +) + +func TestGoGCPVMDiskLossByLabel(t *testing.T) { + RegisterFailHandler(Fail) + RunSpecs(t, "BDD test") +} + +//BDD for testing experiment +var _ = Describe("BDD of gcp-vm-disk-loss-by-label experiment", func() { + + // BDD TEST CASE 1 - gcp-vm-disk-loss-by-label in parallel mode + Context("Check for gcp-vm-disk-loss-by-label experiment", func() { + + It("Should check for the gcp vm disk loss by label in parallel", func() { + + testsDetails := types.TestDetails{} + clients := environment.ClientSets{} + chaosExperiment := v1alpha1.ChaosExperiment{} + chaosEngine := v1alpha1.ChaosEngine{} + + //Getting kubeConfig and Generate ClientSets + By("[PreChaos]: Getting kubeconfig and generate clientset") + err := clients.GenerateClientSetFromKubeConfig() + Expect(err).To(BeNil(), "Unable to Get the kubeconfig, due to {%v}", err) + + //Fetching all the default ENV + By("[PreChaos]: Fetching all default ENVs") + klog.Infof("[PreReq]: Getting the ENVs for the %v test", testsDetails.ExperimentName) + environment.GetENV(&testsDetails, "gcp-vm-disk-loss-by-label", "gcp-disk-label-engine-par") + log.Infof("[Info]: The target disk volumes are: %v", testsDetails.DiskVolumeNames) + + testsDetails.RbacPath = "https://hub.litmuschaos.io/api/chaos/master?file=charts/gcp/gcp-vm-disk-loss-by-label/rbac.yaml" + testsDetails.ExperimentPath = "https://hub.litmuschaos.io/api/chaos/master?file=charts/gcp/gcp-vm-disk-loss-by-label/experiment.yaml" + testsDetails.EnginePath = "https://hub.litmuschaos.io/api/chaos/master?file=charts/gcp/gcp-vm-disk-loss-by-label/engine.yaml" + testsDetails.ChaosNamespace = "default" + testsDetails.AppNS = "default" + + // Checking the chaos operator running status + By("[Status]: Checking chaos operator status") + err = pkg.OperatorStatusCheck(&testsDetails, clients) + Expect(err).To(BeNil(), "Operator status check failed, due to {%v}", err) + + // Prepare Chaos Execution + By("[Prepare]: Prepare Chaos Execution") + err = pkg.PrepareChaos(&testsDetails, &chaosExperiment, &chaosEngine, clients, false) + Expect(err).To(BeNil(), "fail to prepare chaos, due to {%v}", err) + + //Checking runner pod running state + By("[Status]: Runner pod running status check") + err = pkg.RunnerPodStatus(&testsDetails, testsDetails.AppNS, clients) + Expect(err).To(BeNil(), "Runner pod status check failed, due to {%v}", err) + + //Chaos pod running status check + err = pkg.ChaosPodStatus(&testsDetails, clients) + Expect(err).To(BeNil(), "Chaos pod status check failed, due to {%v}", err) + + //Waiting for chaos pod to get completed + //And Print the logs of the chaos pod + By("[Status]: Wait for chaos pod completion and then print logs") + err = pkg.ChaosPodLogs(&testsDetails, clients) + Expect(err).To(BeNil(), "Fail to get the experiment chaos pod logs, due to {%v}", err) + + //Checking the chaosresult verdict + By("[Verdict]: Checking the chaosresult verdict") + err = pkg.ChaosResultVerdict(&testsDetails, clients) + Expect(err).To(BeNil(), "ChasoResult Verdict check failed, due to {%v}", err) + + //Checking chaosengine verdict + By("Checking the Verdict of Chaos Engine") + err = pkg.ChaosEngineVerdict(&testsDetails, clients) + Expect(err).To(BeNil(), "ChaosEngine Verdict check failed, due to {%v}", err) + + }) + }) + + // BDD TEST CASE 2 - gcp-vm-disk-loss-by-label in serial mode + Context("Check for gcp-vm-disk-loss-by-label experiment", func() { + + It("Should check for the gcp vm disk loss by label in serial", func() { + + testsDetails := types.TestDetails{} + clients := environment.ClientSets{} + chaosExperiment := v1alpha1.ChaosExperiment{} + chaosEngine := v1alpha1.ChaosEngine{} + + //Getting kubeConfig and Generate ClientSets + By("[PreChaos]: Getting kubeconfig and generate clientset") + err := clients.GenerateClientSetFromKubeConfig() + Expect(err).To(BeNil(), "Unable to Get the kubeconfig, due to {%v}", err) + + //Fetching all the default ENV + By("[PreChaos]: Fetching all default ENVs") + klog.Infof("[PreReq]: Getting the ENVs for the %v test", testsDetails.ExperimentName) + environment.GetENV(&testsDetails, "gcp-vm-disk-loss-by-label", "gcp-disk-label-engine-ser") + log.Infof("[Info]: The target disk volumes are: %v", testsDetails.DiskVolumeNames) + + testsDetails.RbacPath = "https://hub.litmuschaos.io/api/chaos/master?file=charts/gcp/gcp-vm-disk-loss-by-label/rbac.yaml" + testsDetails.ExperimentPath = "https://hub.litmuschaos.io/api/chaos/master?file=charts/gcp/gcp-vm-disk-loss-by-label/experiment.yaml" + testsDetails.EnginePath = "https://hub.litmuschaos.io/api/chaos/master?file=charts/gcp/gcp-vm-disk-loss-by-label/engine.yaml" + testsDetails.Sequence = "serial" + testsDetails.ChaosNamespace = "default" + testsDetails.AppNS = "default" + + // Checking the chaos operator running status + By("[Status]: Checking chaos operator status") + err = pkg.OperatorStatusCheck(&testsDetails, clients) + Expect(err).To(BeNil(), "Operator status check failed, due to {%v}", err) + + // Prepare Chaos Execution + By("[Prepare]: Prepare Chaos Execution") + err = pkg.PrepareChaos(&testsDetails, &chaosExperiment, &chaosEngine, clients, false) + Expect(err).To(BeNil(), "fail to prepare chaos, due to {%v}", err) + + //Checking runner pod running state + By("[Status]: Runner pod running status check") + err = pkg.RunnerPodStatus(&testsDetails, testsDetails.AppNS, clients) + Expect(err).To(BeNil(), "Runner pod status check failed, due to {%v}", err) + + //Chaos pod running status check + err = pkg.ChaosPodStatus(&testsDetails, clients) + Expect(err).To(BeNil(), "Chaos pod status check failed, due to {%v}", err) + + //Waiting for chaos pod to get completed + //And Print the logs of the chaos pod + By("[Status]: Wait for chaos pod completion and then print logs") + err = pkg.ChaosPodLogs(&testsDetails, clients) + Expect(err).To(BeNil(), "Fail to get the experiment chaos pod logs, due to {%v}", err) + + //Checking the chaosresult verdict + By("[Verdict]: Checking the chaosresult verdict") + err = pkg.ChaosResultVerdict(&testsDetails, clients) + Expect(err).To(BeNil(), "ChasoResult Verdict check failed, due to {%v}", err) + + //Checking chaosengine verdict + By("Checking the Verdict of Chaos Engine") + err = pkg.ChaosEngineVerdict(&testsDetails, clients) + Expect(err).To(BeNil(), "ChaosEngine Verdict check failed, due to {%v}", err) + + }) + }) +}) diff --git a/platform/gcp/gcp-vm-instance-stop-by-label_test.go b/platform/gcp/gcp-vm-instance-stop-by-label_test.go new file mode 100644 index 000000000..797ca57b4 --- /dev/null +++ b/platform/gcp/gcp-vm-instance-stop-by-label_test.go @@ -0,0 +1,151 @@ +package tests + +import ( + "testing" + + "github.com/litmuschaos/chaos-operator/pkg/apis/litmuschaos/v1alpha1" + "github.com/litmuschaos/litmus-e2e/pkg" + "github.com/litmuschaos/litmus-e2e/pkg/environment" + "github.com/litmuschaos/litmus-e2e/pkg/log" + "github.com/litmuschaos/litmus-e2e/pkg/types" + . "github.com/onsi/ginkgo" + . "github.com/onsi/gomega" + "k8s.io/klog" +) + +func TestGoGCPVMInstanceStopByLabel(t *testing.T) { + RegisterFailHandler(Fail) + RunSpecs(t, "BDD test") +} + +var _ = Describe("BDD of gcp-vm-instance-stop-by-label experiment", func() { + + // BDD TEST CASE 1 - gcp-vm-instance-stop-by-label in parallel mode + Context("Check for gcp-vm-instance-stop-by-label experiment", func() { + It("Should check for the gcp vm instance stop by label in parallel", func() { + + testsDetails := types.TestDetails{} + clients := environment.ClientSets{} + chaosExperiment := v1alpha1.ChaosExperiment{} + chaosEngine := v1alpha1.ChaosEngine{} + + //Getting kubeConfig and Generate ClientSets + By("[PreChaos]: Getting kubeconfig and generate clientset") + err := clients.GenerateClientSetFromKubeConfig() + Expect(err).To(BeNil(), "Unable to Get the kubeconfig, due to {%v}", err) + + //Fetching all the default ENV + By("[PreChaos]: Fetching all default ENVs") + klog.Infof("[PreReq]: Getting the ENVs for the %v test", testsDetails.ExperimentName) + environment.GetENV(&testsDetails, "gcp-vm-instance-stop-by-label", "gcp-vm-label-engine-par") + log.Infof("[Info]: The target VM instances are: %v", testsDetails.VMInstanceNames) + + testsDetails.RbacPath = "https://hub.litmuschaos.io/api/chaos/master?file=charts/gcp/gcp-vm-instance-stop-by-label/rbac.yaml" + testsDetails.ExperimentPath = "https://hub.litmuschaos.io/api/chaos/master?file=charts/gcp/gcp-vm-instance-stop-by-label/experiment.yaml" + testsDetails.EnginePath = "https://hub.litmuschaos.io/api/chaos/master?file=charts/gcp/gcp-vm-instance-stop-by-label/engine.yaml" + testsDetails.ChaosNamespace = "default" + testsDetails.AppNS = "default" + + // Checking the chaos operator running status + By("[Status]: Checking chaos operator status") + err = pkg.OperatorStatusCheck(&testsDetails, clients) + Expect(err).To(BeNil(), "Operator status check failed, due to {%v}", err) + + // Prepare Chaos Execution + By("[Prepare]: Prepare Chaos Execution") + err = pkg.PrepareChaos(&testsDetails, &chaosExperiment, &chaosEngine, clients, false) + Expect(err).To(BeNil(), "fail to prepare chaos, due to {%v}", err) + + //Checking runner pod running state + By("[Status]: Runner pod running status check") + err = pkg.RunnerPodStatus(&testsDetails, testsDetails.AppNS, clients) + Expect(err).To(BeNil(), "Runner pod status check failed, due to {%v}", err) + + //Chaos pod running status check + err = pkg.ChaosPodStatus(&testsDetails, clients) + Expect(err).To(BeNil(), "Chaos pod status check failed, due to {%v}", err) + + //Waiting for chaos pod to get completed + //And Print the logs of the chaos pod + By("[Status]: Wait for chaos pod completion and then print logs") + err = pkg.ChaosPodLogs(&testsDetails, clients) + Expect(err).To(BeNil(), "Fail to get the experiment chaos pod logs, due to {%v}", err) + + //Checking the chaosresult verdict + By("[Verdict]: Checking the chaosresult verdict") + err = pkg.ChaosResultVerdict(&testsDetails, clients) + Expect(err).To(BeNil(), "ChasoResult Verdict check failed, due to {%v}", err) + + //Checking chaosengine verdict + By("Checking the Verdict of Chaos Engine") + err = pkg.ChaosEngineVerdict(&testsDetails, clients) + Expect(err).To(BeNil(), "ChaosEngine Verdict check failed, due to {%v}", err) + }) + }) + + // BDD TEST CASE 2 - gcp-vm-instance-stop-by-label in serial mode + Context("Check for gcp-vm-instance-stop-by-label experiment", func() { + + It("Should check for the gcp vm instance stop by label in serial", func() { + + testsDetails := types.TestDetails{} + clients := environment.ClientSets{} + chaosExperiment := v1alpha1.ChaosExperiment{} + chaosEngine := v1alpha1.ChaosEngine{} + + //Getting kubeConfig and Generate ClientSets + By("[PreChaos]: Getting kubeconfig and generate clientset") + err := clients.GenerateClientSetFromKubeConfig() + Expect(err).To(BeNil(), "Unable to Get the kubeconfig, due to {%v}", err) + + //Fetching all the default ENV + By("[PreChaos]: Fetching all default ENVs") + klog.Infof("[PreReq]: Getting the ENVs for the %v test", testsDetails.ExperimentName) + environment.GetENV(&testsDetails, "gcp-vm-instance-stop-by-label", "gcp-vm-label-engine-ser") + log.Infof("[Info]: The target VM instances are: %v", testsDetails.VMInstanceNames) + + testsDetails.RbacPath = "https://hub.litmuschaos.io/api/chaos/master?file=charts/gcp/gcp-vm-instance-stop-by-label/rbac.yaml" + testsDetails.ExperimentPath = "https://hub.litmuschaos.io/api/chaos/master?file=charts/gcp/gcp-vm-instance-stop-by-label/experiment.yaml" + testsDetails.EnginePath = "https://hub.litmuschaos.io/api/chaos/master?file=charts/gcp/gcp-vm-instance-stop-by-label/engine.yaml" + testsDetails.Sequence = "serial" + testsDetails.ChaosNamespace = "default" + testsDetails.AppNS = "default" + + // Checking the chaos operator running status + By("[Status]: Checking chaos operator status") + err = pkg.OperatorStatusCheck(&testsDetails, clients) + Expect(err).To(BeNil(), "Operator status check failed, due to {%v}", err) + + // Prepare Chaos Execution + By("[Prepare]: Prepare Chaos Execution") + err = pkg.PrepareChaos(&testsDetails, &chaosExperiment, &chaosEngine, clients, false) + Expect(err).To(BeNil(), "fail to prepare chaos, due to {%v}", err) + + //Checking runner pod running state + By("[Status]: Runner pod running status check") + err = pkg.RunnerPodStatus(&testsDetails, testsDetails.AppNS, clients) + Expect(err).To(BeNil(), "Runner pod status check failed, due to {%v}", err) + + //Chaos pod running status check + err = pkg.ChaosPodStatus(&testsDetails, clients) + Expect(err).To(BeNil(), "Chaos pod status check failed, due to {%v}", err) + + //Waiting for chaos pod to get completed + //And Print the logs of the chaos pod + By("[Status]: Wait for chaos pod completion and then print logs") + err = pkg.ChaosPodLogs(&testsDetails, clients) + Expect(err).To(BeNil(), "Fail to get the experiment chaos pod logs, due to {%v}", err) + + //Checking the chaosresult verdict + By("[Verdict]: Checking the chaosresult verdict") + err = pkg.ChaosResultVerdict(&testsDetails, clients) + Expect(err).To(BeNil(), "ChasoResult Verdict check failed, due to {%v}", err) + + //Checking chaosengine verdict + By("Checking the Verdict of Chaos Engine") + err = pkg.ChaosEngineVerdict(&testsDetails, clients) + Expect(err).To(BeNil(), "ChaosEngine Verdict check failed, due to {%v}", err) + + }) + }) +})