From 799a12d54ee3266bd9d11591f1a24aaff8dae588 Mon Sep 17 00:00:00 2001 From: Yang Chiu Date: Thu, 24 Oct 2024 19:23:15 +0800 Subject: [PATCH] ci: support oracle for hal cluster Signed-off-by: Yang Chiu --- .../terraform/harvester/oracle/main.tf | 218 ++++++++++++++++++ .../terraform/harvester/oracle/variables.tf | 49 ++++ 2 files changed, 267 insertions(+) create mode 100644 test_framework/terraform/harvester/oracle/main.tf create mode 100644 test_framework/terraform/harvester/oracle/variables.tf diff --git a/test_framework/terraform/harvester/oracle/main.tf b/test_framework/terraform/harvester/oracle/main.tf new file mode 100644 index 000000000..46aefcb0d --- /dev/null +++ b/test_framework/terraform/harvester/oracle/main.tf @@ -0,0 +1,218 @@ +terraform { + required_providers { + rancher2 = { + source = "rancher/rancher2" + version = "~> 5.1.0" + } + } +} + +provider "rancher2" { + api_url = var.lab_url + insecure = true + access_key = var.lab_access_key + secret_key = var.lab_secret_key +} + +resource "random_string" "random_suffix" { + length = 8 + special = false + lower = true + upper = false +} + +data "rancher2_cluster_v2" "hal-cluster" { + name = "hal" +} + +resource "rancher2_cloud_credential" "e2e-credential" { + name = "e2e-credential-${random_string.random_suffix.id}" + harvester_credential_config { + cluster_id = data.rancher2_cluster_v2.hal-cluster.cluster_v1_id + cluster_type = "imported" + kubeconfig_content = data.rancher2_cluster_v2.hal-cluster.kube_config + } +} + +resource "rancher2_machine_config_v2" "e2e-machine-config-controlplane" { + + generate_name = "e2e-machine-config-controlplane-${random_string.random_suffix.id}" + + harvester_config { + + vm_namespace = "longhorn-qa" + + cpu_count = "4" + memory_size = "8" + + disk_info = <- + ${file(var.ssh_public_key_file_path)} +runcmd: + - - systemctl + - enable + - '--now' + - qemu-guest-agent.service + - systemctl stop firewalld.service + - systemctl disable firewalld.service +EOF + } +} + +resource "rancher2_machine_config_v2" "e2e-machine-config-worker" { + + generate_name = "e2e-machine-config-worker-${random_string.random_suffix.id}" + + harvester_config { + + vm_namespace = "longhorn-qa" + + cpu_count = "4" + memory_size = "8" + + disk_info = <- + ${file(var.ssh_public_key_file_path)} +package_update: true +packages: + - qemu-guest-agent + - iptables + - iscsi-initiator-utils + - nfs-utils + - nfs4-acl-tools + - cryptsetup + - device-mapper +runcmd: + - - systemctl + - enable + - '--now' + - qemu-guest-agent.service + - systemctl stop firewalld.service + - systemctl disable firewalld.service + - modprobe uio + - modprobe uio_pci_generic + - modprobe vfio_pci + - modprobe nvme-tcp + - modprobe dm_crypt + - touch /etc/modules-load.d/modules.conf + - echo uio >> /etc/modules-load.d/modules.conf + - echo uio_pci_generic >> /etc/modules-load.d/modules.conf + - echo vfio_pci >> /etc/modules-load.d/modules.conf + - echo nvme-tcp >> /etc/modules-load.d/modules.conf + - echo dm_crypt >> /etc/modules-load.d/modules.conf + - echo 1024 > /sys/kernel/mm/hugepages/hugepages-2048kB/nr_hugepages + - echo "vm.nr_hugepages=1024" >> /etc/sysctl.conf +EOF + } +} + +resource "rancher2_cluster_v2" "e2e-cluster" { + + name = "e2e-cluster-${random_string.random_suffix.id}" + + kubernetes_version = var.k8s_distro_version + + rke_config { + machine_pools { + name = "control-plane-pool" + cloud_credential_secret_name = rancher2_cloud_credential.e2e-credential.id + control_plane_role = true + etcd_role = true + worker_role = false + quantity = 1 + machine_config { + kind = rancher2_machine_config_v2.e2e-machine-config-controlplane.kind + name = rancher2_machine_config_v2.e2e-machine-config-controlplane.name + } + } + machine_pools { + name = "worker-pool" + cloud_credential_secret_name = rancher2_cloud_credential.e2e-credential.id + control_plane_role = false + etcd_role = false + worker_role = true + quantity = 3 + machine_config { + kind = rancher2_machine_config_v2.e2e-machine-config-worker.kind + name = rancher2_machine_config_v2.e2e-machine-config-worker.name + } + } + machine_selector_config { + config = <