From 9da04367f88cbcd230f4e3b3a11f43802aa4e3ad Mon Sep 17 00:00:00 2001
From: zhukun <2019229048@tju.edu.cn>
Date: Mon, 20 Nov 2023 17:37:19 +0800
Subject: [PATCH] feat(elb): import elb 10sp2 resource, unit teset and docs
---
docs/data-sources/lb_certificate_v2.md | 34 +++--
docs/data-sources/lb_certificates_v2.md | 44 ++++++
docs/data-sources/lb_listeners_v2.md | 72 +++++++++
docs/resources/lb_logtank_v3.md | 49 ++++++
...e_flexibleengine_lb_certificate_v2_test.go | 104 +++++++++++++
...rce_flexibleengine_lb_listeners_v2_test.go | 139 ++++++++++++++++++
...ource_flexibleengine_lb_logtank_v3_test.go | 129 ++++++++++++++++
flexibleengine/provider.go | 22 +--
8 files changed, 567 insertions(+), 26 deletions(-)
create mode 100644 docs/data-sources/lb_certificates_v2.md
create mode 100644 docs/data-sources/lb_listeners_v2.md
create mode 100644 docs/resources/lb_logtank_v3.md
create mode 100644 flexibleengine/acceptance/data_source_flexibleengine_lb_certificate_v2_test.go
create mode 100644 flexibleengine/acceptance/data_source_flexibleengine_lb_listeners_v2_test.go
create mode 100644 flexibleengine/acceptance/resource_flexibleengine_lb_logtank_v3_test.go
diff --git a/docs/data-sources/lb_certificate_v2.md b/docs/data-sources/lb_certificate_v2.md
index 3313c124..8cef9c85 100644
--- a/docs/data-sources/lb_certificate_v2.md
+++ b/docs/data-sources/lb_certificate_v2.md
@@ -4,41 +4,43 @@ subcategory: "Elastic Load Balance (ELB)"
# flexibleengine_lb_certificate_v2
-flexibleengine_lb_certificate_v2 provides details about a specific Certificate.
+Use this data source to get the certificates in FlexibleEngine Elastic Load Balance (ELB).
## Example Usage
-The following example shows how one might accept a certificate name as a variable to fetch this data source.
-
```hcl
-variable "cert_name" {}
+variable "certificate_name" {}
-data "flexibleengine_lb_certificate_v2" "by_name" {
- name = var.cert_name
+data "flexibleengine_lb_certificate_v2" "test" {
+ name = var.certificate_name
+ type = "server"
}
```
## Argument Reference
-The arguments of this data source act as filters for querying the available Certificates in the current region.
-The given filters must match exactly one Certificate whose data will be exported as attributes.
+The following arguments are supported:
-* `id` - (Optional, String) The id of the specific Certificate to retrieve.
+* `region` - (Optional, String) The region in which to obtain the ELB certificate. If omitted, the provider-level region
+ will be used.
-* `name` - (Optional, String) Human-readable name for the Certificate. Does not have to be unique.
+* `type` - (Optional, String) Specifies the certificate type. The default value is `server`. The value can be one of the
+ following:
+ + `server`: indicates the server certificate.
+ + `client`: indicates the CA certificate.
-* `description` - (Optional, String) Human-readable description for the Certificate.
+* `name` - (Required, String) The name of certificate. The value is case sensitive and does not supports fuzzy matching.
-* `domain` - (Optional, String) The domain of the Certificate.
+ -> **NOTE:** The certificate name is not unique. Only returns the last created one when matched multiple certificates.
## Attribute Reference
In addition to all arguments above, the following attributes are exported:
-* `private_key` - The private encrypted key of the Certificate, PEM format.
+* `id` - The certificate ID in UUID format.
-* `certificate` - The public encrypted key of the Certificate, PEM format.
+* `domain` - The domain of the Certificate. This parameter is valid only when `type` is "server".
-* `update_time` - Indicates the update time.
+* `description` - Human-readable description for the Certificate.
-* `create_time` - Indicates the creation time.
+* `expiration` - Indicates the time when the certificate expires.
diff --git a/docs/data-sources/lb_certificates_v2.md b/docs/data-sources/lb_certificates_v2.md
new file mode 100644
index 00000000..3313c124
--- /dev/null
+++ b/docs/data-sources/lb_certificates_v2.md
@@ -0,0 +1,44 @@
+---
+subcategory: "Elastic Load Balance (ELB)"
+---
+
+# flexibleengine_lb_certificate_v2
+
+flexibleengine_lb_certificate_v2 provides details about a specific Certificate.
+
+## Example Usage
+
+The following example shows how one might accept a certificate name as a variable to fetch this data source.
+
+```hcl
+variable "cert_name" {}
+
+data "flexibleengine_lb_certificate_v2" "by_name" {
+ name = var.cert_name
+}
+```
+
+## Argument Reference
+
+The arguments of this data source act as filters for querying the available Certificates in the current region.
+The given filters must match exactly one Certificate whose data will be exported as attributes.
+
+* `id` - (Optional, String) The id of the specific Certificate to retrieve.
+
+* `name` - (Optional, String) Human-readable name for the Certificate. Does not have to be unique.
+
+* `description` - (Optional, String) Human-readable description for the Certificate.
+
+* `domain` - (Optional, String) The domain of the Certificate.
+
+## Attribute Reference
+
+In addition to all arguments above, the following attributes are exported:
+
+* `private_key` - The private encrypted key of the Certificate, PEM format.
+
+* `certificate` - The public encrypted key of the Certificate, PEM format.
+
+* `update_time` - Indicates the update time.
+
+* `create_time` - Indicates the creation time.
diff --git a/docs/data-sources/lb_listeners_v2.md b/docs/data-sources/lb_listeners_v2.md
new file mode 100644
index 00000000..9dfb8715
--- /dev/null
+++ b/docs/data-sources/lb_listeners_v2.md
@@ -0,0 +1,72 @@
+---
+subcategory: "Elastic Load Balance (ELB)"
+---
+
+# flexibleengine_lb_listeners_v2
+
+Use this data source to query the list of ELB listeners.
+
+## Example Usage
+
+```hcl
+variable "protocol" {}
+
+data "flexibleengine_lb_listeners_v2" "test" {
+ protocol = var.protocol
+}
+```
+
+## Argument Reference
+
+The following arguments are supported:
+
+* `region` - (Optional, String) Specifies the region in which to query the data source.
+ If omitted, the provider-level region will be used.
+
+* `name` - (Optional, String) The listener name.
+
+* `protocol` - (Optional, String) The listener protocol.
+ The valid values are **TCP**, **UDP**, **HTTP** and **TERMINATED_HTTPS**.
+
+* `protocol_port` - (Optional, String) The front-end listening port of the listener.
+ The valid value is range from `1` to `65535`.
+
+## Attribute Reference
+
+In addition to all arguments above, the following attributes are exported:
+
+* `id` - The resource ID.
+
+* `listeners` - Listener list.
+The [listeners](#listeners_listeners) structure is documented below.
+
+
+The `listeners` block supports:
+
+* `id` - The ELB listener ID.
+
+* `name` - The listener name.
+
+* `protocol` - The listener protocol.
+
+* `protocol_port` - The front-end listening port of the listener.
+
+* `default_pool_id` - The ID of the default pool with which the ELB listener is associated.
+
+* `description` - The description of the ELB listener.
+
+* `connection_limit` - The maximum number of connections allowed for the listener.
+
+* `http2_enable` - Whether the ELB listener uses HTTP/2.
+
+* `default_tls_container_ref` - The ID of the server certificate used by the listener.
+
+* `sni_container_refs` - List of the SNI certificate (server certificates with a domain name) IDs used by the listener.
+
+* `loadbalancers` - Listener list.
+The [loadbalancers](#listeners_loadbalancers) structure is documented below.
+
+
+The `loadbalancers` block supports:
+
+* `id` - The ELB loadbalancer ID.
diff --git a/docs/resources/lb_logtank_v3.md b/docs/resources/lb_logtank_v3.md
new file mode 100644
index 00000000..01e44878
--- /dev/null
+++ b/docs/resources/lb_logtank_v3.md
@@ -0,0 +1,49 @@
+---
+subcategory: "Dedicated Load Balance (Dedicated ELB)"
+---
+
+# flexibleengine_lb_logtank_v3
+
+Manage an LB logtank resource within FlexibleEngine.
+
+## Example Usage
+
+```hcl
+variable "loadbalancer_id" {}
+variable "group_id" {}
+variable "topic_id" {}
+
+resource "flexibleengine_lb_logtank_v3" "test" {
+ loadbalancer_id = var.loadbalancer_id
+ log_group_id = var.group_id
+ log_topic_id = var.topic_id
+}
+```
+
+## Argument Reference
+
+The following arguments are supported:
+
+* `region` - (Optional, String, ForceNew) The region in which to create the logtank resource.
+ If omitted, the provider-level region will be used. Changing this creates a new logtank.
+
+* `loadbalancer_id` - (Required, String, ForceNew) Specifies the ID of a loadbalancer. Changing this
+ creates a new logtank.
+
+* `log_group_id` - (Required, String) Specifies the ID of a log group. It is provided by other service.
+
+* `log_topic_id` - (Required, String) Specifies the ID of the subscribe topic.
+
+## Attribute Reference
+
+In addition to all arguments above, the following attributes are exported:
+
+* `id` - The logtank ID.
+
+## Import
+
+LB logtank can be imported using the logtank ID, e.g.
+
+```bash
+terraform import flexibleengine_lb_logtank_v3.test 2f148a75-acd3-4ce7-8f63-d5c9fadab3a0
+```
diff --git a/flexibleengine/acceptance/data_source_flexibleengine_lb_certificate_v2_test.go b/flexibleengine/acceptance/data_source_flexibleengine_lb_certificate_v2_test.go
new file mode 100644
index 00000000..8df150a8
--- /dev/null
+++ b/flexibleengine/acceptance/data_source_flexibleengine_lb_certificate_v2_test.go
@@ -0,0 +1,104 @@
+package acceptance
+
+import (
+ "fmt"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-sdk/v2/helper/acctest"
+ "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource"
+ "github.com/huaweicloud/terraform-provider-huaweicloud/huaweicloud/services/acceptance"
+)
+
+func TestAccDataSourceLBCertificateV2_basic(t *testing.T) {
+ name := fmt.Sprintf("cert-%s", acctest.RandString(6))
+ dataSourceName := "data.flexibleengine_lb_certificate_v2.cert_1"
+ dc := acceptance.InitDataSourceCheck(dataSourceName)
+
+ resource.Test(t, resource.TestCase{
+ PreCheck: func() { testAccPreCheck(t) },
+ ProviderFactories: TestAccProviderFactories,
+ Steps: []resource.TestStep{
+ {
+ Config: testAccLBCertificateSourceV2_conf(name),
+ Check: resource.ComposeTestCheckFunc(
+ dc.CheckResourceExists(),
+ resource.TestCheckResourceAttr(dataSourceName, "name", name),
+ resource.TestCheckResourceAttr(dataSourceName, "type", "server"),
+ resource.TestCheckResourceAttrSet(dataSourceName, "domain"),
+ resource.TestCheckResourceAttrSet(dataSourceName, "description"),
+ ),
+ },
+ },
+ })
+}
+
+func testAccLBCertificateSourceV2_conf(name string) string {
+ return fmt.Sprintf(`
+data "flexibleengine_lb_certificate_v2" "cert_1" {
+ name = flexibleengine_elb_certificate.certificate_1.name
+
+ depends_on = [flexibleengine_elb_certificate.certificate_1]
+}
+
+resource "flexibleengine_elb_certificate" "certificate_1" {
+ name = "%s"
+ description = "terraform test certificate"
+ domain = "www.elb.com"
+ type = "server"
+ private_key = <