From 82424d076f991e0640b7736d8bfd9be8352bf212 Mon Sep 17 00:00:00 2001 From: Ujjwal Kumar Date: Tue, 20 Jun 2023 09:50:15 +0530 Subject: [PATCH] enhancement(profiles): added support for vcpu manufacturer(vsi, dh) --- ibm/acctest/acctest.go | 4 +- .../vpc/data_source_ibm_is_dedicated_host.go | 22 ++++++- ...ta_source_ibm_is_dedicated_host_profile.go | 49 ++++++++++++++ ...urce_ibm_is_dedicated_host_profile_test.go | 1 + ...a_source_ibm_is_dedicated_host_profiles.go | 40 ++++++++++++ ...rce_ibm_is_dedicated_host_profiles_test.go | 1 + .../data_source_ibm_is_dedicated_host_test.go | 1 + .../vpc/data_source_ibm_is_dedicated_hosts.go | 22 ++++++- ...data_source_ibm_is_dedicated_hosts_test.go | 1 + .../vpc/data_source_ibm_is_instance.go | 7 ++ .../data_source_ibm_is_instance_profile.go | 64 ++++++++++++++++++- ...ata_source_ibm_is_instance_profile_test.go | 3 + .../data_source_ibm_is_instance_profiles.go | 32 ++++++++++ ...ta_source_ibm_is_instance_profiles_test.go | 3 + .../vpc/data_source_ibm_is_instance_test.go | 4 ++ .../vpc/data_source_ibm_is_instances.go | 6 ++ .../vpc/data_source_ibm_is_instances_test.go | 1 + ibm/service/vpc/resource_ibm_is_instance.go | 7 ++ .../vpc/resource_ibm_is_instance_test.go | 8 +++ .../docs/d/is_dedicated_host.html.markdown | 2 + .../d/is_dedicated_host_profile.html.markdown | 5 ++ .../is_dedicated_host_profiles.html.markdown | 5 ++ website/docs/d/is_instance.html.markdown | 1 + .../docs/d/is_instance_profile.html.markdown | 6 ++ .../docs/d/is_instance_profiles.html.markdown | 6 ++ website/docs/d/is_instances.html.markdown | 1 + website/docs/r/is_instance.html.markdown | 1 + 27 files changed, 294 insertions(+), 9 deletions(-) diff --git a/ibm/acctest/acctest.go b/ibm/acctest/acctest.go index 0e065b0d6c..09ff740107 100644 --- a/ibm/acctest/acctest.go +++ b/ibm/acctest/acctest.go @@ -611,8 +611,8 @@ func init() { IsWinImage = os.Getenv("IS_WIN_IMAGE") if IsWinImage == "" { //IsWinImage = "a7a0626c-f97e-4180-afbe-0331ec62f32a" // classic windows machine: ibm-windows-server-2012-full-standard-amd64-1 - IsWinImage = "r006-5f9568ae-792e-47e1-a710-5538b2bdfca7" // next gen windows machine: ibm-windows-server-2012-full-standard-amd64-3 - fmt.Println("[INFO] Set the environment variable IS_WIN_IMAGE for testing ibm_is_instance data source else it is set to default value 'r006-5f9568ae-792e-47e1-a710-5538b2bdfca7'") + IsWinImage = "r006-d2e0d0e9-0a4f-4c45-afd7-cab787030776" // next gen windows machine: ibm-windows-server-2022-full-standard-amd64-8 + fmt.Println("[INFO] Set the environment variable IS_WIN_IMAGE for testing ibm_is_instance data source else it is set to default value 'r006-d2e0d0e9-0a4f-4c45-afd7-cab787030776'") } IsCosBucketName = os.Getenv("IS_COS_BUCKET_NAME") diff --git a/ibm/service/vpc/data_source_ibm_is_dedicated_host.go b/ibm/service/vpc/data_source_ibm_is_dedicated_host.go index 8ebf02565a..db563e252c 100644 --- a/ibm/service/vpc/data_source_ibm_is_dedicated_host.go +++ b/ibm/service/vpc/data_source_ibm_is_dedicated_host.go @@ -54,7 +54,12 @@ func DataSourceIbmIsDedicatedHost() *schema.Resource { Computed: true, Description: "The VCPU architecture.", }, - "count": { + "manufacturer": &schema.Schema{ + Type: schema.TypeString, + Computed: true, + Description: "The VCPU manufacturer.", + }, + "count": &schema.Schema{ Type: schema.TypeInt, Computed: true, Description: "The number of VCPUs assigned.", @@ -314,7 +319,12 @@ func DataSourceIbmIsDedicatedHost() *schema.Resource { Computed: true, Description: "The VCPU architecture.", }, - "count": { + "manufacturer": &schema.Schema{ + Type: schema.TypeString, + Computed: true, + Description: "The VCPU manufacturer.", + }, + "count": &schema.Schema{ Type: schema.TypeInt, Computed: true, Description: "The number of VCPUs assigned.", @@ -493,6 +503,10 @@ func dataSourceDedicatedHostAvailableVcpuToMap(availableVcpuItem vpcv1.Vcpu) (av if availableVcpuItem.Architecture != nil { availableVcpuMap["architecture"] = availableVcpuItem.Architecture } + // Added AMD Support for the manufacturer. + if availableVcpuItem.Manufacturer != nil { + availableVcpuMap["manufacturer"] = availableVcpuItem.Manufacturer + } if availableVcpuItem.Count != nil { availableVcpuMap["count"] = availableVcpuItem.Count } @@ -645,6 +659,10 @@ func dataSourceDedicatedHostVcpuToMap(vcpuItem vpcv1.Vcpu) (vcpuMap map[string]i if vcpuItem.Architecture != nil { vcpuMap["architecture"] = vcpuItem.Architecture } + // Added AMD Support for the manufacturer. + if vcpuItem.Manufacturer != nil { + vcpuMap["manufacturer"] = vcpuItem.Manufacturer + } if vcpuItem.Count != nil { vcpuMap["count"] = vcpuItem.Count } diff --git a/ibm/service/vpc/data_source_ibm_is_dedicated_host_profile.go b/ibm/service/vpc/data_source_ibm_is_dedicated_host_profile.go index 6adc3fadee..689919680e 100644 --- a/ibm/service/vpc/data_source_ibm_is_dedicated_host_profile.go +++ b/ibm/service/vpc/data_source_ibm_is_dedicated_host_profile.go @@ -302,6 +302,24 @@ func DataSourceIbmIsDedicatedHostProfile() *schema.Resource { }, }, }, + "vcpu_manufacturer": &schema.Schema{ + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + "type": &schema.Schema{ + Type: schema.TypeString, + Computed: true, + Description: "The type for this profile field.", + }, + "value": &schema.Schema{ + Type: schema.TypeString, + Computed: true, + Description: "The VCPU manufacturer for a dedicated host with this profile.", + }, + }, + }, + }, }, } } @@ -379,6 +397,14 @@ func dataSourceIbmIsDedicatedHostProfileRead(context context.Context, d *schema. } } + // Changes for the AMD Support, manufacturer information. + if dedicatedHostProfile.VcpuManufacturer != nil { + err = d.Set("vcpu_manufacturer", dataSourceDedicatedHostProfileFlattenVcpuManufacturer(*dedicatedHostProfile.VcpuManufacturer)) + if err != nil { + return diag.FromErr(fmt.Errorf("Error setting vcpu_architecture %s", err)) + } + } + return nil } @@ -502,6 +528,29 @@ func dataSourceDedicatedHostProfileVcpuArchitectureToMap(vcpuArchitectureItem vp return vcpuArchitectureMap } +// Changes for AMD Support, manufacturer details. +func dataSourceDedicatedHostProfileFlattenVcpuManufacturer(result vpcv1.DedicatedHostProfileVcpuManufacturer) (finalList []map[string]interface{}) { + finalList = []map[string]interface{}{} + finalMap := dataSourceDedicatedHostProfileVcpuManufacturerToMap(result) + finalList = append(finalList, finalMap) + + return finalList +} + +// AMD Support for manufacturer +func dataSourceDedicatedHostProfileVcpuManufacturerToMap(vcpuManufacturerItem vpcv1.DedicatedHostProfileVcpuManufacturer) (vcpuManufacturerMap map[string]interface{}) { + vcpuManufacturerMap = map[string]interface{}{} + + if vcpuManufacturerItem.Type != nil { + vcpuManufacturerMap["type"] = vcpuManufacturerItem.Type + } + if vcpuManufacturerItem.Value != nil { + vcpuManufacturerMap["value"] = vcpuManufacturerItem.Value + } + + return vcpuManufacturerMap +} + func dataSourceDedicatedHostProfileFlattenVcpuCount(result vpcv1.DedicatedHostProfileVcpu) (finalList []map[string]interface{}) { finalList = []map[string]interface{}{} finalMap := dataSourceDedicatedHostProfileVcpuCountToMap(result) diff --git a/ibm/service/vpc/data_source_ibm_is_dedicated_host_profile_test.go b/ibm/service/vpc/data_source_ibm_is_dedicated_host_profile_test.go index 2fbcd0a58d..fe617d6d7b 100644 --- a/ibm/service/vpc/data_source_ibm_is_dedicated_host_profile_test.go +++ b/ibm/service/vpc/data_source_ibm_is_dedicated_host_profile_test.go @@ -25,6 +25,7 @@ func TestAccIbmIsDedicatedHostProfileDataSourceBasic(t *testing.T) { resource.TestCheckResourceAttr(resName, "name", acc.DedicatedHostProfileName), resource.TestCheckResourceAttrSet(resName, "class"), resource.TestCheckResourceAttrSet(resName, "family"), + resource.TestCheckResourceAttrSet(resName, "vcpu_manufacturer.#"), ), }, }, diff --git a/ibm/service/vpc/data_source_ibm_is_dedicated_host_profiles.go b/ibm/service/vpc/data_source_ibm_is_dedicated_host_profiles.go index fee8a87832..32405f10c6 100644 --- a/ibm/service/vpc/data_source_ibm_is_dedicated_host_profiles.go +++ b/ibm/service/vpc/data_source_ibm_is_dedicated_host_profiles.go @@ -311,6 +311,25 @@ func DataSourceIbmIsDedicatedHostProfiles() *schema.Resource { }, }, }, + "vcpu_manufacturer": &schema.Schema{ + Type: schema.TypeList, + + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + "type": &schema.Schema{ + Type: schema.TypeString, + Computed: true, + Description: "The type for this profile field.", + }, + "value": &schema.Schema{ + Type: schema.TypeString, + Computed: true, + Description: "TThe VCPU manufacturer for a dedicated host with this profile.", + }, + }, + }, + }, }, }, }, @@ -467,6 +486,13 @@ func dataSourceDedicatedHostProfileCollectionProfilesToMap(profilesItem vpcv1.De vcpuCountList = append(vcpuCountList, vcpuCountMap) profilesMap["vcpu_count"] = vcpuCountList } + // AMD Support, changes for manufacturer details. + if profilesItem.VcpuManufacturer != nil { + vcpuManufacturerList := []map[string]interface{}{} + vcpuManufacturerMap := dataSourceDedicatedHostProfileCollectionProfilesVcpuManufacturerToMap(*profilesItem.VcpuManufacturer) + vcpuManufacturerList = append(vcpuManufacturerList, vcpuManufacturerMap) + profilesMap["vcpu_manufacturer"] = vcpuManufacturerList + } return profilesMap } @@ -553,6 +579,20 @@ func dataSourceDedicatedHostProfileCollectionProfilesVcpuArchitectureToMap(vcpuA return vcpuArchitectureMap } +// AMD Changes, manufacturer details added. +func dataSourceDedicatedHostProfileCollectionProfilesVcpuManufacturerToMap(vcpuManufacturerItem vpcv1.DedicatedHostProfileVcpuManufacturer) (vcpuManufacturerMap map[string]interface{}) { + vcpuManufacturerMap = map[string]interface{}{} + + if vcpuManufacturerItem.Type != nil { + vcpuManufacturerMap["type"] = vcpuManufacturerItem.Type + } + if vcpuManufacturerItem.Value != nil { + vcpuManufacturerMap["value"] = vcpuManufacturerItem.Value + } + + return vcpuManufacturerMap +} + func dataSourceDedicatedHostProfileCollectionProfilesVcpuCountToMap(vcpuCountItem vpcv1.DedicatedHostProfileVcpu) (vcpuCountMap map[string]interface{}) { vcpuCountMap = map[string]interface{}{} diff --git a/ibm/service/vpc/data_source_ibm_is_dedicated_host_profiles_test.go b/ibm/service/vpc/data_source_ibm_is_dedicated_host_profiles_test.go index 6711522935..34f58c9f72 100644 --- a/ibm/service/vpc/data_source_ibm_is_dedicated_host_profiles_test.go +++ b/ibm/service/vpc/data_source_ibm_is_dedicated_host_profiles_test.go @@ -25,6 +25,7 @@ func TestAccIbmIsDedicatedHostProfilesDataSourceBasic(t *testing.T) { resource.TestCheckResourceAttrSet(resName, "profiles.0.name"), resource.TestCheckResourceAttrSet(resName, "profiles.0.class"), resource.TestCheckResourceAttrSet(resName, "profiles.0.family"), + resource.TestCheckResourceAttrSet(resName, "profiles.0.vcpu_manufacturer.#"), ), }, }, diff --git a/ibm/service/vpc/data_source_ibm_is_dedicated_host_test.go b/ibm/service/vpc/data_source_ibm_is_dedicated_host_test.go index c77c1e6b5e..160d361e43 100644 --- a/ibm/service/vpc/data_source_ibm_is_dedicated_host_test.go +++ b/ibm/service/vpc/data_source_ibm_is_dedicated_host_test.go @@ -32,6 +32,7 @@ func TestAccIbmIsDedicatedHostDSBasic(t *testing.T) { resource.TestCheckResourceAttr(resName, "disks.#", "2"), resource.TestCheckResourceAttrSet(resName, "disks.0.name"), resource.TestCheckResourceAttrSet(resName, "disks.0.size"), + resource.TestCheckResourceAttrSet(resName, "vcpu.0.manufacturer"), ), }, }, diff --git a/ibm/service/vpc/data_source_ibm_is_dedicated_hosts.go b/ibm/service/vpc/data_source_ibm_is_dedicated_hosts.go index d0eeab8093..f775e26284 100644 --- a/ibm/service/vpc/data_source_ibm_is_dedicated_hosts.go +++ b/ibm/service/vpc/data_source_ibm_is_dedicated_hosts.go @@ -64,7 +64,12 @@ func DataSourceIbmIsDedicatedHosts() *schema.Resource { Computed: true, Description: "The VCPU architecture.", }, - "count": { + "manufacturer": &schema.Schema{ + Type: schema.TypeString, + Computed: true, + Description: "The VCPU manufacturer.", + }, + "count": &schema.Schema{ Type: schema.TypeInt, Computed: true, Description: "The number of VCPUs assigned.", @@ -344,7 +349,12 @@ func DataSourceIbmIsDedicatedHosts() *schema.Resource { Computed: true, Description: "The VCPU architecture.", }, - "count": { + "manufacturer": &schema.Schema{ + Type: schema.TypeString, + Computed: true, + Description: "The VCPU manufacturer.", + }, + "count": &schema.Schema{ Type: schema.TypeInt, Computed: true, Description: "The number of VCPUs assigned.", @@ -552,6 +562,10 @@ func dataSourceDedicatedHostCollectionDedicatedHostsAvailableVcpuToMap(available if availableVcpuItem.Architecture != nil { availableVcpuMap["architecture"] = availableVcpuItem.Architecture } + // Added AMD Support for the manufacturer. + if availableVcpuItem.Manufacturer != nil { + availableVcpuMap["manufacturer"] = availableVcpuItem.Manufacturer + } if availableVcpuItem.Count != nil { availableVcpuMap["count"] = availableVcpuItem.Count } @@ -664,6 +678,10 @@ func dataSourceDedicatedHostCollectionDedicatedHostsVcpuToMap(vcpuItem vpcv1.Vcp if vcpuItem.Architecture != nil { vcpuMap["architecture"] = vcpuItem.Architecture } + // Added AMD Support for the manufacturer. + if vcpuItem.Manufacturer != nil { + vcpuMap["manufacturer"] = vcpuItem.Manufacturer + } if vcpuItem.Count != nil { vcpuMap["count"] = vcpuItem.Count } diff --git a/ibm/service/vpc/data_source_ibm_is_dedicated_hosts_test.go b/ibm/service/vpc/data_source_ibm_is_dedicated_hosts_test.go index cc18c8a416..164f272725 100644 --- a/ibm/service/vpc/data_source_ibm_is_dedicated_hosts_test.go +++ b/ibm/service/vpc/data_source_ibm_is_dedicated_hosts_test.go @@ -42,6 +42,7 @@ func TestAccIbmIsDedicatedHostsDSBasic(t *testing.T) { resource.TestCheckResourceAttrSet(resName, "dedicated_hosts.0.memory"), resource.TestCheckResourceAttrSet(resName, "dedicated_hosts.0.host_group"), resource.TestCheckResourceAttrSet(resName, "dedicated_hosts.0.zone"), + resource.TestCheckResourceAttrSet(resName, "dedicated_hosts.0.vcpu.0.manufacturer"), ), }, }, diff --git a/ibm/service/vpc/data_source_ibm_is_instance.go b/ibm/service/vpc/data_source_ibm_is_instance.go index 18f9c7d999..755b83f7cb 100644 --- a/ibm/service/vpc/data_source_ibm_is_instance.go +++ b/ibm/service/vpc/data_source_ibm_is_instance.go @@ -485,6 +485,12 @@ func DataSourceIBMISInstance() *schema.Resource { Computed: true, Description: "Instance vCPU count", }, + // Added for AMD support, manufacturer details. + isInstanceCPUManufacturer: { + Type: schema.TypeString, + Computed: true, + Description: "Instance vCPU Manufacturer", + }, }, }, }, @@ -762,6 +768,7 @@ func instanceGetByName(d *schema.ResourceData, meta interface{}, name string) er currentCPU := map[string]interface{}{} currentCPU[isInstanceCPUArch] = *instance.Vcpu.Architecture currentCPU[isInstanceCPUCount] = *instance.Vcpu.Count + currentCPU[isInstanceCPUManufacturer] = *instance.Vcpu.Manufacturer // Added for AMD support, manufacturer details. cpuList = append(cpuList, currentCPU) } d.Set(isInstanceCPU, cpuList) diff --git a/ibm/service/vpc/data_source_ibm_is_instance_profile.go b/ibm/service/vpc/data_source_ibm_is_instance_profile.go index ef51ed51f5..24815b68dc 100644 --- a/ibm/service/vpc/data_source_ibm_is_instance_profile.go +++ b/ibm/service/vpc/data_source_ibm_is_instance_profile.go @@ -12,6 +12,8 @@ const ( isInstanceProfileName = "name" isInstanceProfileFamily = "family" isInstanceProfileArchitecture = "architecture" + isInstanceVCPUArchitecture = "vcpu_architecture" + isInstanceVCPUManufacturer = "vcpu_manufacturer" ) func DataSourceIBMISInstanceProfile() *schema.Resource { @@ -502,7 +504,7 @@ func DataSourceIBMISInstanceProfile() *schema.Resource { }, }, }, - "vcpu_architecture": { + isInstanceVCPUArchitecture: &schema.Schema{ Type: schema.TypeList, Computed: true, Elem: &schema.Resource{ @@ -525,7 +527,30 @@ func DataSourceIBMISInstanceProfile() *schema.Resource { }, }, }, - "vcpu_count": { + isInstanceVCPUManufacturer: &schema.Schema{ + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + "default": &schema.Schema{ + Type: schema.TypeString, + Computed: true, + Description: "The default VCPU manufacturer for an instance with this profile.", + }, + "type": &schema.Schema{ + Type: schema.TypeString, + Computed: true, + Description: "The type for this profile field.", + }, + "value": &schema.Schema{ + Type: schema.TypeString, + Computed: true, + Description: "The VCPU manufacturer for an instance with this profile.", + }, + }, + }, + }, + "vcpu_count": &schema.Schema{ Type: schema.TypeList, Computed: true, Elem: &schema.Resource{ @@ -679,7 +704,15 @@ func instanceProfileGet(d *schema.ResourceData, meta interface{}, name string) e } if profile.VcpuArchitecture != nil { - err = d.Set("vcpu_architecture", dataSourceInstanceProfileFlattenVcpuArchitecture(*profile.VcpuArchitecture)) + err = d.Set(isInstanceVCPUArchitecture, dataSourceInstanceProfileFlattenVcpuArchitecture(*profile.VcpuArchitecture)) + if err != nil { + return err + } + } + + // Manufacturer details added. + if profile.VcpuManufacturer != nil { + err = d.Set(isInstanceVCPUManufacturer, dataSourceInstanceProfileFlattenVcpuManufacture(*profile.VcpuManufacturer)) if err != nil { return err } @@ -948,6 +981,31 @@ func dataSourceInstanceProfileVcpuArchitectureToMap(vcpuArchitectureItem vpcv1.I return vcpuArchitectureMap } +/* Changes for the AMD Support VCPU Manufacturer */ +func dataSourceInstanceProfileFlattenVcpuManufacture(result vpcv1.InstanceProfileVcpuManufacturer) (fl []map[string]interface{}) { + fl = []map[string]interface{}{} + finalMap := dataSourceInstanceProfileVcpuManufacturerToMap(result) + fl = append(fl, finalMap) + + return fl +} + +func dataSourceInstanceProfileVcpuManufacturerToMap(vcpuManufacutererItem vpcv1.InstanceProfileVcpuManufacturer) (vcpuManufacturerMap map[string]interface{}) { + vcpuManufacturerMap = map[string]interface{}{} + + if vcpuManufacutererItem.Default != nil { + vcpuManufacturerMap["default"] = vcpuManufacutererItem.Default + } + if vcpuManufacutererItem.Type != nil { + vcpuManufacturerMap["type"] = vcpuManufacutererItem.Type + } + if vcpuManufacutererItem.Value != nil { + vcpuManufacturerMap["value"] = vcpuManufacutererItem.Value + } + + return vcpuManufacturerMap +} + func dataSourceInstanceProfileFlattenVcpuCount(result vpcv1.InstanceProfileVcpu) (finalList []map[string]interface{}) { finalList = []map[string]interface{}{} finalMap := dataSourceInstanceProfileVcpuCountToMap(result) diff --git a/ibm/service/vpc/data_source_ibm_is_instance_profile_test.go b/ibm/service/vpc/data_source_ibm_is_instance_profile_test.go index a2f2752232..21fa13546e 100644 --- a/ibm/service/vpc/data_source_ibm_is_instance_profile_test.go +++ b/ibm/service/vpc/data_source_ibm_is_instance_profile_test.go @@ -32,6 +32,9 @@ func TestAccIBMISInstanceProfileDataSource_basic(t *testing.T) { resource.TestCheckResourceAttrSet("data.ibm_is_instance_profile.test1", "port_speed.#"), resource.TestCheckResourceAttrSet("data.ibm_is_instance_profile.test1", "vcpu_architecture.#"), resource.TestCheckResourceAttrSet("data.ibm_is_instance_profile.test1", "vcpu_count.#"), + resource.TestCheckResourceAttrSet("data.ibm_is_instance_profile.test1", "vcpu_manufacturer.#"), + resource.TestCheckResourceAttrSet("data.ibm_is_instance_profile.test1", "vcpu_manufacturer.0.type"), + resource.TestCheckResourceAttrSet("data.ibm_is_instance_profile.test1", "vcpu_manufacturer.0.value"), resource.TestCheckResourceAttrSet("data.ibm_is_instance_profile.test1", "network_interface_count.0.type"), ), }, diff --git a/ibm/service/vpc/data_source_ibm_is_instance_profiles.go b/ibm/service/vpc/data_source_ibm_is_instance_profiles.go index a94982d976..6fc76a2cc4 100644 --- a/ibm/service/vpc/data_source_ibm_is_instance_profiles.go +++ b/ibm/service/vpc/data_source_ibm_is_instance_profiles.go @@ -574,6 +574,29 @@ func DataSourceIBMISInstanceProfiles() *schema.Resource { }, }, }, + "vcpu_manufacturer": &schema.Schema{ + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + "default": &schema.Schema{ + Type: schema.TypeString, + Computed: true, + Description: "The default VCPU manufacturer for an instance with this profile.", + }, + "type": &schema.Schema{ + Type: schema.TypeString, + Computed: true, + Description: "The type for this profile field.", + }, + "value": &schema.Schema{ + Type: schema.TypeString, + Computed: true, + Description: "The VCPU manufacturer for an instance with this profile.", + }, + }, + }, + }, }, }, }, @@ -684,6 +707,15 @@ func instanceProfilesList(d *schema.ResourceData, meta interface{}) error { vcpuCountList = append(vcpuCountList, vcpuCountMap) l["vcpu_count"] = vcpuCountList } + // Changes for manufacturer for AMD Support. + // reduce the line of code here. - sumit's suggestions + if profile.VcpuManufacturer != nil { + vcpuManufacturerList := []map[string]interface{}{} + vcpuManufacturerMap := dataSourceInstanceProfileVcpuManufacturerToMap(*profile.VcpuManufacturer) + vcpuManufacturerList = append(vcpuManufacturerList, vcpuManufacturerMap) + l["vcpu_manufacturer"] = vcpuManufacturerList + } + if profile.Disks != nil { l[isInstanceDisks] = dataSourceInstanceProfileFlattenDisks(profile.Disks) if err != nil { diff --git a/ibm/service/vpc/data_source_ibm_is_instance_profiles_test.go b/ibm/service/vpc/data_source_ibm_is_instance_profiles_test.go index fea86c3e30..5984669fbb 100644 --- a/ibm/service/vpc/data_source_ibm_is_instance_profiles_test.go +++ b/ibm/service/vpc/data_source_ibm_is_instance_profiles_test.go @@ -34,6 +34,9 @@ func TestAccIBMISInstanceProfilesDataSource_basic(t *testing.T) { resource.TestCheckResourceAttrSet("data.ibm_is_instance_profiles.test1", "profiles.0.vcpu_count.#"), resource.TestCheckResourceAttrSet("data.ibm_is_instance_profiles.test1", "profiles.0.network_interface_count.#"), resource.TestCheckResourceAttrSet("data.ibm_is_instance_profiles.test1", "profiles.0.network_interface_count.0.type"), + resource.TestCheckResourceAttrSet("data.ibm_is_instance_profiles.test1", "profiles.0.vcpu_manufacturer.#"), + resource.TestCheckResourceAttrSet("data.ibm_is_instance_profiles.test1", "profiles.0.vcpu_manufacturer.0.type"), + resource.TestCheckResourceAttrSet("data.ibm_is_instance_profiles.test1", "profiles.0.vcpu_manufacturer.0.value"), ), }, }, diff --git a/ibm/service/vpc/data_source_ibm_is_instance_test.go b/ibm/service/vpc/data_source_ibm_is_instance_test.go index 7ce0fcc9f5..13f8bf20a8 100644 --- a/ibm/service/vpc/data_source_ibm_is_instance_test.go +++ b/ibm/service/vpc/data_source_ibm_is_instance_test.go @@ -41,6 +41,10 @@ func TestAccIBMISInstanceDataSource_basic(t *testing.T) { resName, "lifecycle_state"), resource.TestCheckResourceAttr( resName, "lifecycle_reasons.#", "0"), + resource.TestCheckResourceAttrSet( + resName, "vcpu.#"), + resource.TestCheckResourceAttrSet( + resName, "vcpu.0.manufacturer"), ), }, }, diff --git a/ibm/service/vpc/data_source_ibm_is_instances.go b/ibm/service/vpc/data_source_ibm_is_instances.go index 414748d1db..cb5d92ac4d 100644 --- a/ibm/service/vpc/data_source_ibm_is_instances.go +++ b/ibm/service/vpc/data_source_ibm_is_instances.go @@ -558,6 +558,11 @@ func DataSourceIBMISInstances() *schema.Resource { Computed: true, Description: "Instance vcpu count", }, + "manufacturer": { + Type: schema.TypeString, + Computed: true, + Description: "Instance vcpu manufacturer", + }, }, }, }, @@ -1049,6 +1054,7 @@ func instancesList(d *schema.ResourceData, meta interface{}) error { currentCPU := map[string]interface{}{} currentCPU["architecture"] = *instance.Vcpu.Architecture currentCPU["count"] = *instance.Vcpu.Count + currentCPU["manufacturer"] = *instance.Vcpu.Manufacturer cpuList = append(cpuList, currentCPU) } l["vcpu"] = cpuList diff --git a/ibm/service/vpc/data_source_ibm_is_instances_test.go b/ibm/service/vpc/data_source_ibm_is_instances_test.go index 886e31920a..feb540be9d 100644 --- a/ibm/service/vpc/data_source_ibm_is_instances_test.go +++ b/ibm/service/vpc/data_source_ibm_is_instances_test.go @@ -57,6 +57,7 @@ ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCKVmnMOlHKcZK8tpt3MP1lqOLAcqcJzhsvJcjscgVE resource.TestCheckResourceAttrSet(resName, "instances.0.availability_policy_host_failure"), resource.TestCheckResourceAttrSet(resName, "instances.0.lifecycle_state"), resource.TestCheckResourceAttr(resName, "instances.0.lifecycle_reasons.#", "0"), + resource.TestCheckResourceAttrSet(resName, "instances.0.vcpu.0.manufacturer"), ), }, }, diff --git a/ibm/service/vpc/resource_ibm_is_instance.go b/ibm/service/vpc/resource_ibm_is_instance.go index 45c07e3610..1f82d0249d 100644 --- a/ibm/service/vpc/resource_ibm_is_instance.go +++ b/ibm/service/vpc/resource_ibm_is_instance.go @@ -55,6 +55,7 @@ const ( isInstanceCPUArch = "architecture" isInstanceCPUCores = "cores" isInstanceCPUCount = "count" + isInstanceCPUManufacturer = "manufacturer" isInstanceGpu = "gpu" isInstanceGpuCores = "cores" isInstanceGpuCount = "count" @@ -719,6 +720,11 @@ func ResourceIBMISInstance() *schema.Resource { Type: schema.TypeInt, Computed: true, }, + isInstanceCPUManufacturer: { + Type: schema.TypeString, + Computed: true, + Description: "The VCPU manufacturer", + }, }, }, }, @@ -3137,6 +3143,7 @@ func instanceGet(d *schema.ResourceData, meta interface{}, id string) error { currentCPU := map[string]interface{}{} currentCPU[isInstanceCPUArch] = *instance.Vcpu.Architecture currentCPU[isInstanceCPUCount] = *instance.Vcpu.Count + currentCPU[isInstanceCPUManufacturer] = instance.Vcpu.Manufacturer cpuList = append(cpuList, currentCPU) } d.Set(isInstanceCPU, cpuList) diff --git a/ibm/service/vpc/resource_ibm_is_instance_test.go b/ibm/service/vpc/resource_ibm_is_instance_test.go index 2f157a64a3..6e6dfc69aa 100644 --- a/ibm/service/vpc/resource_ibm_is_instance_test.go +++ b/ibm/service/vpc/resource_ibm_is_instance_test.go @@ -46,6 +46,10 @@ ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCKVmnMOlHKcZK8tpt3MP1lqOLAcqcJzhsvJcjscgVE "ibm_is_instance.testacc_instance", "user_data", userData1), resource.TestCheckResourceAttr( "ibm_is_instance.testacc_instance", "zone", acc.ISZoneName), + resource.TestCheckResourceAttrSet( + "ibm_is_instance.testacc_instance", "vcpu.#"), + resource.TestCheckResourceAttrSet( + "ibm_is_instance.testacc_instance", "vcpu.0.manufacturer"), ), }, { @@ -60,6 +64,10 @@ ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCKVmnMOlHKcZK8tpt3MP1lqOLAcqcJzhsvJcjscgVE "ibm_is_instance.testacc_instance", "zone", acc.ISZoneName), resource.TestCheckResourceAttrSet( "ibm_is_instance.testacc_instance", "primary_network_interface.0.port_speed"), + resource.TestCheckResourceAttrSet( + "ibm_is_instance.testacc_instance", "vcpu.#"), + resource.TestCheckResourceAttrSet( + "ibm_is_instance.testacc_instance", "vcpu.0.manufacturer"), ), }, }, diff --git a/website/docs/d/is_dedicated_host.html.markdown b/website/docs/d/is_dedicated_host.html.markdown index ca0f21cbe9..b6a1750efa 100644 --- a/website/docs/d/is_dedicated_host.html.markdown +++ b/website/docs/d/is_dedicated_host.html.markdown @@ -47,6 +47,7 @@ In addition to all argument reference list, you can access the following attribu Nested scheme for `available_vcpu`: - `architecture` - (String) The `VCPU` architecture. + - `manufacturer` - (String) The `VCPU` manufacturer. - `count` - (String) The number of `VCPUs` assigned. - `created_at` - (String) The date and time that the dedicated host was created. - `crn` - (String) The CRN for this dedicated host. @@ -112,5 +113,6 @@ In addition to all argument reference list, you can access the following attribu Nested scheme for `vcpu`: - `architecture` - (String) The `VCPU` architecture. + - `manufacturer` - (String) The `VCPU` manufacturer. - `count` - (String) The number of `VCPUs` assigned. - `zone` - (String) The globally unique name of the zone this dedicated host resides in. diff --git a/website/docs/d/is_dedicated_host_profile.html.markdown b/website/docs/d/is_dedicated_host_profile.html.markdown index fa1fbb2498..c6303b20f0 100644 --- a/website/docs/d/is_dedicated_host_profile.html.markdown +++ b/website/docs/d/is_dedicated_host_profile.html.markdown @@ -105,3 +105,8 @@ In addition to all argument reference list, you can access the following attribu - `type`- (String) The type for this profile field. - `value`- (String) The value for this profile field. - `values`- (String) The permitted values for this profile field. +- `vcpu_manufacturer`- (List) Nested `vcpu_manufacturer` blocks have the following structure. + + Nested scheme for `vcpu_manufacturer`: + - `type`- (String) The type for this profile field. + - `value`- (String) The `VCPU` manufacturer for a dedicated host with this profile. diff --git a/website/docs/d/is_dedicated_host_profiles.html.markdown b/website/docs/d/is_dedicated_host_profiles.html.markdown index 5d251a7c02..d058e79684 100644 --- a/website/docs/d/is_dedicated_host_profiles.html.markdown +++ b/website/docs/d/is_dedicated_host_profiles.html.markdown @@ -101,5 +101,10 @@ Review the argument references that you can specify for your data source. - `type` - (String) The type for this profile field. - `value` - (String) The value for this profile field. - `values` - (String) The permitted values for this profile field. + - `vcpu_manufacturer` - (List) Nested `vcpu_manufacturer` blocks have the following structure: + + Nested scheme for `vcpu_manufacturer`: + - `type` - (String) The type for this profile field. + - `value` - (String) The VCPU manufacturer for a dedicated host with this profile. - `total_count` - (String) The total number of resources across all pages. diff --git a/website/docs/d/is_instance.html.markdown b/website/docs/d/is_instance.html.markdown index 1ddb6f3436..eef79787eb 100644 --- a/website/docs/d/is_instance.html.markdown +++ b/website/docs/d/is_instance.html.markdown @@ -215,6 +215,7 @@ In addition to all argument reference list, you can access the following attribu Nested scheme for `vcpu`: - `architecture` - (String) The architecture of the virtual CPU. + - `manufacturer` - (String) The manufacturer of the virtual CPU. - `count`- (Integer) The number of virtual CPUs that are allocated to the instance. - `volume_attachments`- (List) A list of volume attachments that were created for the instance. diff --git a/website/docs/d/is_instance_profile.html.markdown b/website/docs/d/is_instance_profile.html.markdown index c13a7c9fc8..3350195366 100644 --- a/website/docs/d/is_instance_profile.html.markdown +++ b/website/docs/d/is_instance_profile.html.markdown @@ -154,3 +154,9 @@ In addition to the argument reference list, you can access the following attribu - `type` - (String) The type for this profile field. - `value` - (String) The value for this profile field. - `values` - (String) The permitted values for this profile field. +- `vcpu_manufacturer` - (List) Nested `vcpu_manufacturer` blocks have the following structure: + + Nested scheme for `vcpu_manufacturer`: + - `default` - (String) The default VCPU manufacturer for an instance with this profile. + - `type` - (String) The type for this profile field. + - `value` - (String) The VCPU manufacturer for an instance with this profile. diff --git a/website/docs/d/is_instance_profiles.html.markdown b/website/docs/d/is_instance_profiles.html.markdown index 21fd659699..2b0a8ba980 100644 --- a/website/docs/d/is_instance_profiles.html.markdown +++ b/website/docs/d/is_instance_profiles.html.markdown @@ -156,3 +156,9 @@ You can access the following attribute references after your data source is crea - `type` - (String) The type for this profile field. - `value` - (String) The value for this profile field. - `values` - (String) The permitted values for this profile field. + - `vcpu_manufacturer` - (List) Nested `vcpu_manufacturer` blocks have the following structure: + + Nested scheme for `vcpu_manufacturer`: + - `default` - (String) The default VCPU manufacturer for an instance with this profile. + - `type` - (String) The type for this profile field. + - `value` - (String) The VCPU manufacturer for an instance with this profile. \ No newline at end of file diff --git a/website/docs/d/is_instances.html.markdown b/website/docs/d/is_instances.html.markdown index 0559a69e67..94a14a428d 100644 --- a/website/docs/d/is_instances.html.markdown +++ b/website/docs/d/is_instances.html.markdown @@ -176,6 +176,7 @@ In addition to all argument reference list, you can access the following attribu Nested scheme for `vcpu`: - `architecture` - (String) The architecture of the virtual CPU. + - `manufacturer` - (String) The manufacturer of the virtual CPU. - `count`- (Integer) The number of virtual CPUs that are allocated to the instance. - `vpc` - (String) The ID of the VPC that the instance belongs to. - `zone` - (String) The zone where the instance was created. diff --git a/website/docs/r/is_instance.html.markdown b/website/docs/r/is_instance.html.markdown index d5d030ff37..c1cddb8107 100644 --- a/website/docs/r/is_instance.html.markdown +++ b/website/docs/r/is_instance.html.markdown @@ -633,6 +633,7 @@ In addition to all argument reference list, you can access the following attribu Nested scheme for `vcpu`: - `architecture` - (String) The architecture of the CPU. - `count`- (Integer) The number of virtual CPUS that are assigned to the instance. + - `manufacturer`- (String) The VCPU manufacturer. ## Import