From 2bb6fc980af0ff574b33952881663b8b1651b847 Mon Sep 17 00:00:00 2001 From: Mariana Dima Date: Tue, 31 Mar 2020 10:40:37 +0200 Subject: [PATCH] Move Metricbeat azure module to GA and add final tests (#17319) * temp * add tests and move to GA * changelog * fix --- CHANGELOG.next.asciidoc | 1 + metricbeat/docs/modules/azure.asciidoc | 2 - .../docs/modules/azure/compute_vm.asciidoc | 2 - .../azure/compute_vm_scaleset.asciidoc | 2 - .../modules/azure/container_instance.asciidoc | 2 - .../modules/azure/container_registry.asciidoc | 2 - .../modules/azure/container_service.asciidoc | 2 - .../modules/azure/database_account.asciidoc | 2 - .../docs/modules/azure/monitor.asciidoc | 2 - .../docs/modules/azure/storage.asciidoc | 2 - metricbeat/docs/modules_list.asciidoc | 18 ++--- .../metricbeat/module/azure/_meta/fields.yml | 2 +- x-pack/metricbeat/module/azure/azure.go | 3 - .../module/azure/compute_vm/_meta/fields.yml | 2 +- .../compute_vm/compute_vm_integration_test.go | 2 + .../compute_vm_scaleset/_meta/fields.yml | 2 +- .../compute_vm_scaleset_integration_test.go | 1 + .../azure/container_instance/_meta/fields.yml | 2 +- .../container_instance_integration_test.go | 1 + .../azure/container_registry/_meta/fields.yml | 2 +- .../container_registry_integration_test.go | 1 + .../azure/container_service/_meta/fields.yml | 2 +- .../container_service_integration_test.go | 1 + .../azure/database_account/_meta/fields.yml | 2 +- .../database_account_integration_test.go | 1 + x-pack/metricbeat/module/azure/fields.go | 2 +- .../module/azure/monitor/_meta/fields.yml | 2 +- .../azure/monitor/monitor_integration_test.go | 1 + .../module/azure/storage/_meta/fields.yml | 2 +- .../azure/storage/storage_integration_test.go | 1 + .../module/azure/test/integration.go | 70 +++++++++++++++++++ 31 files changed, 99 insertions(+), 40 deletions(-) diff --git a/CHANGELOG.next.asciidoc b/CHANGELOG.next.asciidoc index 36a2ef964321..c3356cbc880c 100644 --- a/CHANGELOG.next.asciidoc +++ b/CHANGELOG.next.asciidoc @@ -281,6 +281,7 @@ https://github.com/elastic/beats/compare/v7.0.0-alpha2...master[Check the HEAD d - Release vsphere module as GA. {issue}15798[15798] {pull}17119[17119] - Add Storage metricsets to GCP module {pull}15598[15598] - Added documentation for running Metricbeat in Cloud Foundry. {pull}17275[17275] +- Add final tests and move label to GA for the azure module in metricbeat. {pull}17319[17319] *Packetbeat* diff --git a/metricbeat/docs/modules/azure.asciidoc b/metricbeat/docs/modules/azure.asciidoc index a19996d7c2a8..e02484698a17 100644 --- a/metricbeat/docs/modules/azure.asciidoc +++ b/metricbeat/docs/modules/azure.asciidoc @@ -6,8 +6,6 @@ This file is generated! See scripts/mage/docs_collector.go [role="xpack"] == azure module -beta[] - This is the azure module. The Azure Monitor feature collects and aggregates logs and metrics from a variety of sources into a common data platform where it can be used for analysis, visualization, and alerting. diff --git a/metricbeat/docs/modules/azure/compute_vm.asciidoc b/metricbeat/docs/modules/azure/compute_vm.asciidoc index 39d3be6eae09..2cf7e6050e78 100644 --- a/metricbeat/docs/modules/azure/compute_vm.asciidoc +++ b/metricbeat/docs/modules/azure/compute_vm.asciidoc @@ -5,8 +5,6 @@ This file is generated! See scripts/mage/docs_collector.go [[metricbeat-metricset-azure-compute_vm]] === azure compute_vm metricset -beta[] - include::../../../../x-pack/metricbeat/module/azure/compute_vm/_meta/docs.asciidoc[] diff --git a/metricbeat/docs/modules/azure/compute_vm_scaleset.asciidoc b/metricbeat/docs/modules/azure/compute_vm_scaleset.asciidoc index 0bc72248c53c..7433ba21d633 100644 --- a/metricbeat/docs/modules/azure/compute_vm_scaleset.asciidoc +++ b/metricbeat/docs/modules/azure/compute_vm_scaleset.asciidoc @@ -5,8 +5,6 @@ This file is generated! See scripts/mage/docs_collector.go [[metricbeat-metricset-azure-compute_vm_scaleset]] === azure compute_vm_scaleset metricset -beta[] - include::../../../../x-pack/metricbeat/module/azure/compute_vm_scaleset/_meta/docs.asciidoc[] diff --git a/metricbeat/docs/modules/azure/container_instance.asciidoc b/metricbeat/docs/modules/azure/container_instance.asciidoc index 88f1959637d0..5805cb35aacb 100644 --- a/metricbeat/docs/modules/azure/container_instance.asciidoc +++ b/metricbeat/docs/modules/azure/container_instance.asciidoc @@ -5,8 +5,6 @@ This file is generated! See scripts/mage/docs_collector.go [[metricbeat-metricset-azure-container_instance]] === azure container_instance metricset -beta[] - include::../../../../x-pack/metricbeat/module/azure/container_instance/_meta/docs.asciidoc[] This is a default metricset. If the host module is unconfigured, this metricset is enabled by default. diff --git a/metricbeat/docs/modules/azure/container_registry.asciidoc b/metricbeat/docs/modules/azure/container_registry.asciidoc index 67ff888d807f..4c5e936f965d 100644 --- a/metricbeat/docs/modules/azure/container_registry.asciidoc +++ b/metricbeat/docs/modules/azure/container_registry.asciidoc @@ -5,8 +5,6 @@ This file is generated! See scripts/mage/docs_collector.go [[metricbeat-metricset-azure-container_registry]] === azure container_registry metricset -beta[] - include::../../../../x-pack/metricbeat/module/azure/container_registry/_meta/docs.asciidoc[] This is a default metricset. If the host module is unconfigured, this metricset is enabled by default. diff --git a/metricbeat/docs/modules/azure/container_service.asciidoc b/metricbeat/docs/modules/azure/container_service.asciidoc index 2aed94c77493..49f558194484 100644 --- a/metricbeat/docs/modules/azure/container_service.asciidoc +++ b/metricbeat/docs/modules/azure/container_service.asciidoc @@ -5,8 +5,6 @@ This file is generated! See scripts/mage/docs_collector.go [[metricbeat-metricset-azure-container_service]] === azure container_service metricset -beta[] - include::../../../../x-pack/metricbeat/module/azure/container_service/_meta/docs.asciidoc[] This is a default metricset. If the host module is unconfigured, this metricset is enabled by default. diff --git a/metricbeat/docs/modules/azure/database_account.asciidoc b/metricbeat/docs/modules/azure/database_account.asciidoc index 1d08d27a335d..8d28d132fd43 100644 --- a/metricbeat/docs/modules/azure/database_account.asciidoc +++ b/metricbeat/docs/modules/azure/database_account.asciidoc @@ -5,8 +5,6 @@ This file is generated! See scripts/mage/docs_collector.go [[metricbeat-metricset-azure-database_account]] === azure database_account metricset -beta[] - include::../../../../x-pack/metricbeat/module/azure/database_account/_meta/docs.asciidoc[] This is a default metricset. If the host module is unconfigured, this metricset is enabled by default. diff --git a/metricbeat/docs/modules/azure/monitor.asciidoc b/metricbeat/docs/modules/azure/monitor.asciidoc index 1596987e18ec..726562c0ca77 100644 --- a/metricbeat/docs/modules/azure/monitor.asciidoc +++ b/metricbeat/docs/modules/azure/monitor.asciidoc @@ -5,8 +5,6 @@ This file is generated! See scripts/mage/docs_collector.go [[metricbeat-metricset-azure-monitor]] === azure monitor metricset -beta[] - include::../../../../x-pack/metricbeat/module/azure/monitor/_meta/docs.asciidoc[] This is a default metricset. If the host module is unconfigured, this metricset is enabled by default. diff --git a/metricbeat/docs/modules/azure/storage.asciidoc b/metricbeat/docs/modules/azure/storage.asciidoc index 21a073d0b067..695bb3359a01 100644 --- a/metricbeat/docs/modules/azure/storage.asciidoc +++ b/metricbeat/docs/modules/azure/storage.asciidoc @@ -5,8 +5,6 @@ This file is generated! See scripts/mage/docs_collector.go [[metricbeat-metricset-azure-storage]] === azure storage metricset -beta[] - include::../../../../x-pack/metricbeat/module/azure/storage/_meta/docs.asciidoc[] diff --git a/metricbeat/docs/modules_list.asciidoc b/metricbeat/docs/modules_list.asciidoc index a8a6f204203f..b324627d173d 100644 --- a/metricbeat/docs/modules_list.asciidoc +++ b/metricbeat/docs/modules_list.asciidoc @@ -32,15 +32,15 @@ This file is generated! See scripts/mage/docs_collector.go |<> beta[] |<> beta[] |<> beta[] -|<> beta[] |image:./images/icon-yes.png[Prebuilt dashboards are available] | -.8+| .8+| |<> beta[] -|<> beta[] -|<> beta[] -|<> beta[] -|<> beta[] -|<> beta[] -|<> beta[] -|<> beta[] +|<> |image:./images/icon-yes.png[Prebuilt dashboards are available] | +.8+| .8+| |<> +|<> +|<> +|<> +|<> +|<> +|<> +|<> |<> |image:./images/icon-no.png[No prebuilt dashboards] | .2+| .2+| |<> |<> diff --git a/x-pack/metricbeat/module/azure/_meta/fields.yml b/x-pack/metricbeat/module/azure/_meta/fields.yml index 61913ce00199..2e27d9fda2d4 100644 --- a/x-pack/metricbeat/module/azure/_meta/fields.yml +++ b/x-pack/metricbeat/module/azure/_meta/fields.yml @@ -2,7 +2,7 @@ title: "azure" description: > azure module - release: beta + release: ga fields: - name: azure type: group diff --git a/x-pack/metricbeat/module/azure/azure.go b/x-pack/metricbeat/module/azure/azure.go index b321ac5f8aeb..bc70de81bcca 100644 --- a/x-pack/metricbeat/module/azure/azure.go +++ b/x-pack/metricbeat/module/azure/azure.go @@ -8,8 +8,6 @@ import ( "fmt" "time" - "github.com/elastic/beats/v7/libbeat/common/cfgwarn" - "github.com/pkg/errors" "github.com/elastic/beats/v7/metricbeat/mb" @@ -82,7 +80,6 @@ type MetricSet struct { // NewMetricSet will instantiate a new azure metricset func NewMetricSet(base mb.BaseMetricSet) (*MetricSet, error) { metricsetName := base.Name() - cfgwarn.Beta("The azure %s metricset is beta.", metricsetName) var config Config err := base.Module().UnpackConfig(&config) if err != nil { diff --git a/x-pack/metricbeat/module/azure/compute_vm/_meta/fields.yml b/x-pack/metricbeat/module/azure/compute_vm/_meta/fields.yml index 01ad69f53752..e8c1bdfff09b 100644 --- a/x-pack/metricbeat/module/azure/compute_vm/_meta/fields.yml +++ b/x-pack/metricbeat/module/azure/compute_vm/_meta/fields.yml @@ -1,5 +1,5 @@ - name: compute_vm.*.* - release: beta + release: ga type: object object_type: float object_type_mapping_type: "*" diff --git a/x-pack/metricbeat/module/azure/compute_vm/compute_vm_integration_test.go b/x-pack/metricbeat/module/azure/compute_vm/compute_vm_integration_test.go index f5f988d41f3c..3e197f186b37 100644 --- a/x-pack/metricbeat/module/azure/compute_vm/compute_vm_integration_test.go +++ b/x-pack/metricbeat/module/azure/compute_vm/compute_vm_integration_test.go @@ -25,6 +25,8 @@ func TestFetchMetricset(t *testing.T) { t.Fatalf("Expected 0 error, had %d. %v\n", len(errs), errs) } assert.NotEmpty(t, events) + test.TestFieldsDocumentation(t, events) + } func TestData(t *testing.T) { diff --git a/x-pack/metricbeat/module/azure/compute_vm_scaleset/_meta/fields.yml b/x-pack/metricbeat/module/azure/compute_vm_scaleset/_meta/fields.yml index bd216e771e28..59aa1719b270 100644 --- a/x-pack/metricbeat/module/azure/compute_vm_scaleset/_meta/fields.yml +++ b/x-pack/metricbeat/module/azure/compute_vm_scaleset/_meta/fields.yml @@ -1,5 +1,5 @@ - name: compute_vm_scaleset.*.* - release: beta + release: ga type: object object_type: float object_type_mapping_type: "*" diff --git a/x-pack/metricbeat/module/azure/compute_vm_scaleset/compute_vm_scaleset_integration_test.go b/x-pack/metricbeat/module/azure/compute_vm_scaleset/compute_vm_scaleset_integration_test.go index b48d7a65c5f9..fc11506d8906 100644 --- a/x-pack/metricbeat/module/azure/compute_vm_scaleset/compute_vm_scaleset_integration_test.go +++ b/x-pack/metricbeat/module/azure/compute_vm_scaleset/compute_vm_scaleset_integration_test.go @@ -25,6 +25,7 @@ func TestFetchMetricset(t *testing.T) { t.Fatalf("Expected 0 error, had %d. %v\n", len(errs), errs) } assert.NotEmpty(t, events) + test.TestFieldsDocumentation(t, events) } func TestData(t *testing.T) { diff --git a/x-pack/metricbeat/module/azure/container_instance/_meta/fields.yml b/x-pack/metricbeat/module/azure/container_instance/_meta/fields.yml index d79ddd149995..f6ad2b7eeda4 100644 --- a/x-pack/metricbeat/module/azure/container_instance/_meta/fields.yml +++ b/x-pack/metricbeat/module/azure/container_instance/_meta/fields.yml @@ -1,5 +1,5 @@ - name: container_instance.*.* - release: beta + release: ga type: object object_type: float object_type_mapping_type: "*" diff --git a/x-pack/metricbeat/module/azure/container_instance/container_instance_integration_test.go b/x-pack/metricbeat/module/azure/container_instance/container_instance_integration_test.go index 4808c3fde5d1..700e606a039b 100644 --- a/x-pack/metricbeat/module/azure/container_instance/container_instance_integration_test.go +++ b/x-pack/metricbeat/module/azure/container_instance/container_instance_integration_test.go @@ -28,6 +28,7 @@ func TestFetchMetricset(t *testing.T) { t.Fatalf("Expected 0 error, had %d. %v\n", len(errs), errs) } assert.NotEmpty(t, events) + test.TestFieldsDocumentation(t, events) } func TestData(t *testing.T) { diff --git a/x-pack/metricbeat/module/azure/container_registry/_meta/fields.yml b/x-pack/metricbeat/module/azure/container_registry/_meta/fields.yml index c8296603a776..60e9390bea05 100644 --- a/x-pack/metricbeat/module/azure/container_registry/_meta/fields.yml +++ b/x-pack/metricbeat/module/azure/container_registry/_meta/fields.yml @@ -1,5 +1,5 @@ - name: container_registry.*.* - release: beta + release: ga type: object object_type: float object_type_mapping_type: "*" diff --git a/x-pack/metricbeat/module/azure/container_registry/container_registry_integration_test.go b/x-pack/metricbeat/module/azure/container_registry/container_registry_integration_test.go index 3f6fceb64d7e..a820e252a368 100644 --- a/x-pack/metricbeat/module/azure/container_registry/container_registry_integration_test.go +++ b/x-pack/metricbeat/module/azure/container_registry/container_registry_integration_test.go @@ -28,6 +28,7 @@ func TestFetchMetricset(t *testing.T) { t.Fatalf("Expected 0 error, had %d. %v\n", len(errs), errs) } assert.NotEmpty(t, events) + test.TestFieldsDocumentation(t, events) } func TestData(t *testing.T) { diff --git a/x-pack/metricbeat/module/azure/container_service/_meta/fields.yml b/x-pack/metricbeat/module/azure/container_service/_meta/fields.yml index 9cccb41591d7..669ab5690f39 100644 --- a/x-pack/metricbeat/module/azure/container_service/_meta/fields.yml +++ b/x-pack/metricbeat/module/azure/container_service/_meta/fields.yml @@ -1,5 +1,5 @@ - name: container_service.*.* - release: beta + release: ga type: object object_type: float object_type_mapping_type: "*" diff --git a/x-pack/metricbeat/module/azure/container_service/container_service_integration_test.go b/x-pack/metricbeat/module/azure/container_service/container_service_integration_test.go index dfb1017c74f2..821d2049e877 100644 --- a/x-pack/metricbeat/module/azure/container_service/container_service_integration_test.go +++ b/x-pack/metricbeat/module/azure/container_service/container_service_integration_test.go @@ -28,6 +28,7 @@ func TestFetchMetricset(t *testing.T) { t.Fatalf("Expected 0 error, had %d. %v\n", len(errs), errs) } assert.NotEmpty(t, events) + test.TestFieldsDocumentation(t, events) } func TestData(t *testing.T) { diff --git a/x-pack/metricbeat/module/azure/database_account/_meta/fields.yml b/x-pack/metricbeat/module/azure/database_account/_meta/fields.yml index 60f53a8fa589..7a2e82b3aae1 100644 --- a/x-pack/metricbeat/module/azure/database_account/_meta/fields.yml +++ b/x-pack/metricbeat/module/azure/database_account/_meta/fields.yml @@ -1,5 +1,5 @@ - name: database_account.*.* - release: beta + release: ga type: object object_type: float object_type_mapping_type: "*" diff --git a/x-pack/metricbeat/module/azure/database_account/database_account_integration_test.go b/x-pack/metricbeat/module/azure/database_account/database_account_integration_test.go index 0ec41fdd8a48..e8ab246834cc 100644 --- a/x-pack/metricbeat/module/azure/database_account/database_account_integration_test.go +++ b/x-pack/metricbeat/module/azure/database_account/database_account_integration_test.go @@ -25,6 +25,7 @@ func TestFetchMetricset(t *testing.T) { t.Fatalf("Expected 0 error, had %d. %v\n", len(errs), errs) } assert.NotEmpty(t, events) + test.TestFieldsDocumentation(t, events) } func TestData(t *testing.T) { diff --git a/x-pack/metricbeat/module/azure/fields.go b/x-pack/metricbeat/module/azure/fields.go index 478d649d8a21..7f92f16265e5 100644 --- a/x-pack/metricbeat/module/azure/fields.go +++ b/x-pack/metricbeat/module/azure/fields.go @@ -19,5 +19,5 @@ func init() { // AssetAzure returns asset data. // This is the base64 encoded gzipped contents of module/azure. func AssetAzure() string { - return "eJzUls+OmzAQxu95ilGOkTYPwKFSpV566K135JgJnS7YaGbYij59RQCv+b9pe0h8iBTbfN/38wwWL/CKTQLmd814AFDSAhM43v4fDwAZimWqlLxL4NMBALq9UPqsLtpHGAs0gglcUM0B4EpYZJLctr6AMyW+y7dDmwoTyNnXVT+z4DGWiaWUSszZkAsrg+QrNr88Z9H8onA3vv9A+NyBoDLZBd3BkVF8zRZnhjHDB+wGHZAKLV0J46hT3BFyU+FoYZ14J8YQpX0c/BU0irVoPUX8D97hGObaAdjkcj4t2vrLT7Q6Weom061g0Za0NFVFLu/3H0/H+yC6tgkYt7Czpml/pTILXXN3mwYpECzQatQ3g5vUlyCRUvbvnrEgfP0yM8yoRCfk3bhOKzXaqc9Ha7ORefQqR+Fmwa0vq1oxfSvPp1H06TV2D9K18GZl8W+B3nNuIKRiTYGC+iwsIXBYX6Bzasghp+REjbP46HB9XhjybiAx5iTKzbMgDXk3kAT5jZ6nSH3c+YVm1FyMYGqs9bV78DdqSAt92hlO6R2p591PljWuDe+59Na3S3cly+Q4N45u9/juOcIdlHZ86wICo9bsMDuvX02ink3+4K3ehwyd8ScAAP//n2w3Eg==" + return "eJzUlsGOmzAQhu95ilGOkTYPwKFSpV566K135JgJnS7Y1sywFX36igBeEwhs2h4SHyLFNv//f57B4gVesc3A/G4YdwBKWmEG+8v//Q6gQLFMQcm7DD7tAKDfC7Uvmqp7hLFCI5hBaXYAZ8KqkOyy8QWcqfFdvBvahm4r+yYMMwsOU5lUSqnGkg25uDJKvmL7y3ORzC8K9+P7D4TPPQYqk13QHR0ZxTdscWaYMnzAbtQBCWjpTJhGvcadILcBJwu3iTdijFG6x8GfQZNYi9bXiP/BOx7DXDsCm1KOh0Vbf/qJVq+W+sl8LViyJa9NCOTKYf/+sL8Pom+biHEJO2ua7leCWeiau9s0SoFghVaTvhndpDlFiZyKf/dMBeHrl5lhQTU6Ie+mdbpRo436fLQ2K5knr3ISbhbc+jo0ivlbfTxMok8vsXuAzpU3Nxb/Fuc95QpALtZUKKjPQRLjxvUFNqeGHHJOTtQ4i4+NNqSFMe0KEGNJotw+B9CYdgVIkN/oWQo0hJ1fY0bNyQjmxlrfuId+k8asMGSdwdTekXre/ExZplpxnguvfa30l7BcHeXKwW0e3j0HuIHSjW99QGDUhh0Wx9sXkqhnUz50kw8RY1f8CQAA//+sjy+e" } diff --git a/x-pack/metricbeat/module/azure/monitor/_meta/fields.yml b/x-pack/metricbeat/module/azure/monitor/_meta/fields.yml index ef31dd9af5ba..139b2c380478 100644 --- a/x-pack/metricbeat/module/azure/monitor/_meta/fields.yml +++ b/x-pack/metricbeat/module/azure/monitor/_meta/fields.yml @@ -1,6 +1,6 @@ - name: monitor type: group - release: beta + release: ga description: > monitor fields: diff --git a/x-pack/metricbeat/module/azure/monitor/monitor_integration_test.go b/x-pack/metricbeat/module/azure/monitor/monitor_integration_test.go index f37a87f18c8c..1feba658f854 100644 --- a/x-pack/metricbeat/module/azure/monitor/monitor_integration_test.go +++ b/x-pack/metricbeat/module/azure/monitor/monitor_integration_test.go @@ -25,6 +25,7 @@ func TestFetchMetricset(t *testing.T) { t.Fatalf("Expected 0 error, had %d. %v\n", len(errs), errs) } assert.NotEmpty(t, events) + test.TestFieldsDocumentation(t, events) } func TestData(t *testing.T) { diff --git a/x-pack/metricbeat/module/azure/storage/_meta/fields.yml b/x-pack/metricbeat/module/azure/storage/_meta/fields.yml index c103e77f8414..0e699901c8a9 100644 --- a/x-pack/metricbeat/module/azure/storage/_meta/fields.yml +++ b/x-pack/metricbeat/module/azure/storage/_meta/fields.yml @@ -1,5 +1,5 @@ - name: storage.*.* - release: beta + release: ga type: object object_type: float object_type_mapping_type: "*" diff --git a/x-pack/metricbeat/module/azure/storage/storage_integration_test.go b/x-pack/metricbeat/module/azure/storage/storage_integration_test.go index f3a3f906173b..532ef4927752 100644 --- a/x-pack/metricbeat/module/azure/storage/storage_integration_test.go +++ b/x-pack/metricbeat/module/azure/storage/storage_integration_test.go @@ -25,6 +25,7 @@ func TestFetchMetricset(t *testing.T) { t.Fatalf("Expected 0 error, had %d. %v\n", len(errs), errs) } assert.NotEmpty(t, events) + test.TestFieldsDocumentation(t, events) } func TestData(t *testing.T) { diff --git a/x-pack/metricbeat/module/azure/test/integration.go b/x-pack/metricbeat/module/azure/test/integration.go index 7187e3b93f70..91a30175bca9 100644 --- a/x-pack/metricbeat/module/azure/test/integration.go +++ b/x-pack/metricbeat/module/azure/test/integration.go @@ -5,8 +5,13 @@ package test import ( + "errors" "os" "testing" + + "github.com/stretchr/testify/assert" + + "github.com/elastic/beats/v7/metricbeat/mb" ) // GetConfig function gets azure credentials for integration tests. @@ -40,3 +45,68 @@ func GetConfig(t *testing.T, metricSetName string) map[string]interface{} { "subscription_id": subId, } } + +// TestFieldsDocumentation func checks if all the documented fields have the expected type +func TestFieldsDocumentation(t *testing.T, events []mb.Event) { + for _, event := range events { + // RootField + checkIsDocumented("service.name", "string", event, t) + checkIsDocumented("cloud.provider", "string", event, t) + checkIsDocumented("cloud.region", "string", event, t) + checkIsDocumented("cloud.instance.name", "string", event, t) + checkIsDocumented("cloud.instance.id", "string", event, t) + + // MetricSetField + checkIsDocumented("azure.timegrain", "string", event, t) + checkIsDocumented("azure.subscription_id", "string", event, t) + checkIsDocumented("azure.namespace", "string", event, t) + checkIsDocumented("azure.resource.type", "string", event, t) + checkIsDocumented("azure.resource.group", "string", event, t) + } +} + +// checkIsDocumented function checks a given field type and compares it with the expected type for integration tests. +// this implementation is only temporary, will be replaced by issue https://github.com/elastic/beats/issues/17315 +func checkIsDocumented(metricName string, expectedType string, event mb.Event, t *testing.T) { + t.Helper() + + ok1, err1 := event.MetricSetFields.HasKey(metricName) + ok2, err2 := event.RootFields.HasKey(metricName) + if ok1 || ok2 { + if ok1 { + assert.NoError(t, err1) + metricValue, err := event.MetricSetFields.GetValue(metricName) + assert.NoError(t, err) + err = compareType(metricValue, expectedType, metricName) + assert.NoError(t, err) + t.Log("Succeed: Field " + metricName + " matches type " + expectedType) + } else if ok2 { + assert.NoError(t, err2) + rootValue, err := event.RootFields.GetValue(metricName) + assert.NoError(t, err) + err = compareType(rootValue, expectedType, metricName) + assert.NoError(t, err) + t.Log("Succeed: Field " + metricName + " matches type " + expectedType) + } + } else { + t.Log("Field " + metricName + " does not exist in metric set fields") + } +} + +func compareType(metricValue interface{}, expectedType string, metricName string) (err error) { + switch metricValue.(type) { + case float64: + if expectedType != "float" { + err = errors.New("Failed: Field " + metricName + " is not in type " + expectedType) + } + case string: + if expectedType != "string" { + err = errors.New("Failed: Field " + metricName + " is not in type " + expectedType) + } + case int64: + if expectedType != "int" { + err = errors.New("Failed: Field " + metricName + " is not in type " + expectedType) + } + } + return +}