From ceb470ce6e80c0e7503c203cc6d888663fd2beec Mon Sep 17 00:00:00 2001 From: Daniel Hrabovcak Date: Mon, 4 Dec 2023 13:38:14 -0500 Subject: [PATCH 1/4] Replace deprecated wait methods --- e2e/alertmanager_test.go | 37 ++++++++++------- e2e/collector_test.go | 29 ++++++++------ e2e/kubeutil/deployment.go | 4 +- e2e/kubeutil/pod.go | 8 ++-- e2e/operator_context_test.go | 7 ---- e2e/operatorutil/podmonitoringutil.go | 18 +++++---- e2e/ruler_test.go | 57 ++++++++++++++++----------- e2e/webhook_test.go | 4 +- pkg/operator/collection_test.go | 10 ++--- pkg/operator/target_status_test.go | 8 +++- 10 files changed, 103 insertions(+), 79 deletions(-) diff --git a/e2e/alertmanager_test.go b/e2e/alertmanager_test.go index 9feea9e7c3..d8ede365e0 100644 --- a/e2e/alertmanager_test.go +++ b/e2e/alertmanager_test.go @@ -119,9 +119,10 @@ func testAlertmanager(ctx context.Context, t *OperatorContext, spec *monitoringv } func testAlertmanagerDeployed(ctx context.Context, t *OperatorContext, config *monitoringv1.ManagedAlertmanagerSpec) { - err := wait.Poll(time.Second, 1*time.Minute, func() (bool, error) { + var err error + pollErr := wait.PollUntilContextTimeout(ctx, time.Second, 2*time.Minute, true, func(ctx context.Context) (bool, error) { var ss appsv1.StatefulSet - if err := t.Client().Get(ctx, client.ObjectKey{Namespace: t.namespace, Name: operator.NameAlertmanager}, &ss); err != nil { + if err = t.Client().Get(ctx, client.ObjectKey{Namespace: t.namespace, Name: operator.NameAlertmanager}, &ss); err != nil { if apierrors.IsNotFound(err) { return false, nil } @@ -142,10 +143,11 @@ func testAlertmanagerDeployed(ctx context.Context, t *OperatorContext, config *m return true, nil } + const containerName = "alertmanager" // TODO(pintohutch): clean-up wantArgs init logic. var wantArgs []string for _, c := range ss.Spec.Template.Spec.Containers { - if c.Name != "alertmanager" { + if c.Name != containerName { continue } // We're mainly interested in the dynamic flags but checking the entire set including @@ -155,15 +157,18 @@ func testAlertmanagerDeployed(ctx context.Context, t *OperatorContext, config *m } if diff := cmp.Diff(strings.Join(wantArgs, " "), getEnvVar(c.Env, "EXTRA_ARGS")); diff != "" { - return false, fmt.Errorf("unexpected flags (-want, +got): %s", diff) + err = fmt.Errorf("unexpected flags (-want, +got): %s", diff) } - return true, nil + return err == nil, nil } - return true, nil + return false, fmt.Errorf("no container with name %q found", containerName) }) - if err != nil { - t.Errorf("unable to get alertmanager statefulset: %s", err) + if pollErr != nil { + if errors.Is(pollErr, context.DeadlineExceeded) && err != nil { + pollErr = err + } + t.Errorf("unable to get alertmanager statefulset: %s", pollErr) } } @@ -172,9 +177,10 @@ func testAlertmanagerConfig(ctx context.Context, t *OperatorContext, pub *corev1 t.Fatalf("unable to create alertmanager config secret: %s", err) } - if err := wait.Poll(3*time.Second, 3*time.Minute, func() (bool, error) { + var err error + if pollErr := wait.PollUntilContextTimeout(ctx, 3*time.Second, 3*time.Minute, true, func(ctx context.Context) (bool, error) { var secret corev1.Secret - if err := t.Client().Get(ctx, client.ObjectKey{Namespace: t.namespace, Name: operator.AlertmanagerSecretName}, &secret); err != nil { + if err = t.Client().Get(ctx, client.ObjectKey{Namespace: t.namespace, Name: operator.AlertmanagerSecretName}, &secret); err != nil { if apierrors.IsNotFound(err) { return false, nil } @@ -189,10 +195,13 @@ func testAlertmanagerConfig(ctx context.Context, t *OperatorContext, pub *corev1 // Grab data from public secret and compare. data := pub.Data[key] if diff := cmp.Diff(data, bytes); diff != "" { - return false, fmt.Errorf("unexpected configuration (-want, +got): %s", diff) + err = fmt.Errorf("unexpected configuration (-want, +got): %s", diff) + } + return err == nil, nil + }); pollErr != nil { + if errors.Is(pollErr, context.DeadlineExceeded) && err != nil { + pollErr = err } - return true, nil - }); err != nil { - t.Errorf("unable to get alertmanager config: %s", err) + t.Errorf("unable to get alertmanager config: %s", pollErr) } } diff --git a/e2e/collector_test.go b/e2e/collector_test.go index cdb9d7bfde..916266c1ec 100644 --- a/e2e/collector_test.go +++ b/e2e/collector_test.go @@ -173,9 +173,10 @@ func testCollectorDeployed(ctx context.Context, t *OperatorContext) { }, }) - err := wait.Poll(3*time.Second, 3*time.Minute, func() (bool, error) { + var err error + pollErr := wait.PollUntilContextTimeout(ctx, 3*time.Second, 3*time.Minute, true, func(ctx context.Context) (bool, error) { var ds appsv1.DaemonSet - if err := t.Client().Get(ctx, client.ObjectKey{Namespace: t.namespace, Name: operator.NameCollector}, &ds); err != nil { + if err = t.Client().Get(ctx, client.ObjectKey{Namespace: t.namespace, Name: operator.NameCollector}, &ds); err != nil { if apierrors.IsNotFound(err) { return false, nil } @@ -210,7 +211,7 @@ func testCollectorDeployed(ctx context.Context, t *OperatorContext) { "cluster-autoscaler.kubernetes.io/safe-to-evict": "true", } if diff := cmp.Diff(wantedAnnotations, ds.Spec.Template.Annotations); diff != "" { - return false, fmt.Errorf("unexpected annotations (-want, +got): %s", diff) + err = fmt.Errorf("unexpected annotations (-want, +got): %s", diff) } // TODO(pintohutch): clean-up wantArgs init logic. @@ -234,15 +235,17 @@ func testCollectorDeployed(ctx context.Context, t *OperatorContext) { if diff := cmp.Diff(strings.Join(wantArgs, " "), getEnvVar(c.Env, "EXTRA_ARGS")); diff != "" { t.Log(fmt.Errorf("unexpected flags (-want, +got): %s", diff)) - return false, fmt.Errorf("unexpected flags (-want, +got): %s", diff) + err = fmt.Errorf("unexpected flags (-want, +got): %s", diff) } - return true, nil + return err == nil, nil } - t.Log(errors.New("no container with name prometheus found")) - return false, errors.New("no container with name prometheus found") + return false, fmt.Errorf("no container with name %q found", operator.CollectorPrometheusContainerName) }) - if err != nil { - t.Fatalf("Waiting for DaemonSet deployment failed: %s", err) + if pollErr != nil { + if errors.Is(pollErr, context.DeadlineExceeded) && err != nil { + pollErr = err + } + t.Fatalf("Waiting for DaemonSet deployment failed: %s", pollErr) } } @@ -328,7 +331,7 @@ func validateCollectorUpMetrics(ctx context.Context, t *OperatorContext, job str for _, port := range []string{operator.CollectorPrometheusContainerPortName, operator.CollectorConfigReloaderContainerPortName} { t.Logf("Poll up metric for pod %q and port %q", pod.Name, port) - err = wait.PollImmediateUntil(3*time.Second, func() (bool, error) { + err = wait.PollUntilContextCancel(ctx, 3*time.Second, true, func(ctx context.Context) (bool, error) { now := time.Now() // Validate the majority of labels being set correctly by filtering along them. @@ -369,7 +372,7 @@ func validateCollectorUpMetrics(ctx context.Context, t *OperatorContext, job str return false, fmt.Errorf("expected iterator to be done but got series %v: %w", series, err) } return true, nil - }, ctx.Done()) + }) if err != nil { t.Fatalf("Waiting for collector metrics to appear in Cloud Monitoring failed: %s", err) } @@ -414,7 +417,7 @@ func testCollectorScrapeKubelet(ctx context.Context, t *OperatorContext) { for _, port := range []string{"metrics", "cadvisor"} { t.Logf("Poll up metric for kubelet on node %q and port %q", node.Name, port) - err = wait.PollImmediateUntil(3*time.Second, func() (bool, error) { + err = wait.PollUntilContextCancel(ctx, 3*time.Second, true, func(ctx context.Context) (bool, error) { now := time.Now() // Validate the majority of labels being set correctly by filtering along them. @@ -455,7 +458,7 @@ func testCollectorScrapeKubelet(ctx context.Context, t *OperatorContext) { return false, fmt.Errorf("expected iterator to be done but got series %v: %w", series, err) } return true, nil - }, ctx.Done()) + }) if err != nil { t.Fatalf("Waiting for collector metrics to appear in Cloud Monitoring failed: %s", err) } diff --git a/e2e/kubeutil/deployment.go b/e2e/kubeutil/deployment.go index 6c8d91821c..933dd6f78e 100644 --- a/e2e/kubeutil/deployment.go +++ b/e2e/kubeutil/deployment.go @@ -58,11 +58,11 @@ func IsDeploymentReady(ctx context.Context, kubeClient client.Client, namespace, func WaitForDeploymentReady(ctx context.Context, kubeClient client.Client, namespace, name string) error { var err error - if waitErr := wait.Poll(3*time.Second, 1*time.Minute, func() (bool, error) { + if waitErr := wait.PollUntilContextTimeout(ctx, 3*time.Second, 1*time.Minute, true, func(ctx context.Context) (bool, error) { err := IsDeploymentReady(ctx, kubeClient, namespace, name) return err == nil, nil }); waitErr != nil { - if errors.Is(waitErr, wait.ErrWaitTimeout) { + if errors.Is(waitErr, context.DeadlineExceeded) { return err } return waitErr diff --git a/e2e/kubeutil/pod.go b/e2e/kubeutil/pod.go index e3e8fa99ac..551ee8528e 100644 --- a/e2e/kubeutil/pod.go +++ b/e2e/kubeutil/pod.go @@ -54,14 +54,14 @@ func WaitForPodContainerReady(ctx context.Context, t testing.TB, restConfig *res return nil } t.Logf("waiting for pod to be ready: %s", err) - if waitErr := wait.Poll(2*time.Second, 30*time.Second, func() (done bool, err error) { + if waitErr := wait.PollUntilContextTimeout(ctx, 2*time.Second, 30*time.Second, true, func(ctx context.Context) (done bool, err error) { if err = kubeClient.Get(ctx, client.ObjectKeyFromObject(pod), pod); err != nil { return false, err } err = IsPodContainerReady(ctx, restConfig, pod, container) return err == nil, nil }); waitErr != nil { - if errors.Is(waitErr, wait.ErrWaitTimeout) { + if errors.Is(waitErr, context.DeadlineExceeded) { return err } return waitErr @@ -87,14 +87,14 @@ func WaitForPodReady(ctx context.Context, t *testing.T, restConfig *rest.Config, return nil } t.Logf("waiting for pod to be ready: %s", err) - if waitErr := wait.Poll(2*time.Second, 30*time.Second, func() (done bool, err error) { + if waitErr := wait.PollUntilContextTimeout(ctx, 2*time.Second, 30*time.Second, true, func(ctx context.Context) (done bool, err error) { if err = kubeClient.Get(ctx, client.ObjectKeyFromObject(pod), pod); err != nil { return false, err } err = IsPodReady(ctx, restConfig, pod) return err == nil, nil }); waitErr != nil { - if errors.Is(waitErr, wait.ErrWaitTimeout) { + if errors.Is(waitErr, context.DeadlineExceeded) { return err } return waitErr diff --git a/e2e/operator_context_test.go b/e2e/operator_context_test.go index 5798ef261d..31c7c4b873 100644 --- a/e2e/operator_context_test.go +++ b/e2e/operator_context_test.go @@ -39,7 +39,6 @@ import ( apierrors "k8s.io/apimachinery/pkg/api/errors" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/labels" - "k8s.io/apimachinery/pkg/runtime" "k8s.io/apimachinery/pkg/runtime/schema" "k8s.io/apimachinery/pkg/selection" "k8s.io/client-go/discovery" @@ -369,12 +368,6 @@ func createGCPSecretResources(ctx context.Context, kubeClient client.Client, nam return nil } -func parseResourceYAML(b []byte) (runtime.Object, error) { - // Ignore returned schema. It's redundant since it's already encoded in obj. - obj, _, err := scheme.Codecs.UniversalDeserializer().Decode(b, nil, nil) - return obj, err -} - func createCollectorResources(ctx context.Context, kubeClient client.Client, namespace, labelValue string) error { if err := kubeClient.Create(ctx, &corev1.ServiceAccount{ ObjectMeta: metav1.ObjectMeta{ diff --git a/e2e/operatorutil/podmonitoringutil.go b/e2e/operatorutil/podmonitoringutil.go index deb93530de..019f30049b 100644 --- a/e2e/operatorutil/podmonitoringutil.go +++ b/e2e/operatorutil/podmonitoringutil.go @@ -62,7 +62,7 @@ func WaitForPodMonitoringReady(ctx context.Context, kubeClient client.Client, pm var err error var resVer string - pollErr := wait.Poll(3*time.Second, timeout, func() (bool, error) { + pollErr := wait.PollUntilContextTimeout(ctx, 3*time.Second, timeout, true, func(ctx context.Context) (bool, error) { if err = kubeClient.Get(ctx, client.ObjectKeyFromObject(pm), pm); err != nil { return false, fmt.Errorf("getting PodMonitoring failed: %w", err) } @@ -83,7 +83,7 @@ func WaitForPodMonitoringReady(ctx context.Context, kubeClient client.Client, pm return true, nil }) if pollErr != nil { - if errors.Is(pollErr, wait.ErrWaitTimeout) && err != nil { + if errors.Is(pollErr, context.DeadlineExceeded) && err != nil { return err } return pollErr @@ -108,7 +108,11 @@ func isPodMonitoringScrapeEndpointSuccess(status *monitoringv1.ScrapeEndpointSta } else { for _, target := range group.SampleTargets { if target.Health != "up" { - errs = append(errs, fmt.Errorf("unhealthy target %q at group %d", target.Health, i)) + lastErr := "no error reported" + if target.LastError != nil { + lastErr = *target.LastError + } + errs = append(errs, fmt.Errorf("unhealthy target %q at group %d: %s", target.Health, i, lastErr)) break } } @@ -169,14 +173,14 @@ func IsPodMonitoringSuccess(pm monitoringv1.PodMonitoringCRD, targetStatusEnable func WaitForPodMonitoringSuccess(ctx context.Context, kubeClient client.Client, pm monitoringv1.PodMonitoringCRD) error { var err error - if pollErr := wait.Poll(3*time.Second, 3*time.Minute, func() (bool, error) { + if pollErr := wait.PollUntilContextTimeout(ctx, 3*time.Second, 3*time.Minute, true, func(ctx context.Context) (bool, error) { if err = kubeClient.Get(ctx, client.ObjectKeyFromObject(pm), pm); err != nil { return false, nil } err = IsPodMonitoringSuccess(pm, true) return err == nil, nil }); pollErr != nil { - if errors.Is(pollErr, wait.ErrWaitTimeout) && err != nil { + if errors.Is(pollErr, context.DeadlineExceeded) && err != nil { return err } return pollErr @@ -199,14 +203,14 @@ func IsPodMonitoringFailure(pm monitoringv1.PodMonitoringCRD, expectedFn func(me func WaitForPodMonitoringFailure(ctx context.Context, kubeClient client.Client, pm monitoringv1.PodMonitoringCRD, expectedFn func(message string) error) error { var err error - if pollErr := wait.Poll(3*time.Second, 3*time.Minute, func() (bool, error) { + if pollErr := wait.PollUntilContextTimeout(ctx, 3*time.Second, 3*time.Minute, true, func(ctx context.Context) (bool, error) { if err = kubeClient.Get(ctx, client.ObjectKeyFromObject(pm), pm); err != nil { return false, nil } err = IsPodMonitoringFailure(pm, expectedFn) return err == nil, nil }); pollErr != nil { - if errors.Is(pollErr, wait.ErrWaitTimeout) && err != nil { + if errors.Is(pollErr, context.DeadlineExceeded) && err != nil { return err } return pollErr diff --git a/e2e/ruler_test.go b/e2e/ruler_test.go index 5530ef53cb..1b35eb032d 100644 --- a/e2e/ruler_test.go +++ b/e2e/ruler_test.go @@ -155,9 +155,10 @@ func testRuleEvaluatorSecrets(ctx context.Context, t *OperatorContext, cert, key fmt.Sprintf("secret_%s_alertmanager-tls_key", t.pubNamespace): key, fmt.Sprintf("secret_%s_alertmanager-authorization_token", t.pubNamespace): []byte("auth-bearer-password"), } - err := wait.Poll(1*time.Second, 1*time.Minute, func() (bool, error) { + var err error + pollErr := wait.PollUntilContextTimeout(ctx, 1*time.Second, 1*time.Minute, true, func(ctx context.Context) (bool, error) { var secret corev1.Secret - if err := t.Client().Get(ctx, client.ObjectKey{Namespace: t.namespace, Name: operator.RulesSecretName}, &secret); err != nil { + if err = t.Client().Get(ctx, client.ObjectKey{Namespace: t.namespace, Name: operator.RulesSecretName}, &secret); err != nil { if apierrors.IsNotFound(err) { return false, nil } @@ -166,12 +167,15 @@ func testRuleEvaluatorSecrets(ctx context.Context, t *OperatorContext, cert, key delete(secret.Data, fmt.Sprintf("secret_%s_user-gcp-service-account_key.json", t.pubNamespace)) if diff := cmp.Diff(want, secret.Data); diff != "" { - return false, fmt.Errorf("unexpected configuration (-want, +got): %s", diff) + err = fmt.Errorf("unexpected configuration (-want, +got): %s", diff) } - return true, nil + return err == nil, nil }) - if err != nil { - t.Fatalf("failed waiting for generated rule-evaluator config: %s", err) + if pollErr != nil { + if errors.Is(pollErr, context.DeadlineExceeded) && err != nil { + pollErr = err + } + t.Fatalf("failed waiting for generated rule-evaluator config: %s", pollErr) } } @@ -234,29 +238,34 @@ rule_files: - /etc/rules/*.yaml `), } - err := wait.Poll(1*time.Second, 1*time.Minute, func() (bool, error) { + var err error + pollErr := wait.PollUntilContextTimeout(ctx, 1*time.Second, 1*time.Minute, true, func(ctx context.Context) (bool, error) { var cm corev1.ConfigMap - if err := t.Client().Get(ctx, client.ObjectKey{Namespace: t.namespace, Name: "rule-evaluator"}, &cm); err != nil { + if err = t.Client().Get(ctx, client.ObjectKey{Namespace: t.namespace, Name: "rule-evaluator"}, &cm); err != nil { if apierrors.IsNotFound(err) { return false, nil } return false, fmt.Errorf("get configmap: %w", err) } if diff := cmp.Diff(want, cm.Data); diff != "" { - return false, fmt.Errorf("unexpected configuration (-want, +got): %s", diff) + err = fmt.Errorf("unexpected configuration (-want, +got): %s", diff) } - return true, nil + return err == nil, nil }) - if err != nil { - t.Fatalf("failed waiting for generated rule-evaluator config: %s", err) + if pollErr != nil { + if errors.Is(pollErr, context.DeadlineExceeded) && err != nil { + pollErr = err + } + t.Fatalf("failed waiting for generated rule-evaluator config: %s", pollErr) } } func testRuleEvaluatorDeployment(ctx context.Context, t *OperatorContext) { - err := wait.Poll(1*time.Second, 2*time.Minute, func() (bool, error) { + var err error + pollErr := wait.PollUntilContextTimeout(ctx, 1*time.Second, 1*time.Minute, true, func(ctx context.Context) (bool, error) { var deploy appsv1.Deployment - if err := t.Client().Get(ctx, client.ObjectKey{Namespace: t.namespace, Name: "rule-evaluator"}, &deploy); err != nil { + if err = t.Client().Get(ctx, client.ObjectKey{Namespace: t.namespace, Name: "rule-evaluator"}, &deploy); err != nil { if apierrors.IsNotFound(err) { return false, nil } @@ -283,9 +292,10 @@ func testRuleEvaluatorDeployment(ctx context.Context, t *OperatorContext) { return false, fmt.Errorf("unexpected annotations (-want, +got): %s", diff) } + const containerName = "evaluator" // TODO(pintohutch): clean-up wantArgs init logic. for _, c := range deploy.Spec.Template.Spec.Containers { - if c.Name != "evaluator" { + if c.Name != containerName { continue } // We're mainly interested in the dynamic flags but checking the entire set including @@ -305,14 +315,17 @@ func testRuleEvaluatorDeployment(ctx context.Context, t *OperatorContext) { } if diff := cmp.Diff(strings.Join(wantArgs, " "), getEnvVar(c.Env, "EXTRA_ARGS")); diff != "" { - return false, fmt.Errorf("unexpected flags (-want, +got): %s", diff) + err = fmt.Errorf("unexpected flags (-want, +got): %s", diff) } - return true, nil + return err == nil, nil } - return false, errors.New("no container with name evaluator found") + return false, fmt.Errorf("no container with name %q found", containerName) }) - if err != nil { - t.Fatalf("failed waiting for generated rule-evaluator deployment: %s", err) + if pollErr != nil { + if errors.Is(pollErr, context.DeadlineExceeded) && err != nil { + pollErr = err + } + t.Fatalf("failed waiting for generated rule-evaluator deployment: %s", pollErr) } } @@ -451,7 +464,7 @@ func testRulesGeneration(ctx context.Context, t *OperatorContext) { var diff string - err := wait.Poll(1*time.Second, time.Minute, func() (bool, error) { + err := wait.PollUntilContextTimeout(ctx, 1*time.Second, time.Minute, true, func(ctx context.Context) (bool, error) { var cm corev1.ConfigMap if err := t.Client().Get(ctx, client.ObjectKey{Namespace: t.namespace, Name: "rules-generated"}, &cm); err != nil { if apierrors.IsNotFound(err) { @@ -496,7 +509,7 @@ func testValidateRuleEvaluationMetrics(ctx context.Context, t *OperatorContext) } defer metricClient.Close() - err = wait.Poll(1*time.Second, 3*time.Minute, func() (bool, error) { + err = wait.PollUntilContextTimeout(ctx, 1*time.Second, 3*time.Minute, true, func(ctx context.Context) (bool, error) { now := time.Now() // Validate the majority of labels being set correctly by filtering along them. diff --git a/e2e/webhook_test.go b/e2e/webhook_test.go index 88eb57a068..e0af1de4aa 100644 --- a/e2e/webhook_test.go +++ b/e2e/webhook_test.go @@ -65,7 +65,7 @@ func TestWebhookCABundleInjection(t *testing.T) { } // Wait for caBundle injection. - err := wait.Poll(3*time.Second, 2*time.Minute, func() (bool, error) { + err := wait.PollUntilContextTimeout(ctx, 3*time.Second, 2*time.Minute, true, func(ctx context.Context) (bool, error) { if err := tctx.Client().Get(ctx, client.ObjectKeyFromObject(vwc), vwc); err != nil { return false, fmt.Errorf("get validatingwebhook configuration: %w", err) } @@ -112,7 +112,7 @@ func TestWebhookCABundleInjection(t *testing.T) { } // Wait for caBundle injection. - err := wait.Poll(3*time.Second, 2*time.Minute, func() (bool, error) { + err := wait.PollUntilContextTimeout(ctx, 3*time.Second, 2*time.Minute, true, func(ctx context.Context) (bool, error) { if err := tctx.Client().Get(ctx, client.ObjectKeyFromObject(mwc), mwc); err != nil { return false, fmt.Errorf("get mutatingwebhook configuration: %w", err) } diff --git a/pkg/operator/collection_test.go b/pkg/operator/collection_test.go index bc47df46df..307ba89d53 100644 --- a/pkg/operator/collection_test.go +++ b/pkg/operator/collection_test.go @@ -29,7 +29,6 @@ import ( appsv1 "k8s.io/api/apps/v1" corev1 "k8s.io/api/core/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" - v1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/runtime" "k8s.io/apimachinery/pkg/types" "k8s.io/apimachinery/pkg/util/intstr" @@ -108,7 +107,7 @@ func TestCollectionStatus(t *testing.T) { kubeClient := newFakeClientBuilder(). WithObjects(&monitoringv1.PodMonitoring{ - ObjectMeta: v1.ObjectMeta{ + ObjectMeta: metav1.ObjectMeta{ Name: "prom-example", Namespace: "gmp-test", }, @@ -121,7 +120,7 @@ func TestCollectionStatus(t *testing.T) { Status: statusIn, }). WithObjects(&monitoringv1.OperatorConfig{ - ObjectMeta: v1.ObjectMeta{ + ObjectMeta: metav1.ObjectMeta{ Name: NameOperatorConfig, Namespace: opts.PublicNamespace, }, @@ -161,13 +160,12 @@ func TestCollectionStatus(t *testing.T) { for i := range status.Conditions { // Normalize times because we cannot predict this. condition := &status.Conditions[i] - condition.LastUpdateTime = v1.Time{} - condition.LastTransitionTime = v1.Time{} + condition.LastUpdateTime = metav1.Time{} + condition.LastTransitionTime = metav1.Time{} } if diff := cmp.Diff(status, statusOut); diff != "" { t.Fatalf("invalid PodMonitoringStatus: %s", diff) } - break default: t.Fatalf("invalid PodMonitorings found: %d", amount) } diff --git a/pkg/operator/target_status_test.go b/pkg/operator/target_status_test.go index bbf607cac0..81b2d317b5 100644 --- a/pkg/operator/target_status_test.go +++ b/pkg/operator/target_status_test.go @@ -16,6 +16,7 @@ package operator import ( "context" + "errors" "fmt" "net/http" "sort" @@ -1252,7 +1253,7 @@ func TestPolling(t *testing.T) { expectStatus := func(t *testing.T, description string, expected []monitoringv1.ScrapeEndpointStatus) { // Must poll because status is updated via other thread. var err error - if pollErr := wait.Poll(100*time.Millisecond, 2*time.Second, func() (bool, error) { + if pollErr := wait.PollUntilContextTimeout(ctx, 100*time.Millisecond, 2*time.Second, true, func(ctx context.Context) (bool, error) { var podMonitorings monitoringv1.PodMonitoringList if err := kubeClient.List(ctx, &podMonitorings); err != nil { return false, nil @@ -1275,7 +1276,10 @@ func TestPolling(t *testing.T) { return false, err } }); pollErr != nil { - t.Fatalf("Failed waiting for %s status: %s", description, err) + if errors.Is(pollErr, context.DeadlineExceeded) && err != nil { + pollErr = err + } + t.Fatalf("Failed waiting for %s status: %s", description, pollErr) } } From 481b9268dc5db29fdef63fef67790b874c6007cc Mon Sep 17 00:00:00 2001 From: Daniel Hrabovcak Date: Thu, 7 Dec 2023 09:47:22 -0500 Subject: [PATCH 2/4] Update monitoring protobuf import --- go.mod | 2 +- pkg/export/export.go | 2 +- pkg/export/export_test.go | 2 +- pkg/export/pool.go | 2 +- pkg/export/pool_test.go | 2 +- pkg/export/series_cache.go | 2 +- pkg/export/shard.go | 2 +- pkg/export/transform.go | 2 +- pkg/export/transform_test.go | 2 +- .../googleapis/monitoring/v3/alias.go | 1287 ----------------- vendor/modules.txt | 1 - 11 files changed, 9 insertions(+), 1297 deletions(-) delete mode 100644 vendor/google.golang.org/genproto/googleapis/monitoring/v3/alias.go diff --git a/go.mod b/go.mod index 1b57eb7264..a4932ab710 100644 --- a/go.mod +++ b/go.mod @@ -27,7 +27,6 @@ require ( golang.org/x/oauth2 v0.10.0 golang.org/x/time v0.3.0 google.golang.org/api v0.128.0 - google.golang.org/genproto v0.0.0-20230711160842-782d3b101e98 google.golang.org/genproto/googleapis/api v0.0.0-20230711160842-782d3b101e98 google.golang.org/grpc v1.58.3 google.golang.org/protobuf v1.31.0 @@ -115,6 +114,7 @@ require ( golang.org/x/tools v0.9.3 // indirect gomodules.xyz/jsonpatch/v2 v2.4.0 // indirect google.golang.org/appengine v1.6.7 // indirect + google.golang.org/genproto v0.0.0-20230711160842-782d3b101e98 // indirect google.golang.org/genproto/googleapis/rpc v0.0.0-20230711160842-782d3b101e98 // indirect gopkg.in/inf.v0 v0.9.1 // indirect k8s.io/apiextensions-apiserver v0.28.3 // indirect diff --git a/pkg/export/export.go b/pkg/export/export.go index f1322f25cf..e2540b8f7c 100644 --- a/pkg/export/export.go +++ b/pkg/export/export.go @@ -29,6 +29,7 @@ import ( "time" monitoring "cloud.google.com/go/monitoring/apiv3/v2" + monitoring_pb "cloud.google.com/go/monitoring/apiv3/v2/monitoringpb" "github.com/go-kit/log" "github.com/go-kit/log/level" gax "github.com/googleapis/gax-go/v2" @@ -41,7 +42,6 @@ import ( "github.com/prometheus/prometheus/storage" "github.com/prometheus/prometheus/tsdb/record" "google.golang.org/api/option" - monitoring_pb "google.golang.org/genproto/googleapis/monitoring/v3" "google.golang.org/grpc" "google.golang.org/grpc/encoding/gzip" ) diff --git a/pkg/export/export_test.go b/pkg/export/export_test.go index ce74096426..3c0d277dfc 100644 --- a/pkg/export/export_test.go +++ b/pkg/export/export_test.go @@ -24,6 +24,7 @@ import ( "time" monitoring "cloud.google.com/go/monitoring/apiv3/v2" + monitoring_pb "cloud.google.com/go/monitoring/apiv3/v2/monitoringpb" "github.com/go-kit/log" timestamp_pb "github.com/golang/protobuf/ptypes/timestamp" "github.com/google/go-cmp/cmp" @@ -34,7 +35,6 @@ import ( "github.com/prometheus/prometheus/tsdb/record" "google.golang.org/api/option" monitoredres_pb "google.golang.org/genproto/googleapis/api/monitoredres" - monitoring_pb "google.golang.org/genproto/googleapis/monitoring/v3" "google.golang.org/grpc" "google.golang.org/grpc/test/bufconn" empty_pb "google.golang.org/protobuf/types/known/emptypb" diff --git a/pkg/export/pool.go b/pkg/export/pool.go index ed4f3e98aa..d6e2571a55 100644 --- a/pkg/export/pool.go +++ b/pkg/export/pool.go @@ -19,8 +19,8 @@ import ( "hash/fnv" "sync" + monitoring_pb "cloud.google.com/go/monitoring/apiv3/v2/monitoringpb" "github.com/prometheus/client_golang/prometheus" - monitoring_pb "google.golang.org/genproto/googleapis/monitoring/v3" ) var ( diff --git a/pkg/export/pool_test.go b/pkg/export/pool_test.go index 69d9536081..8d1f14bba2 100644 --- a/pkg/export/pool_test.go +++ b/pkg/export/pool_test.go @@ -17,9 +17,9 @@ package export import ( "testing" + monitoring_pb "cloud.google.com/go/monitoring/apiv3/v2/monitoringpb" metric_pb "google.golang.org/genproto/googleapis/api/metric" monitoredres_pb "google.golang.org/genproto/googleapis/api/monitoredres" - monitoring_pb "google.golang.org/genproto/googleapis/monitoring/v3" ) func TestPool(t *testing.T) { diff --git a/pkg/export/series_cache.go b/pkg/export/series_cache.go index 9f13e457af..40bea16615 100644 --- a/pkg/export/series_cache.go +++ b/pkg/export/series_cache.go @@ -34,9 +34,9 @@ import ( "github.com/prometheus/prometheus/storage" "github.com/prometheus/prometheus/tsdb/record" + monitoring_pb "cloud.google.com/go/monitoring/apiv3/v2/monitoringpb" metric_pb "google.golang.org/genproto/googleapis/api/metric" monitoredres_pb "google.golang.org/genproto/googleapis/api/monitoredres" - monitoring_pb "google.golang.org/genproto/googleapis/monitoring/v3" ) // seriesCache holds a mapping from series reference to label set. diff --git a/pkg/export/shard.go b/pkg/export/shard.go index 3f72d9e04a..c0564cf543 100644 --- a/pkg/export/shard.go +++ b/pkg/export/shard.go @@ -18,7 +18,7 @@ import ( "fmt" "sync" - monitoring_pb "google.golang.org/genproto/googleapis/monitoring/v3" + monitoring_pb "cloud.google.com/go/monitoring/apiv3/v2/monitoringpb" ) // shard holds a queue of data for a subset of samples. diff --git a/pkg/export/transform.go b/pkg/export/transform.go index 6b9f37cc20..73ebc1d2c6 100644 --- a/pkg/export/transform.go +++ b/pkg/export/transform.go @@ -31,9 +31,9 @@ import ( "github.com/prometheus/prometheus/storage" "github.com/prometheus/prometheus/tsdb/record" + monitoring_pb "cloud.google.com/go/monitoring/apiv3/v2/monitoringpb" timestamp_pb "github.com/golang/protobuf/ptypes/timestamp" distribution_pb "google.golang.org/genproto/googleapis/api/distribution" - monitoring_pb "google.golang.org/genproto/googleapis/monitoring/v3" "google.golang.org/protobuf/types/known/anypb" ) diff --git a/pkg/export/transform_test.go b/pkg/export/transform_test.go index dfbb351661..e9111351aa 100644 --- a/pkg/export/transform_test.go +++ b/pkg/export/transform_test.go @@ -30,11 +30,11 @@ import ( "google.golang.org/protobuf/testing/protocmp" "google.golang.org/protobuf/types/known/anypb" + monitoring_pb "cloud.google.com/go/monitoring/apiv3/v2/monitoringpb" timestamp_pb "github.com/golang/protobuf/ptypes/timestamp" distribution_pb "google.golang.org/genproto/googleapis/api/distribution" metric_pb "google.golang.org/genproto/googleapis/api/metric" monitoredres_pb "google.golang.org/genproto/googleapis/api/monitoredres" - monitoring_pb "google.golang.org/genproto/googleapis/monitoring/v3" ) type seriesMap map[storage.SeriesRef]labels.Labels diff --git a/vendor/google.golang.org/genproto/googleapis/monitoring/v3/alias.go b/vendor/google.golang.org/genproto/googleapis/monitoring/v3/alias.go deleted file mode 100644 index 13e82c852e..0000000000 --- a/vendor/google.golang.org/genproto/googleapis/monitoring/v3/alias.go +++ /dev/null @@ -1,1287 +0,0 @@ -// Copyright 2022 Google LLC -// -// Licensed under the Apache License, Version 2.0 (the "License"); -// you may not use this file except in compliance with the License. -// You may obtain a copy of the License at -// -// http://www.apache.org/licenses/LICENSE-2.0 -// -// Unless required by applicable law or agreed to in writing, software -// distributed under the License is distributed on an "AS IS" BASIS, -// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -// See the License for the specific language governing permissions and -// limitations under the License. - -// Code generated by aliasgen. DO NOT EDIT. - -// Package monitoring aliases all exported identifiers in package -// "cloud.google.com/go/monitoring/apiv3/v2/monitoringpb". -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb. -// Please read https://github.com/googleapis/google-cloud-go/blob/main/migration.md -// for more details. -package monitoring - -import ( - src "cloud.google.com/go/monitoring/apiv3/v2/monitoringpb" - grpc "google.golang.org/grpc" -) - -// Deprecated: Please use consts in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -const ( - Aggregation_ALIGN_COUNT = src.Aggregation_ALIGN_COUNT - Aggregation_ALIGN_COUNT_FALSE = src.Aggregation_ALIGN_COUNT_FALSE - Aggregation_ALIGN_COUNT_TRUE = src.Aggregation_ALIGN_COUNT_TRUE - Aggregation_ALIGN_DELTA = src.Aggregation_ALIGN_DELTA - Aggregation_ALIGN_FRACTION_TRUE = src.Aggregation_ALIGN_FRACTION_TRUE - Aggregation_ALIGN_INTERPOLATE = src.Aggregation_ALIGN_INTERPOLATE - Aggregation_ALIGN_MAX = src.Aggregation_ALIGN_MAX - Aggregation_ALIGN_MEAN = src.Aggregation_ALIGN_MEAN - Aggregation_ALIGN_MIN = src.Aggregation_ALIGN_MIN - Aggregation_ALIGN_NEXT_OLDER = src.Aggregation_ALIGN_NEXT_OLDER - Aggregation_ALIGN_NONE = src.Aggregation_ALIGN_NONE - Aggregation_ALIGN_PERCENTILE_05 = src.Aggregation_ALIGN_PERCENTILE_05 - Aggregation_ALIGN_PERCENTILE_50 = src.Aggregation_ALIGN_PERCENTILE_50 - Aggregation_ALIGN_PERCENTILE_95 = src.Aggregation_ALIGN_PERCENTILE_95 - Aggregation_ALIGN_PERCENTILE_99 = src.Aggregation_ALIGN_PERCENTILE_99 - Aggregation_ALIGN_PERCENT_CHANGE = src.Aggregation_ALIGN_PERCENT_CHANGE - Aggregation_ALIGN_RATE = src.Aggregation_ALIGN_RATE - Aggregation_ALIGN_STDDEV = src.Aggregation_ALIGN_STDDEV - Aggregation_ALIGN_SUM = src.Aggregation_ALIGN_SUM - Aggregation_REDUCE_COUNT = src.Aggregation_REDUCE_COUNT - Aggregation_REDUCE_COUNT_FALSE = src.Aggregation_REDUCE_COUNT_FALSE - Aggregation_REDUCE_COUNT_TRUE = src.Aggregation_REDUCE_COUNT_TRUE - Aggregation_REDUCE_FRACTION_TRUE = src.Aggregation_REDUCE_FRACTION_TRUE - Aggregation_REDUCE_MAX = src.Aggregation_REDUCE_MAX - Aggregation_REDUCE_MEAN = src.Aggregation_REDUCE_MEAN - Aggregation_REDUCE_MIN = src.Aggregation_REDUCE_MIN - Aggregation_REDUCE_NONE = src.Aggregation_REDUCE_NONE - Aggregation_REDUCE_PERCENTILE_05 = src.Aggregation_REDUCE_PERCENTILE_05 - Aggregation_REDUCE_PERCENTILE_50 = src.Aggregation_REDUCE_PERCENTILE_50 - Aggregation_REDUCE_PERCENTILE_95 = src.Aggregation_REDUCE_PERCENTILE_95 - Aggregation_REDUCE_PERCENTILE_99 = src.Aggregation_REDUCE_PERCENTILE_99 - Aggregation_REDUCE_STDDEV = src.Aggregation_REDUCE_STDDEV - Aggregation_REDUCE_SUM = src.Aggregation_REDUCE_SUM - AlertPolicy_AND = src.AlertPolicy_AND - AlertPolicy_AND_WITH_MATCHING_RESOURCE = src.AlertPolicy_AND_WITH_MATCHING_RESOURCE - AlertPolicy_COMBINE_UNSPECIFIED = src.AlertPolicy_COMBINE_UNSPECIFIED - AlertPolicy_Condition_EVALUATION_MISSING_DATA_ACTIVE = src.AlertPolicy_Condition_EVALUATION_MISSING_DATA_ACTIVE - AlertPolicy_Condition_EVALUATION_MISSING_DATA_INACTIVE = src.AlertPolicy_Condition_EVALUATION_MISSING_DATA_INACTIVE - AlertPolicy_Condition_EVALUATION_MISSING_DATA_NO_OP = src.AlertPolicy_Condition_EVALUATION_MISSING_DATA_NO_OP - AlertPolicy_Condition_EVALUATION_MISSING_DATA_UNSPECIFIED = src.AlertPolicy_Condition_EVALUATION_MISSING_DATA_UNSPECIFIED - AlertPolicy_OR = src.AlertPolicy_OR - ComparisonType_COMPARISON_EQ = src.ComparisonType_COMPARISON_EQ - ComparisonType_COMPARISON_GE = src.ComparisonType_COMPARISON_GE - ComparisonType_COMPARISON_GT = src.ComparisonType_COMPARISON_GT - ComparisonType_COMPARISON_LE = src.ComparisonType_COMPARISON_LE - ComparisonType_COMPARISON_LT = src.ComparisonType_COMPARISON_LT - ComparisonType_COMPARISON_NE = src.ComparisonType_COMPARISON_NE - ComparisonType_COMPARISON_UNSPECIFIED = src.ComparisonType_COMPARISON_UNSPECIFIED - GroupResourceType_AWS_ELB_LOAD_BALANCER = src.GroupResourceType_AWS_ELB_LOAD_BALANCER - GroupResourceType_INSTANCE = src.GroupResourceType_INSTANCE - GroupResourceType_RESOURCE_TYPE_UNSPECIFIED = src.GroupResourceType_RESOURCE_TYPE_UNSPECIFIED - InternalChecker_CREATING = src.InternalChecker_CREATING - InternalChecker_RUNNING = src.InternalChecker_RUNNING - InternalChecker_UNSPECIFIED = src.InternalChecker_UNSPECIFIED - ListTimeSeriesRequest_FULL = src.ListTimeSeriesRequest_FULL - ListTimeSeriesRequest_HEADERS = src.ListTimeSeriesRequest_HEADERS - NotificationChannel_UNVERIFIED = src.NotificationChannel_UNVERIFIED - NotificationChannel_VERIFICATION_STATUS_UNSPECIFIED = src.NotificationChannel_VERIFICATION_STATUS_UNSPECIFIED - NotificationChannel_VERIFIED = src.NotificationChannel_VERIFIED - ServiceLevelObjective_EXPLICIT = src.ServiceLevelObjective_EXPLICIT - ServiceLevelObjective_FULL = src.ServiceLevelObjective_FULL - ServiceLevelObjective_VIEW_UNSPECIFIED = src.ServiceLevelObjective_VIEW_UNSPECIFIED - ServiceTier_SERVICE_TIER_BASIC = src.ServiceTier_SERVICE_TIER_BASIC - ServiceTier_SERVICE_TIER_PREMIUM = src.ServiceTier_SERVICE_TIER_PREMIUM - ServiceTier_SERVICE_TIER_UNSPECIFIED = src.ServiceTier_SERVICE_TIER_UNSPECIFIED - UptimeCheckConfig_ContentMatcher_CONTAINS_STRING = src.UptimeCheckConfig_ContentMatcher_CONTAINS_STRING - UptimeCheckConfig_ContentMatcher_CONTENT_MATCHER_OPTION_UNSPECIFIED = src.UptimeCheckConfig_ContentMatcher_CONTENT_MATCHER_OPTION_UNSPECIFIED - UptimeCheckConfig_ContentMatcher_MATCHES_REGEX = src.UptimeCheckConfig_ContentMatcher_MATCHES_REGEX - UptimeCheckConfig_ContentMatcher_NOT_CONTAINS_STRING = src.UptimeCheckConfig_ContentMatcher_NOT_CONTAINS_STRING - UptimeCheckConfig_ContentMatcher_NOT_MATCHES_REGEX = src.UptimeCheckConfig_ContentMatcher_NOT_MATCHES_REGEX - UptimeCheckConfig_HttpCheck_GET = src.UptimeCheckConfig_HttpCheck_GET - UptimeCheckConfig_HttpCheck_METHOD_UNSPECIFIED = src.UptimeCheckConfig_HttpCheck_METHOD_UNSPECIFIED - UptimeCheckConfig_HttpCheck_POST = src.UptimeCheckConfig_HttpCheck_POST - UptimeCheckConfig_HttpCheck_TYPE_UNSPECIFIED = src.UptimeCheckConfig_HttpCheck_TYPE_UNSPECIFIED - UptimeCheckConfig_HttpCheck_URL_ENCODED = src.UptimeCheckConfig_HttpCheck_URL_ENCODED - UptimeCheckRegion_ASIA_PACIFIC = src.UptimeCheckRegion_ASIA_PACIFIC - UptimeCheckRegion_EUROPE = src.UptimeCheckRegion_EUROPE - UptimeCheckRegion_REGION_UNSPECIFIED = src.UptimeCheckRegion_REGION_UNSPECIFIED - UptimeCheckRegion_SOUTH_AMERICA = src.UptimeCheckRegion_SOUTH_AMERICA - UptimeCheckRegion_USA = src.UptimeCheckRegion_USA -) - -// Deprecated: Please use vars in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -var ( - Aggregation_Aligner_name = src.Aggregation_Aligner_name - Aggregation_Aligner_value = src.Aggregation_Aligner_value - Aggregation_Reducer_name = src.Aggregation_Reducer_name - Aggregation_Reducer_value = src.Aggregation_Reducer_value - AlertPolicy_ConditionCombinerType_name = src.AlertPolicy_ConditionCombinerType_name - AlertPolicy_ConditionCombinerType_value = src.AlertPolicy_ConditionCombinerType_value - AlertPolicy_Condition_EvaluationMissingData_name = src.AlertPolicy_Condition_EvaluationMissingData_name - AlertPolicy_Condition_EvaluationMissingData_value = src.AlertPolicy_Condition_EvaluationMissingData_value - ComparisonType_name = src.ComparisonType_name - ComparisonType_value = src.ComparisonType_value - File_google_monitoring_v3_alert_proto = src.File_google_monitoring_v3_alert_proto - File_google_monitoring_v3_alert_service_proto = src.File_google_monitoring_v3_alert_service_proto - File_google_monitoring_v3_common_proto = src.File_google_monitoring_v3_common_proto - File_google_monitoring_v3_dropped_labels_proto = src.File_google_monitoring_v3_dropped_labels_proto - File_google_monitoring_v3_group_proto = src.File_google_monitoring_v3_group_proto - File_google_monitoring_v3_group_service_proto = src.File_google_monitoring_v3_group_service_proto - File_google_monitoring_v3_metric_proto = src.File_google_monitoring_v3_metric_proto - File_google_monitoring_v3_metric_service_proto = src.File_google_monitoring_v3_metric_service_proto - File_google_monitoring_v3_mutation_record_proto = src.File_google_monitoring_v3_mutation_record_proto - File_google_monitoring_v3_notification_proto = src.File_google_monitoring_v3_notification_proto - File_google_monitoring_v3_notification_service_proto = src.File_google_monitoring_v3_notification_service_proto - File_google_monitoring_v3_query_service_proto = src.File_google_monitoring_v3_query_service_proto - File_google_monitoring_v3_service_proto = src.File_google_monitoring_v3_service_proto - File_google_monitoring_v3_service_service_proto = src.File_google_monitoring_v3_service_service_proto - File_google_monitoring_v3_span_context_proto = src.File_google_monitoring_v3_span_context_proto - File_google_monitoring_v3_uptime_proto = src.File_google_monitoring_v3_uptime_proto - File_google_monitoring_v3_uptime_service_proto = src.File_google_monitoring_v3_uptime_service_proto - GroupResourceType_name = src.GroupResourceType_name - GroupResourceType_value = src.GroupResourceType_value - InternalChecker_State_name = src.InternalChecker_State_name - InternalChecker_State_value = src.InternalChecker_State_value - ListTimeSeriesRequest_TimeSeriesView_name = src.ListTimeSeriesRequest_TimeSeriesView_name - ListTimeSeriesRequest_TimeSeriesView_value = src.ListTimeSeriesRequest_TimeSeriesView_value - NotificationChannel_VerificationStatus_name = src.NotificationChannel_VerificationStatus_name - NotificationChannel_VerificationStatus_value = src.NotificationChannel_VerificationStatus_value - ServiceLevelObjective_View_name = src.ServiceLevelObjective_View_name - ServiceLevelObjective_View_value = src.ServiceLevelObjective_View_value - ServiceTier_name = src.ServiceTier_name - ServiceTier_value = src.ServiceTier_value - UptimeCheckConfig_ContentMatcher_ContentMatcherOption_name = src.UptimeCheckConfig_ContentMatcher_ContentMatcherOption_name - UptimeCheckConfig_ContentMatcher_ContentMatcherOption_value = src.UptimeCheckConfig_ContentMatcher_ContentMatcherOption_value - UptimeCheckConfig_HttpCheck_ContentType_name = src.UptimeCheckConfig_HttpCheck_ContentType_name - UptimeCheckConfig_HttpCheck_ContentType_value = src.UptimeCheckConfig_HttpCheck_ContentType_value - UptimeCheckConfig_HttpCheck_RequestMethod_name = src.UptimeCheckConfig_HttpCheck_RequestMethod_name - UptimeCheckConfig_HttpCheck_RequestMethod_value = src.UptimeCheckConfig_HttpCheck_RequestMethod_value - UptimeCheckRegion_name = src.UptimeCheckRegion_name - UptimeCheckRegion_value = src.UptimeCheckRegion_value -) - -// Describes how to combine multiple time series to provide a different view -// of the data. Aggregation of time series is done in two steps. First, each -// time series in the set is _aligned_ to the same time interval boundaries, -// then the set of time series is optionally _reduced_ in number. Alignment -// consists of applying the `per_series_aligner` operation to each time series -// after its data has been divided into regular `alignment_period` time -// intervals. This process takes _all_ of the data points in an alignment -// period, applies a mathematical transformation such as averaging, minimum, -// maximum, delta, etc., and converts them into a single data point per period. -// Reduction is when the aligned and transformed time series can optionally be -// combined, reducing the number of time series through similar mathematical -// transformations. Reduction involves applying a `cross_series_reducer` to all -// the time series, optionally sorting the time series into subsets with -// `group_by_fields`, and applying the reducer to each subset. The raw time -// series data can contain a huge amount of information from multiple sources. -// Alignment and reduction transforms this mass of data into a more manageable -// and representative collection of data, for example "the 95% latency across -// the average of all tasks in a cluster". This representative data can be more -// easily graphed and comprehended, and the individual time series data is -// still available for later drilldown. For more details, see [Filtering and -// aggregation](https://cloud.google.com/monitoring/api/v3/aggregation). -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type Aggregation = src.Aggregation - -// The `Aligner` specifies the operation that will be applied to the data -// points in each alignment period in a time series. Except for `ALIGN_NONE`, -// which specifies that no operation be applied, each alignment operation -// replaces the set of data values in each alignment period with a single -// value: the result of applying the operation to the data values. An aligned -// time series has a single data value at the end of each `alignment_period`. -// An alignment operation can change the data type of the values, too. For -// example, if you apply a counting operation to boolean values, the data -// `value_type` in the original time series is `BOOLEAN`, but the `value_type` -// in the aligned result is `INT64`. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type Aggregation_Aligner = src.Aggregation_Aligner - -// A Reducer operation describes how to aggregate data points from multiple -// time series into a single time series, where the value of each data point in -// the resulting series is a function of all the already aligned values in the -// input time series. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type Aggregation_Reducer = src.Aggregation_Reducer - -// A description of the conditions under which some aspect of your system is -// considered to be "unhealthy" and the ways to notify people or services about -// this state. For an overview of alert policies, see [Introduction to -// Alerting](https://cloud.google.com/monitoring/alerts/). -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type AlertPolicy = src.AlertPolicy - -// AlertPolicyServiceClient is the client API for AlertPolicyService service. -// For semantics around ctx use and closing/ending streaming RPCs, please refer -// to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type AlertPolicyServiceClient = src.AlertPolicyServiceClient - -// AlertPolicyServiceServer is the server API for AlertPolicyService service. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type AlertPolicyServiceServer = src.AlertPolicyServiceServer - -// Control over how the notification channels in `notification_channels` are -// notified when this alert fires. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type AlertPolicy_AlertStrategy = src.AlertPolicy_AlertStrategy - -// Control over the rate of notifications sent to this alert policy's -// notification channels. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type AlertPolicy_AlertStrategy_NotificationRateLimit = src.AlertPolicy_AlertStrategy_NotificationRateLimit - -// A condition is a true/false test that determines when an alerting policy -// should open an incident. If a condition evaluates to true, it signifies that -// something is wrong. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type AlertPolicy_Condition = src.AlertPolicy_Condition - -// Operators for combining conditions. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type AlertPolicy_ConditionCombinerType = src.AlertPolicy_ConditionCombinerType -type AlertPolicy_Condition_ConditionAbsent = src.AlertPolicy_Condition_ConditionAbsent -type AlertPolicy_Condition_ConditionMatchedLog = src.AlertPolicy_Condition_ConditionMatchedLog -type AlertPolicy_Condition_ConditionMonitoringQueryLanguage = src.AlertPolicy_Condition_ConditionMonitoringQueryLanguage -type AlertPolicy_Condition_ConditionThreshold = src.AlertPolicy_Condition_ConditionThreshold - -// A condition control that determines how metric-threshold conditions are -// evaluated when data stops arriving. This control doesn't affect -// metric-absence policies. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type AlertPolicy_Condition_EvaluationMissingData = src.AlertPolicy_Condition_EvaluationMissingData - -// A condition type that checks whether a log message in the [scoping -// project](https://cloud.google.com/monitoring/api/v3#project_name) satisfies -// the given filter. Logs from other projects in the metrics scope are not -// evaluated. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type AlertPolicy_Condition_LogMatch = src.AlertPolicy_Condition_LogMatch - -// A condition type that checks that monitored resources are reporting data. -// The configuration defines a metric and a set of monitored resources. The -// predicate is considered in violation when a time series for the specified -// metric of a monitored resource does not include any data in the specified -// `duration`. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type AlertPolicy_Condition_MetricAbsence = src.AlertPolicy_Condition_MetricAbsence - -// A condition type that compares a collection of time series against a -// threshold. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type AlertPolicy_Condition_MetricThreshold = src.AlertPolicy_Condition_MetricThreshold - -// A condition type that allows alert policies to be defined using [Monitoring -// Query Language](https://cloud.google.com/monitoring/mql). -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type AlertPolicy_Condition_MonitoringQueryLanguageCondition = src.AlertPolicy_Condition_MonitoringQueryLanguageCondition - -// Specifies how many time series must fail a predicate to trigger a -// condition. If not specified, then a `{count: 1}` trigger is used. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type AlertPolicy_Condition_Trigger = src.AlertPolicy_Condition_Trigger -type AlertPolicy_Condition_Trigger_Count = src.AlertPolicy_Condition_Trigger_Count -type AlertPolicy_Condition_Trigger_Percent = src.AlertPolicy_Condition_Trigger_Percent - -// A content string and a MIME type that describes the content string's -// format. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type AlertPolicy_Documentation = src.AlertPolicy_Documentation - -// An SLI measuring performance on a well-known service type. Performance will -// be computed on the basis of pre-defined metrics. The type of the -// `service_resource` determines the metrics to use and the -// `service_resource.labels` and `metric_labels` are used to construct a -// monitoring filter to filter that metric down to just the data relevant to -// this service. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type BasicSli = src.BasicSli -type BasicSli_Availability = src.BasicSli_Availability - -// Future parameters for the availability SLI. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type BasicSli_AvailabilityCriteria = src.BasicSli_AvailabilityCriteria -type BasicSli_Latency = src.BasicSli_Latency - -// Parameters for a latency threshold SLI. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type BasicSli_LatencyCriteria = src.BasicSli_LatencyCriteria - -// Specifies an ordering relationship on two arguments, called `left` and -// `right`. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ComparisonType = src.ComparisonType - -// The protocol for the `CreateAlertPolicy` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type CreateAlertPolicyRequest = src.CreateAlertPolicyRequest - -// The `CreateGroup` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type CreateGroupRequest = src.CreateGroupRequest - -// The `CreateMetricDescriptor` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type CreateMetricDescriptorRequest = src.CreateMetricDescriptorRequest - -// The `CreateNotificationChannel` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type CreateNotificationChannelRequest = src.CreateNotificationChannelRequest - -// The `CreateServiceLevelObjective` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type CreateServiceLevelObjectiveRequest = src.CreateServiceLevelObjectiveRequest - -// The `CreateService` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type CreateServiceRequest = src.CreateServiceRequest - -// DEPRECATED. Used to hold per-time-series error status. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type CreateTimeSeriesError = src.CreateTimeSeriesError - -// The `CreateTimeSeries` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type CreateTimeSeriesRequest = src.CreateTimeSeriesRequest - -// Summary of the result of a failed request to write data to a time series. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type CreateTimeSeriesSummary = src.CreateTimeSeriesSummary - -// Detailed information about an error category. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type CreateTimeSeriesSummary_Error = src.CreateTimeSeriesSummary_Error - -// The protocol for the `CreateUptimeCheckConfig` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type CreateUptimeCheckConfigRequest = src.CreateUptimeCheckConfigRequest - -// The protocol for the `DeleteAlertPolicy` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type DeleteAlertPolicyRequest = src.DeleteAlertPolicyRequest - -// The `DeleteGroup` request. The default behavior is to be able to delete a -// single group without any descendants. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type DeleteGroupRequest = src.DeleteGroupRequest - -// The `DeleteMetricDescriptor` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type DeleteMetricDescriptorRequest = src.DeleteMetricDescriptorRequest - -// The `DeleteNotificationChannel` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type DeleteNotificationChannelRequest = src.DeleteNotificationChannelRequest - -// The `DeleteServiceLevelObjective` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type DeleteServiceLevelObjectiveRequest = src.DeleteServiceLevelObjectiveRequest - -// The `DeleteService` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type DeleteServiceRequest = src.DeleteServiceRequest - -// The protocol for the `DeleteUptimeCheckConfig` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type DeleteUptimeCheckConfigRequest = src.DeleteUptimeCheckConfigRequest - -// A `DistributionCut` defines a `TimeSeries` and thresholds used for -// measuring good service and total service. The `TimeSeries` must have -// `ValueType = DISTRIBUTION` and `MetricKind = DELTA` or `MetricKind = -// CUMULATIVE`. The computed `good_service` will be the estimated count of -// values in the `Distribution` that fall within the specified `min` and `max`. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type DistributionCut = src.DistributionCut - -// A set of (label, value) pairs that were removed from a Distribution time -// series during aggregation and then added as an attachment to a -// Distribution.Exemplar. The full label set for the exemplars is constructed -// by using the dropped pairs in combination with the label values that remain -// on the aggregated Distribution time series. The constructed full label set -// can be used to identify the specific entity, such as the instance or job, -// which might be contributing to a long-tail. However, with dropped labels, -// the storage requirements are reduced because only the aggregated -// distribution values for a large group of time series are stored. Note that -// there are no guarantees on ordering of the labels from exemplar-to-exemplar -// and from distribution-to-distribution in the same stream, and there may be -// duplicates. It is up to clients to resolve any ambiguities. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type DroppedLabels = src.DroppedLabels - -// The protocol for the `GetAlertPolicy` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type GetAlertPolicyRequest = src.GetAlertPolicyRequest - -// The `GetGroup` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type GetGroupRequest = src.GetGroupRequest - -// The `GetMetricDescriptor` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type GetMetricDescriptorRequest = src.GetMetricDescriptorRequest - -// The `GetMonitoredResourceDescriptor` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type GetMonitoredResourceDescriptorRequest = src.GetMonitoredResourceDescriptorRequest - -// The `GetNotificationChannelDescriptor` response. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type GetNotificationChannelDescriptorRequest = src.GetNotificationChannelDescriptorRequest - -// The `GetNotificationChannel` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type GetNotificationChannelRequest = src.GetNotificationChannelRequest - -// The `GetNotificationChannelVerificationCode` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type GetNotificationChannelVerificationCodeRequest = src.GetNotificationChannelVerificationCodeRequest - -// The `GetNotificationChannelVerificationCode` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type GetNotificationChannelVerificationCodeResponse = src.GetNotificationChannelVerificationCodeResponse - -// The `GetServiceLevelObjective` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type GetServiceLevelObjectiveRequest = src.GetServiceLevelObjectiveRequest - -// The `GetService` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type GetServiceRequest = src.GetServiceRequest - -// The protocol for the `GetUptimeCheckConfig` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type GetUptimeCheckConfigRequest = src.GetUptimeCheckConfigRequest - -// The description of a dynamic collection of monitored resources. Each group -// has a filter that is matched against monitored resources and their -// associated metadata. If a group's filter matches an available monitored -// resource, then that resource is a member of that group. Groups can contain -// any number of monitored resources, and each monitored resource can be a -// member of any number of groups. Groups can be nested in parent-child -// hierarchies. The `parentName` field identifies an optional parent for each -// group. If a group has a parent, then the only monitored resources available -// to be matched by the group's filter are the resources contained in the -// parent group. In other words, a group contains the monitored resources that -// match its filter and the filters of all the group's ancestors. A group -// without a parent can contain any monitored resource. For example, consider -// an infrastructure running a set of instances with two user-defined tags: -// `"environment"` and `"role"`. A parent group has a filter, -// `environment="production"`. A child of that parent group has a filter, -// `role="transcoder"`. The parent group contains all instances in the -// production environment, regardless of their roles. The child group contains -// instances that have the transcoder role *and* are in the production -// environment. The monitored resources contained in a group can change at any -// moment, depending on what resources exist and what filters are associated -// with the group and its ancestors. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type Group = src.Group - -// The supported resource types that can be used as values of -// `group_resource.resource_type`. `INSTANCE` includes `gce_instance` and -// `aws_ec2_instance` resource types. The resource types `gae_app` and -// `uptime_url` are not valid here because group checks on App Engine modules -// and URLs are not allowed. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type GroupResourceType = src.GroupResourceType - -// GroupServiceClient is the client API for GroupService service. For -// semantics around ctx use and closing/ending streaming RPCs, please refer to -// https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type GroupServiceClient = src.GroupServiceClient - -// GroupServiceServer is the server API for GroupService service. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type GroupServiceServer = src.GroupServiceServer - -// An internal checker allows Uptime checks to run on private/internal GCP -// resources. Deprecated: Do not use. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type InternalChecker = src.InternalChecker - -// Operational states for an internal checker. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type InternalChecker_State = src.InternalChecker_State - -// A label value. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type LabelValue = src.LabelValue -type LabelValue_BoolValue = src.LabelValue_BoolValue -type LabelValue_Int64Value = src.LabelValue_Int64Value -type LabelValue_StringValue = src.LabelValue_StringValue - -// The protocol for the `ListAlertPolicies` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListAlertPoliciesRequest = src.ListAlertPoliciesRequest - -// The protocol for the `ListAlertPolicies` response. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListAlertPoliciesResponse = src.ListAlertPoliciesResponse - -// The `ListGroupMembers` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListGroupMembersRequest = src.ListGroupMembersRequest - -// The `ListGroupMembers` response. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListGroupMembersResponse = src.ListGroupMembersResponse - -// The `ListGroup` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListGroupsRequest = src.ListGroupsRequest -type ListGroupsRequest_AncestorsOfGroup = src.ListGroupsRequest_AncestorsOfGroup -type ListGroupsRequest_ChildrenOfGroup = src.ListGroupsRequest_ChildrenOfGroup -type ListGroupsRequest_DescendantsOfGroup = src.ListGroupsRequest_DescendantsOfGroup - -// The `ListGroups` response. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListGroupsResponse = src.ListGroupsResponse - -// The `ListMetricDescriptors` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListMetricDescriptorsRequest = src.ListMetricDescriptorsRequest - -// The `ListMetricDescriptors` response. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListMetricDescriptorsResponse = src.ListMetricDescriptorsResponse - -// The `ListMonitoredResourceDescriptors` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListMonitoredResourceDescriptorsRequest = src.ListMonitoredResourceDescriptorsRequest - -// The `ListMonitoredResourceDescriptors` response. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListMonitoredResourceDescriptorsResponse = src.ListMonitoredResourceDescriptorsResponse - -// The `ListNotificationChannelDescriptors` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListNotificationChannelDescriptorsRequest = src.ListNotificationChannelDescriptorsRequest - -// The `ListNotificationChannelDescriptors` response. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListNotificationChannelDescriptorsResponse = src.ListNotificationChannelDescriptorsResponse - -// The `ListNotificationChannels` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListNotificationChannelsRequest = src.ListNotificationChannelsRequest - -// The `ListNotificationChannels` response. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListNotificationChannelsResponse = src.ListNotificationChannelsResponse - -// The `ListServiceLevelObjectives` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListServiceLevelObjectivesRequest = src.ListServiceLevelObjectivesRequest - -// The `ListServiceLevelObjectives` response. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListServiceLevelObjectivesResponse = src.ListServiceLevelObjectivesResponse - -// The `ListServices` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListServicesRequest = src.ListServicesRequest - -// The `ListServices` response. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListServicesResponse = src.ListServicesResponse - -// The `ListTimeSeries` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListTimeSeriesRequest = src.ListTimeSeriesRequest - -// Controls which fields are returned by `ListTimeSeries`. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListTimeSeriesRequest_TimeSeriesView = src.ListTimeSeriesRequest_TimeSeriesView - -// The `ListTimeSeries` response. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListTimeSeriesResponse = src.ListTimeSeriesResponse - -// The protocol for the `ListUptimeCheckConfigs` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListUptimeCheckConfigsRequest = src.ListUptimeCheckConfigsRequest - -// The protocol for the `ListUptimeCheckConfigs` response. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListUptimeCheckConfigsResponse = src.ListUptimeCheckConfigsResponse - -// The protocol for the `ListUptimeCheckIps` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListUptimeCheckIpsRequest = src.ListUptimeCheckIpsRequest - -// The protocol for the `ListUptimeCheckIps` response. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ListUptimeCheckIpsResponse = src.ListUptimeCheckIpsResponse - -// MetricServiceClient is the client API for MetricService service. For -// semantics around ctx use and closing/ending streaming RPCs, please refer to -// https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type MetricServiceClient = src.MetricServiceClient - -// MetricServiceServer is the server API for MetricService service. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type MetricServiceServer = src.MetricServiceServer - -// Describes a change made to a configuration. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type MutationRecord = src.MutationRecord - -// A `NotificationChannel` is a medium through which an alert is delivered -// when a policy violation is detected. Examples of channels include email, -// SMS, and third-party messaging applications. Fields containing sensitive -// information like authentication tokens or contact info are only partially -// populated on retrieval. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type NotificationChannel = src.NotificationChannel - -// A description of a notification channel. The descriptor includes the -// properties of the channel and the set of labels or fields that must be -// specified to configure channels of a given type. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type NotificationChannelDescriptor = src.NotificationChannelDescriptor - -// NotificationChannelServiceClient is the client API for -// NotificationChannelService service. For semantics around ctx use and -// closing/ending streaming RPCs, please refer to -// https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type NotificationChannelServiceClient = src.NotificationChannelServiceClient - -// NotificationChannelServiceServer is the server API for -// NotificationChannelService service. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type NotificationChannelServiceServer = src.NotificationChannelServiceServer - -// Indicates whether the channel has been verified or not. It is illegal to -// specify this field in a -// [`CreateNotificationChannel`][google.monitoring.v3.NotificationChannelService.CreateNotificationChannel] -// or an -// [`UpdateNotificationChannel`][google.monitoring.v3.NotificationChannelService.UpdateNotificationChannel] -// operation. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type NotificationChannel_VerificationStatus = src.NotificationChannel_VerificationStatus - -// A single data point in a time series. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type Point = src.Point - -// An error associated with a query in the time series query language format. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type QueryError = src.QueryError - -// This is an error detail intended to be used with INVALID_ARGUMENT errors. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type QueryErrorList = src.QueryErrorList - -// QueryServiceClient is the client API for QueryService service. For -// semantics around ctx use and closing/ending streaming RPCs, please refer to -// https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type QueryServiceClient = src.QueryServiceClient - -// QueryServiceServer is the server API for QueryService service. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type QueryServiceServer = src.QueryServiceServer - -// The `QueryTimeSeries` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type QueryTimeSeriesRequest = src.QueryTimeSeriesRequest - -// The `QueryTimeSeries` response. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type QueryTimeSeriesResponse = src.QueryTimeSeriesResponse - -// Range of numerical values within `min` and `max`. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type Range = src.Range - -// Service Level Indicators for which atomic units of service are counted -// directly. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type RequestBasedSli = src.RequestBasedSli -type RequestBasedSli_DistributionCut = src.RequestBasedSli_DistributionCut -type RequestBasedSli_GoodTotalRatio = src.RequestBasedSli_GoodTotalRatio - -// The `SendNotificationChannelVerificationCode` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type SendNotificationChannelVerificationCodeRequest = src.SendNotificationChannelVerificationCodeRequest - -// A `Service` is a discrete, autonomous, and network-accessible unit, -// designed to solve an individual concern -// ([Wikipedia](https://en.wikipedia.org/wiki/Service-orientation)). In Cloud -// Monitoring, a `Service` acts as the root resource under which operational -// aspects of the service are accessible. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type Service = src.Service - -// A Service-Level Indicator (SLI) describes the "performance" of a service. -// For some services, the SLI is well-defined. In such cases, the SLI can be -// described easily by referencing the well-known SLI and providing the needed -// parameters. Alternatively, a "custom" SLI can be defined with a query to the -// underlying metric store. An SLI is defined to be `good_service / -// total_service` over any queried time interval. The value of performance -// always falls into the range `0 <= performance <= 1`. A custom SLI describes -// how to compute this ratio, whether this is by dividing values from a pair of -// time series, cutting a `Distribution` into good and bad counts, or counting -// time windows in which the service complies with a criterion. For separation -// of concerns, a single Service-Level Indicator measures performance for only -// one aspect of service quality, such as fraction of successful queries or -// fast-enough queries. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ServiceLevelIndicator = src.ServiceLevelIndicator -type ServiceLevelIndicator_BasicSli = src.ServiceLevelIndicator_BasicSli -type ServiceLevelIndicator_RequestBased = src.ServiceLevelIndicator_RequestBased -type ServiceLevelIndicator_WindowsBased = src.ServiceLevelIndicator_WindowsBased - -// A Service-Level Objective (SLO) describes a level of desired good service. -// It consists of a service-level indicator (SLI), a performance goal, and a -// period over which the objective is to be evaluated against that goal. The -// SLO can use SLIs defined in a number of different manners. Typical SLOs -// might include "99% of requests in each rolling week have latency below 200 -// milliseconds" or "99.5% of requests in each calendar month return -// successfully." -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ServiceLevelObjective = src.ServiceLevelObjective -type ServiceLevelObjective_CalendarPeriod = src.ServiceLevelObjective_CalendarPeriod -type ServiceLevelObjective_RollingPeriod = src.ServiceLevelObjective_RollingPeriod - -// `ServiceLevelObjective.View` determines what form of -// `ServiceLevelObjective` is returned from `GetServiceLevelObjective`, -// `ListServiceLevelObjectives`, and `ListServiceLevelObjectiveVersions` RPCs. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ServiceLevelObjective_View = src.ServiceLevelObjective_View - -// ServiceMonitoringServiceClient is the client API for -// ServiceMonitoringService service. For semantics around ctx use and -// closing/ending streaming RPCs, please refer to -// https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ServiceMonitoringServiceClient = src.ServiceMonitoringServiceClient - -// ServiceMonitoringServiceServer is the server API for -// ServiceMonitoringService service. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ServiceMonitoringServiceServer = src.ServiceMonitoringServiceServer - -// The tier of service for a Workspace. Please see the [service tiers -// documentation](https://cloud.google.com/monitoring/workspaces/tiers) for -// more details. Deprecated: Do not use. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type ServiceTier = src.ServiceTier - -// App Engine service. Learn more at https://cloud.google.com/appengine. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type Service_AppEngine = src.Service_AppEngine -type Service_AppEngine_ = src.Service_AppEngine_ - -// Cloud Endpoints service. Learn more at https://cloud.google.com/endpoints. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type Service_CloudEndpoints = src.Service_CloudEndpoints -type Service_CloudEndpoints_ = src.Service_CloudEndpoints_ - -// Istio service scoped to a single Kubernetes cluster. Learn more at -// https://istio.io. Clusters running OSS Istio will have their services -// ingested as this type. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type Service_ClusterIstio = src.Service_ClusterIstio -type Service_ClusterIstio_ = src.Service_ClusterIstio_ - -// Custom view of service telemetry. Currently a place-holder pending final -// design. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type Service_Custom = src.Service_Custom -type Service_Custom_ = src.Service_Custom_ - -// Canonical service scoped to an Istio mesh. Anthos clusters running ASM >= -// 1.6.8 will have their services ingested as this type. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type Service_IstioCanonicalService = src.Service_IstioCanonicalService -type Service_IstioCanonicalService_ = src.Service_IstioCanonicalService_ - -// Istio service scoped to an Istio mesh. Anthos clusters running ASM < 1.6.8 -// will have their services ingested as this type. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type Service_MeshIstio = src.Service_MeshIstio -type Service_MeshIstio_ = src.Service_MeshIstio_ - -// Configuration for how to query telemetry on a Service. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type Service_Telemetry = src.Service_Telemetry - -// The context of a span. This is attached to an -// [Exemplar][google.api.Distribution.Exemplar] in -// [Distribution][google.api.Distribution] values during aggregation. It -// contains the name of a span with format: -// projects/[PROJECT_ID_OR_NUMBER]/traces/[TRACE_ID]/spans/[SPAN_ID] -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type SpanContext = src.SpanContext - -// A locator for text. Indicates a particular part of the text of a request or -// of an object referenced in the request. For example, suppose the request -// field `text` contains: text: "The quick brown fox jumps over the lazy dog." -// Then the locator: source: "text" start_position { line: 1 column: 17 } -// end_position { line: 1 column: 19 } refers to the part of the text: "fox". -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type TextLocator = src.TextLocator - -// The position of a byte within the text. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type TextLocator_Position = src.TextLocator_Position - -// A closed time interval. It extends from the start time to the end time, and -// includes both: `[startTime, endTime]`. Valid time intervals depend on the -// [`MetricKind`](https://cloud.google.com/monitoring/api/ref_v3/rest/v3/projects.metricDescriptors#MetricKind) -// of the metric value. The end time must not be earlier than the start time. -// When writing data points, the start time must not be more than 25 hours in -// the past and the end time must not be more than five minutes in the future. -// - For `GAUGE` metrics, the `startTime` value is technically optional; if no -// value is specified, the start time defaults to the value of the end time, -// and the interval represents a single point in time. If both start and end -// times are specified, they must be identical. Such an interval is valid only -// for `GAUGE` metrics, which are point-in-time measurements. The end time of a -// new interval must be at least a millisecond after the end time of the -// previous interval. - For `DELTA` metrics, the start time and end time must -// specify a non-zero interval, with subsequent points specifying contiguous -// and non-overlapping intervals. For `DELTA` metrics, the start time of the -// next interval must be at least a millisecond after the end time of the -// previous interval. - For `CUMULATIVE` metrics, the start time and end time -// must specify a non-zero interval, with subsequent points specifying the same -// start time and increasing end times, until an event resets the cumulative -// value to zero and sets a new start time for the following points. The new -// start time must be at least a millisecond after the end time of the previous -// interval. - The start time of a new interval must be at least a millisecond -// after the end time of the previous interval because intervals are closed. If -// the start time of a new interval is the same as the end time of the previous -// interval, then data written at the new start time could overwrite data -// written at the previous end time. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type TimeInterval = src.TimeInterval - -// A collection of data points that describes the time-varying values of a -// metric. A time series is identified by a combination of a fully-specified -// monitored resource and a fully-specified metric. This type is used for both -// listing and creating time series. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type TimeSeries = src.TimeSeries - -// Represents the values of a time series associated with a -// TimeSeriesDescriptor. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type TimeSeriesData = src.TimeSeriesData - -// A point's value columns and time interval. Each point has one or more point -// values corresponding to the entries in `point_descriptors` field in the -// TimeSeriesDescriptor associated with this object. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type TimeSeriesData_PointData = src.TimeSeriesData_PointData - -// A descriptor for the labels and points in a time series. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type TimeSeriesDescriptor = src.TimeSeriesDescriptor - -// A descriptor for the value columns in a data point. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type TimeSeriesDescriptor_ValueDescriptor = src.TimeSeriesDescriptor_ValueDescriptor - -// A `TimeSeriesRatio` specifies two `TimeSeries` to use for computing the -// `good_service / total_service` ratio. The specified `TimeSeries` must have -// `ValueType = DOUBLE` or `ValueType = INT64` and must have `MetricKind = -// DELTA` or `MetricKind = CUMULATIVE`. The `TimeSeriesRatio` must specify -// exactly two of good, bad, and total, and the relationship `good_service + -// bad_service = total_service` will be assumed. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type TimeSeriesRatio = src.TimeSeriesRatio - -// A single strongly-typed value. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type TypedValue = src.TypedValue -type TypedValue_BoolValue = src.TypedValue_BoolValue -type TypedValue_DistributionValue = src.TypedValue_DistributionValue -type TypedValue_DoubleValue = src.TypedValue_DoubleValue -type TypedValue_Int64Value = src.TypedValue_Int64Value -type TypedValue_StringValue = src.TypedValue_StringValue - -// UnimplementedAlertPolicyServiceServer can be embedded to have forward -// compatible implementations. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UnimplementedAlertPolicyServiceServer = src.UnimplementedAlertPolicyServiceServer - -// UnimplementedGroupServiceServer can be embedded to have forward compatible -// implementations. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UnimplementedGroupServiceServer = src.UnimplementedGroupServiceServer - -// UnimplementedMetricServiceServer can be embedded to have forward compatible -// implementations. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UnimplementedMetricServiceServer = src.UnimplementedMetricServiceServer - -// UnimplementedNotificationChannelServiceServer can be embedded to have -// forward compatible implementations. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UnimplementedNotificationChannelServiceServer = src.UnimplementedNotificationChannelServiceServer - -// UnimplementedQueryServiceServer can be embedded to have forward compatible -// implementations. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UnimplementedQueryServiceServer = src.UnimplementedQueryServiceServer - -// UnimplementedServiceMonitoringServiceServer can be embedded to have forward -// compatible implementations. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UnimplementedServiceMonitoringServiceServer = src.UnimplementedServiceMonitoringServiceServer - -// UnimplementedUptimeCheckServiceServer can be embedded to have forward -// compatible implementations. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UnimplementedUptimeCheckServiceServer = src.UnimplementedUptimeCheckServiceServer - -// The protocol for the `UpdateAlertPolicy` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UpdateAlertPolicyRequest = src.UpdateAlertPolicyRequest - -// The `UpdateGroup` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UpdateGroupRequest = src.UpdateGroupRequest - -// The `UpdateNotificationChannel` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UpdateNotificationChannelRequest = src.UpdateNotificationChannelRequest - -// The `UpdateServiceLevelObjective` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UpdateServiceLevelObjectiveRequest = src.UpdateServiceLevelObjectiveRequest - -// The `UpdateService` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UpdateServiceRequest = src.UpdateServiceRequest - -// The protocol for the `UpdateUptimeCheckConfig` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UpdateUptimeCheckConfigRequest = src.UpdateUptimeCheckConfigRequest - -// This message configures which resources and services to monitor for -// availability. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UptimeCheckConfig = src.UptimeCheckConfig - -// Optional. Used to perform content matching. This allows matching based on -// substrings and regular expressions, together with their negations. Only the -// first 4 MB of an HTTP or HTTPS check's response (and the first -// 1 MB of a TCP check's response) are examined for purposes of content -// matching. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UptimeCheckConfig_ContentMatcher = src.UptimeCheckConfig_ContentMatcher - -// Options to perform content matching. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UptimeCheckConfig_ContentMatcher_ContentMatcherOption = src.UptimeCheckConfig_ContentMatcher_ContentMatcherOption - -// Information involved in an HTTP/HTTPS Uptime check request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UptimeCheckConfig_HttpCheck = src.UptimeCheckConfig_HttpCheck -type UptimeCheckConfig_HttpCheck_ = src.UptimeCheckConfig_HttpCheck_ - -// The authentication parameters to provide to the specified resource or URL -// that requires a username and password. Currently, only [Basic HTTP -// authentication](https://tools.ietf.org/html/rfc7617) is supported in Uptime -// checks. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UptimeCheckConfig_HttpCheck_BasicAuthentication = src.UptimeCheckConfig_HttpCheck_BasicAuthentication - -// Header options corresponding to the content type of a HTTP request body. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UptimeCheckConfig_HttpCheck_ContentType = src.UptimeCheckConfig_HttpCheck_ContentType - -// The HTTP request method options. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UptimeCheckConfig_HttpCheck_RequestMethod = src.UptimeCheckConfig_HttpCheck_RequestMethod -type UptimeCheckConfig_MonitoredResource = src.UptimeCheckConfig_MonitoredResource - -// The resource submessage for group checks. It can be used instead of a -// monitored resource, when multiple resources are being monitored. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UptimeCheckConfig_ResourceGroup = src.UptimeCheckConfig_ResourceGroup -type UptimeCheckConfig_ResourceGroup_ = src.UptimeCheckConfig_ResourceGroup_ - -// Information required for a TCP Uptime check request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UptimeCheckConfig_TcpCheck = src.UptimeCheckConfig_TcpCheck -type UptimeCheckConfig_TcpCheck_ = src.UptimeCheckConfig_TcpCheck_ - -// Contains the region, location, and list of IP addresses where checkers in -// the location run from. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UptimeCheckIp = src.UptimeCheckIp - -// The regions from which an Uptime check can be run. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UptimeCheckRegion = src.UptimeCheckRegion - -// UptimeCheckServiceClient is the client API for UptimeCheckService service. -// For semantics around ctx use and closing/ending streaming RPCs, please refer -// to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UptimeCheckServiceClient = src.UptimeCheckServiceClient - -// UptimeCheckServiceServer is the server API for UptimeCheckService service. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type UptimeCheckServiceServer = src.UptimeCheckServiceServer - -// The `VerifyNotificationChannel` request. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type VerifyNotificationChannelRequest = src.VerifyNotificationChannelRequest - -// A `WindowsBasedSli` defines `good_service` as the count of time windows for -// which the provided service was of good quality. Criteria for determining if -// service was good are embedded in the `window_criterion`. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type WindowsBasedSli = src.WindowsBasedSli -type WindowsBasedSli_GoodBadMetricFilter = src.WindowsBasedSli_GoodBadMetricFilter -type WindowsBasedSli_GoodTotalRatioThreshold = src.WindowsBasedSli_GoodTotalRatioThreshold -type WindowsBasedSli_MetricMeanInRange = src.WindowsBasedSli_MetricMeanInRange - -// A `MetricRange` is used when each window is good when the value x of a -// single `TimeSeries` satisfies `range.min <= x <= range.max`. The provided -// `TimeSeries` must have `ValueType = INT64` or `ValueType = DOUBLE` and -// `MetricKind = GAUGE`. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type WindowsBasedSli_MetricRange = src.WindowsBasedSli_MetricRange -type WindowsBasedSli_MetricSumInRange = src.WindowsBasedSli_MetricSumInRange - -// A `PerformanceThreshold` is used when each window is good when that window -// has a sufficiently high `performance`. -// -// Deprecated: Please use types in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -type WindowsBasedSli_PerformanceThreshold = src.WindowsBasedSli_PerformanceThreshold -type WindowsBasedSli_PerformanceThreshold_BasicSliPerformance = src.WindowsBasedSli_PerformanceThreshold_BasicSliPerformance -type WindowsBasedSli_PerformanceThreshold_Performance = src.WindowsBasedSli_PerformanceThreshold_Performance - -// Deprecated: Please use funcs in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -func NewAlertPolicyServiceClient(cc grpc.ClientConnInterface) AlertPolicyServiceClient { - return src.NewAlertPolicyServiceClient(cc) -} - -// Deprecated: Please use funcs in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -func NewGroupServiceClient(cc grpc.ClientConnInterface) GroupServiceClient { - return src.NewGroupServiceClient(cc) -} - -// Deprecated: Please use funcs in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -func NewMetricServiceClient(cc grpc.ClientConnInterface) MetricServiceClient { - return src.NewMetricServiceClient(cc) -} - -// Deprecated: Please use funcs in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -func NewNotificationChannelServiceClient(cc grpc.ClientConnInterface) NotificationChannelServiceClient { - return src.NewNotificationChannelServiceClient(cc) -} - -// Deprecated: Please use funcs in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -func NewQueryServiceClient(cc grpc.ClientConnInterface) QueryServiceClient { - return src.NewQueryServiceClient(cc) -} - -// Deprecated: Please use funcs in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -func NewServiceMonitoringServiceClient(cc grpc.ClientConnInterface) ServiceMonitoringServiceClient { - return src.NewServiceMonitoringServiceClient(cc) -} - -// Deprecated: Please use funcs in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -func NewUptimeCheckServiceClient(cc grpc.ClientConnInterface) UptimeCheckServiceClient { - return src.NewUptimeCheckServiceClient(cc) -} - -// Deprecated: Please use funcs in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -func RegisterAlertPolicyServiceServer(s *grpc.Server, srv AlertPolicyServiceServer) { - src.RegisterAlertPolicyServiceServer(s, srv) -} - -// Deprecated: Please use funcs in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -func RegisterGroupServiceServer(s *grpc.Server, srv GroupServiceServer) { - src.RegisterGroupServiceServer(s, srv) -} - -// Deprecated: Please use funcs in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -func RegisterMetricServiceServer(s *grpc.Server, srv MetricServiceServer) { - src.RegisterMetricServiceServer(s, srv) -} - -// Deprecated: Please use funcs in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -func RegisterNotificationChannelServiceServer(s *grpc.Server, srv NotificationChannelServiceServer) { - src.RegisterNotificationChannelServiceServer(s, srv) -} - -// Deprecated: Please use funcs in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -func RegisterQueryServiceServer(s *grpc.Server, srv QueryServiceServer) { - src.RegisterQueryServiceServer(s, srv) -} - -// Deprecated: Please use funcs in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -func RegisterServiceMonitoringServiceServer(s *grpc.Server, srv ServiceMonitoringServiceServer) { - src.RegisterServiceMonitoringServiceServer(s, srv) -} - -// Deprecated: Please use funcs in: cloud.google.com/go/monitoring/apiv3/v2/monitoringpb -func RegisterUptimeCheckServiceServer(s *grpc.Server, srv UptimeCheckServiceServer) { - src.RegisterUptimeCheckServiceServer(s, srv) -} diff --git a/vendor/modules.txt b/vendor/modules.txt index 092fd4532a..7671d879f8 100644 --- a/vendor/modules.txt +++ b/vendor/modules.txt @@ -569,7 +569,6 @@ google.golang.org/appengine/socket google.golang.org/appengine/urlfetch # google.golang.org/genproto v0.0.0-20230711160842-782d3b101e98 ## explicit; go 1.19 -google.golang.org/genproto/googleapis/monitoring/v3 google.golang.org/genproto/googleapis/type/calendarperiod google.golang.org/genproto/internal # google.golang.org/genproto/googleapis/api v0.0.0-20230711160842-782d3b101e98 From 4cef4a3ae24cdac6a85566504df75f70cfb3f2a7 Mon Sep 17 00:00:00 2001 From: Daniel Hrabovcak Date: Thu, 7 Dec 2023 09:49:18 -0500 Subject: [PATCH 3/4] Fix e2e test lint warnings --- e2e/kubeutil/pod.go | 10 ++++++---- e2e/operator_context_test.go | 9 ++++++--- 2 files changed, 12 insertions(+), 7 deletions(-) diff --git a/e2e/kubeutil/pod.go b/e2e/kubeutil/pod.go index 551ee8528e..8a47fea30b 100644 --- a/e2e/kubeutil/pod.go +++ b/e2e/kubeutil/pod.go @@ -37,11 +37,13 @@ import ( func IsPodContainerReady(ctx context.Context, restConfig *rest.Config, pod *corev1.Pod, container string) error { for _, status := range pod.Status.ContainerStatuses { - if status.Name == container && !status.Ready { - key := client.ObjectKeyFromObject(pod) - return fmt.Errorf("pod %s container %s not ready: %s", key, status.Name, containerStateString(&status.State)) + if status.Name == container { + if !status.Ready { + key := client.ObjectKeyFromObject(pod) + return fmt.Errorf("pod %s container %s not ready: %s", key, status.Name, containerStateString(&status.State)) + } + return nil } - return nil } key := client.ObjectKeyFromObject(pod) return fmt.Errorf("no container named %s found in pod %s", container, key) diff --git a/e2e/operator_context_test.go b/e2e/operator_context_test.go index 31c7c4b873..4f1e799ae8 100644 --- a/e2e/operator_context_test.go +++ b/e2e/operator_context_test.go @@ -96,7 +96,7 @@ func newClient() (client.Client, error) { }) } -func setRESTConfigDefaults(restConfig *rest.Config) { +func setRESTConfigDefaults(restConfig *rest.Config) error { // https://github.com/kubernetes/client-go/issues/657 // https://github.com/kubernetes/client-go/issues/1159 // https://github.com/kubernetes/kubectl/blob/6fb6697c77304b7aaf43a520d30cb17563c69886/pkg/cmd/util/kubectl_match_version.go#L115 @@ -110,7 +110,7 @@ func setRESTConfigDefaults(restConfig *rest.Config) { if restConfig.NegotiatedSerializer == nil { restConfig.NegotiatedSerializer = scheme.Codecs.WithoutConversion() } - rest.SetKubernetesDefaults(restConfig) + return rest.SetKubernetesDefaults(restConfig) } // TestMain injects custom flags and adds extra signal handling to ensure testing @@ -140,11 +140,14 @@ func TestMain(m *testing.M) { var err error kubeconfig, err = ctrl.GetConfig() - setRESTConfigDefaults(kubeconfig) if err != nil { fmt.Fprintln(os.Stderr, "Loading kubeconfig failed:", err) os.Exit(1) } + if err := setRESTConfigDefaults(kubeconfig); err != nil { + fmt.Fprintln(os.Stderr, "Setting REST config defaults failed:", err) + os.Exit(1) + } c, err := newClient() if err != nil { From 8770d0b890783102c4131d19353a6daff21af1cf Mon Sep 17 00:00:00 2001 From: Daniel Hrabovcak Date: Thu, 7 Dec 2023 09:50:08 -0500 Subject: [PATCH 4/4] Fix deprecated, missing error and type cast lint checks --- cmd/config-reloader/main.go | 9 ++-- cmd/frontend/main.go | 18 ++++++-- cmd/operator/main.go | 8 ++-- cmd/rule-evaluator/main.go | 11 +++-- pkg/export/bench/app/example_app.go | 10 ++-- pkg/export/bench/server.go | 2 +- pkg/export/export.go | 3 +- pkg/export/export_test.go | 15 ++++-- pkg/export/gcm/promtest/local_export.go | 11 ++++- pkg/export/gcm/promtest/promtest.go | 32 +++++++++---- pkg/export/gcm/promtest/skip.go | 2 +- pkg/export/series_cache_test.go | 4 +- pkg/export/transform.go | 6 +-- pkg/export/transform_test.go | 46 +++++++++---------- .../apis/monitoring/v1alpha1/types.go | 6 --- pkg/operator/collection.go | 12 ----- pkg/operator/collection_test.go | 10 ++-- pkg/rules/rules_test.go | 6 ++- pkg/ui/ui.go | 4 +- 19 files changed, 125 insertions(+), 90 deletions(-) diff --git a/cmd/config-reloader/main.go b/cmd/config-reloader/main.go index 7592c0246d..e0cf30706c 100644 --- a/cmd/config-reloader/main.go +++ b/cmd/config-reloader/main.go @@ -29,6 +29,7 @@ import ( "github.com/go-kit/log/level" "github.com/oklog/run" "github.com/prometheus/client_golang/prometheus" + "github.com/prometheus/client_golang/prometheus/collectors" "github.com/prometheus/client_golang/prometheus/promhttp" "github.com/thanos-io/thanos/pkg/reloader" ) @@ -56,8 +57,8 @@ func main() { metrics := prometheus.NewRegistry() metrics.MustRegister( - prometheus.NewGoCollector(), - prometheus.NewProcessCollector(prometheus.ProcessCollectorOpts{}), + collectors.NewGoCollector(), + collectors.NewProcessCollector(collectors.ProcessCollectorOpts{}), ) reloadURL, err := url.Parse(*reloadURLStr) @@ -154,7 +155,9 @@ func main() { return server.ListenAndServe() }, func(err error) { ctx, cancel := context.WithTimeout(context.Background(), time.Minute) - server.Shutdown(ctx) + if err := server.Shutdown(ctx); err != nil { + level.Error(logger).Log("msg", "unable to shut down server", "err", err) + } cancel() }) } diff --git a/cmd/frontend/main.go b/cmd/frontend/main.go index 20885a63e5..47892d866a 100644 --- a/cmd/frontend/main.go +++ b/cmd/frontend/main.go @@ -37,6 +37,7 @@ import ( "github.com/go-kit/log/level" "github.com/oklog/run" "github.com/prometheus/client_golang/prometheus" + "github.com/prometheus/client_golang/prometheus/collectors" "github.com/prometheus/client_golang/prometheus/promhttp" "google.golang.org/api/option" apihttp "google.golang.org/api/transport/http" @@ -74,8 +75,8 @@ func main() { metrics := prometheus.NewRegistry() metrics.MustRegister( - prometheus.NewGoCollector(), - prometheus.NewProcessCollector(prometheus.ProcessCollectorOpts{}), + collectors.NewGoCollector(), + collectors.NewProcessCollector(collectors.ProcessCollectorOpts{}), ) if *projectID == "" { @@ -147,8 +148,11 @@ func main() { level.Info(logger).Log("msg", "Starting web server for metrics", "listen", *listenAddress) return server.ListenAndServe() }, func(err error) { - ctx, _ = context.WithTimeout(ctx, time.Minute) - server.Shutdown(ctx) + ctx, timeoutCancel := context.WithTimeout(ctx, time.Minute) + if err := server.Shutdown(ctx); err != nil { + level.Error(logger).Log("msg", "unable to shut down server", "err", err) + } + timeoutCancel() cancel() }) } @@ -192,7 +196,11 @@ func forward(logger log.Logger, target *url.URL, transport http.RoundTripper) ht // /api/v1/series currently not accepting match[] params on POST. if req.URL.Path == "/api/v1/series" { method = "GET" - req.ParseForm() + if err := req.ParseForm(); err != nil { + level.Warn(logger).Log("msg", "parse form failed", "err", err) + w.WriteHeader(http.StatusInternalServerError) + return + } u.RawQuery = req.Form.Encode() } else { u.RawQuery = req.URL.RawQuery diff --git a/cmd/operator/main.go b/cmd/operator/main.go index 350b8177c6..586c0df2d2 100644 --- a/cmd/operator/main.go +++ b/cmd/operator/main.go @@ -38,10 +38,6 @@ import ( "github.com/GoogleCloudPlatform/prometheus-engine/pkg/operator" ) -func unstableFlagHelp(help string) string { - return help + " (Setting this flag voids any guarantees of proper behavior of the operator.)" -} - func main() { var ( defaultProjectID string @@ -147,7 +143,9 @@ func main() { return server.ListenAndServe() }, func(err error) { ctx, cancel := context.WithTimeout(context.Background(), time.Minute) - server.Shutdown(ctx) + if err := server.Shutdown(ctx); err != nil { + logger.Error(err, "unable to shut down server") + } cancel() }) } diff --git a/cmd/rule-evaluator/main.go b/cmd/rule-evaluator/main.go index ee74cc1ffe..ea04ad9a70 100644 --- a/cmd/rule-evaluator/main.go +++ b/cmd/rule-evaluator/main.go @@ -33,7 +33,6 @@ import ( "github.com/alecthomas/kingpin/v2" "github.com/go-kit/log" "github.com/go-kit/log/level" - grpc_prometheus "github.com/grpc-ecosystem/go-grpc-prometheus" "github.com/oklog/run" "google.golang.org/api/option" apihttp "google.golang.org/api/transport/http" @@ -41,6 +40,7 @@ import ( "github.com/prometheus/client_golang/api" v1 "github.com/prometheus/client_golang/api/prometheus/v1" "github.com/prometheus/client_golang/prometheus" + "github.com/prometheus/client_golang/prometheus/collectors" "github.com/prometheus/client_golang/prometheus/promhttp" "github.com/prometheus/common/model" "github.com/prometheus/prometheus/config" @@ -79,9 +79,8 @@ func main() { reg := prometheus.NewRegistry() reg.MustRegister( - prometheus.NewGoCollector(), - prometheus.NewProcessCollector(prometheus.ProcessCollectorOpts{}), - grpc_prometheus.DefaultClientMetrics, + collectors.NewGoCollector(), + collectors.NewProcessCollector(collectors.ProcessCollectorOpts{}), ) // The rule-evaluator version is identical to the export library version for now, so @@ -359,7 +358,9 @@ func main() { return server.ListenAndServe() }, func(err error) { ctx, cancel := context.WithTimeout(context.Background(), time.Minute) - server.Shutdown(ctx) + if err := server.Shutdown(ctx); err != nil { + level.Error(logger).Log("msg", "unable to shut down server", "err", err) + } cancel() }) } diff --git a/pkg/export/bench/app/example_app.go b/pkg/export/bench/app/example_app.go index eec98289ce..4e4e8dedfd 100644 --- a/pkg/export/bench/app/example_app.go +++ b/pkg/export/bench/app/example_app.go @@ -29,6 +29,7 @@ import ( "github.com/oklog/run" "github.com/prometheus/client_golang/prometheus" + "github.com/prometheus/client_golang/prometheus/collectors" "github.com/prometheus/client_golang/prometheus/promhttp" ) @@ -146,8 +147,8 @@ func main() { metrics := prometheus.NewRegistry() metrics.MustRegister( - prometheus.NewGoCollector(), - prometheus.NewProcessCollector(prometheus.ProcessCollectorOpts{}), + collectors.NewGoCollector(), + collectors.NewProcessCollector(collectors.ProcessCollectorOpts{}), metricIncomingRequestsPending, metricOutgoingRequestsPending, metricIncomingRequests, @@ -192,7 +193,10 @@ func main() { return server.ListenAndServe() }, func(err error) { ctx, cancel := context.WithTimeout(context.Background(), time.Minute) - server.Shutdown(ctx) + if err := server.Shutdown(ctx); err != http.ErrServerClosed { + log.Println("Unable to shutdown server", err) + os.Exit(1) + } cancel() }) } diff --git a/pkg/export/bench/server.go b/pkg/export/bench/server.go index db9cd94aab..e7fd60eda2 100644 --- a/pkg/export/bench/server.go +++ b/pkg/export/bench/server.go @@ -28,6 +28,7 @@ import ( grpc_prometheus "github.com/grpc-ecosystem/go-grpc-prometheus" "github.com/prometheus/client_golang/prometheus/promhttp" "google.golang.org/grpc" + _ "google.golang.org/grpc/encoding/gzip" ) func main() { @@ -46,7 +47,6 @@ func main() { srv := grpc.NewServer( grpc.StreamInterceptor(grpc_prometheus.StreamServerInterceptor), grpc.UnaryInterceptor(grpc_prometheus.UnaryServerInterceptor), - grpc.RPCDecompressor(grpc.NewGZIPDecompressor()), ) monitoring_pb.RegisterMetricServiceServer(srv, &server{latency: *backendLatency}) diff --git a/pkg/export/export.go b/pkg/export/export.go index e2540b8f7c..fafe78492a 100644 --- a/pkg/export/export.go +++ b/pkg/export/export.go @@ -43,6 +43,7 @@ import ( "github.com/prometheus/prometheus/tsdb/record" "google.golang.org/api/option" "google.golang.org/grpc" + "google.golang.org/grpc/credentials/insecure" "google.golang.org/grpc/encoding/gzip" ) @@ -281,7 +282,7 @@ func newMetricClient(ctx context.Context, opts ExporterOpts) (*monitoring.Metric if opts.DisableAuth { clientOpts = append(clientOpts, option.WithoutAuthentication(), - option.WithGRPCDialOption(grpc.WithInsecure()), + option.WithGRPCDialOption(grpc.WithTransportCredentials(insecure.NewCredentials())), ) } if opts.CredentialsFile != "" { diff --git a/pkg/export/export_test.go b/pkg/export/export_test.go index 3c0d277dfc..693487e984 100644 --- a/pkg/export/export_test.go +++ b/pkg/export/export_test.go @@ -36,6 +36,7 @@ import ( "google.golang.org/api/option" monitoredres_pb "google.golang.org/genproto/googleapis/api/monitoredres" "google.golang.org/grpc" + "google.golang.org/grpc/credentials/insecure" "google.golang.org/grpc/test/bufconn" empty_pb "google.golang.org/protobuf/types/known/emptypb" ) @@ -342,7 +343,11 @@ func TestExporter_drainBacklog(t *testing.T) { ) monitoring_pb.RegisterMetricServiceServer(srv, metricServer) - go srv.Serve(listener) + go func() { + if err := srv.Serve(listener); err != nil { + t.Errorf("gRPC server failed: %s", err) + } + }() defer srv.Stop() ctx, cancel := context.WithCancel(context.Background()) @@ -353,7 +358,7 @@ func TestExporter_drainBacklog(t *testing.T) { } metricClient, err := monitoring.NewMetricClient(ctx, option.WithoutAuthentication(), - option.WithGRPCDialOption(grpc.WithInsecure()), + option.WithGRPCDialOption(grpc.WithTransportCredentials(insecure.NewCredentials())), option.WithGRPCDialOption(grpc.WithContextDialer(bufDialer)), ) if err != nil { @@ -377,7 +382,11 @@ func TestExporter_drainBacklog(t *testing.T) { }, nil) } - go e.Run(ctx) + go func() { + if err := e.Run(ctx); err != nil { + t.Errorf("exporter run failed: %s", err) + } + }() // As our samples are all for the same series, each batch can only contain a single sample. // The exporter waits for the batch delay duration before sending it. // We sleep for an appropriate multiple of it to allow it to drain the shard. diff --git a/pkg/export/gcm/promtest/local_export.go b/pkg/export/gcm/promtest/local_export.go index 02d672af46..e91f7d5430 100644 --- a/pkg/export/gcm/promtest/local_export.go +++ b/pkg/export/gcm/promtest/local_export.go @@ -96,13 +96,20 @@ func (l *localExportWithGCM) start(t testing.TB, _ e2e.Environment) (v1.API, map } // Apply empty config, so resources labels are attached. - l.e.ApplyConfig(&config.DefaultConfig) + if err := l.e.ApplyConfig(&config.DefaultConfig); err != nil { + t.Fatalf("apply config: %s", err) + } l.e.SetLabelsByIDFunc(func(ref storage.SeriesRef) labels.Labels { return l.labelsByRef[ref] }) cancelableCtx, cancel := context.WithCancel(ctx) - go l.e.Run(cancelableCtx) + go func() { + if err := l.e.Run(cancelableCtx); err != nil { + // Cannot use "fatal" in goroutines, so we must use a regular error. + t.Errorf("exporter run: %v", err) + } + }() // TODO(bwplotka): Consider listening for KILL signal too. t.Cleanup(cancel) diff --git a/pkg/export/gcm/promtest/promtest.go b/pkg/export/gcm/promtest/promtest.go index 36cfa7f8c7..ebeec25478 100644 --- a/pkg/export/gcm/promtest/promtest.go +++ b/pkg/export/gcm/promtest/promtest.go @@ -48,8 +48,6 @@ type ingestionTest struct { testID string - env e2e.Environment - backends map[string]backend expectationsPerBackend map[string]model.Matrix @@ -171,13 +169,20 @@ type ingestionTestExpRecorder struct { func (ir *ingestionTestExpRecorder) Expect(val float64, metric prometheus.Metric, b Backend) ExpectationsRecorder { m := dto.Metric{} - metric.Write(&m) + if err := metric.Write(&m); err != nil { + ir.it.t.Fatalf("write metric: %s", err) + } + if m.GetSummary() != nil || m.GetHistogram() != nil { // TODO(bwplotka): Implement an alternative. ir.it.t.Fatal("It's not practical to use Expect against histograms and summaries.") } - modelMetric := toModelMetric(metric) + modelMetric, err := toModelMetric(metric) + if err != nil { + ir.it.t.Fatal(err) + } + for _, ss := range ir.it.expectationsPerBackend[b.Ref()] { if ss.Metric.Equal(modelMetric) { ss.Values = append(ss.Values, model.SamplePair{ @@ -228,7 +233,9 @@ func (it *ingestionTest) FatalOnUnexpectedPromQLResults(b Backend, metric promet it.t.Helper() m := dto.Metric{} - metric.Write(&m) + if err := metric.Write(&m); err != nil { + it.t.Fatalf("write metric: %s", err) + } if m.GetSummary() != nil || m.GetHistogram() != nil { // TODO(bwplotka): Implement alternative. @@ -240,7 +247,10 @@ func (it *ingestionTest) FatalOnUnexpectedPromQLResults(b Backend, metric promet it.t.Fatalf("%s backend not seen before? Did you pass it in NewIngestionTest?", b.Ref()) } - modelMetric := toModelMetric(metric) + modelMetric, err := toModelMetric(metric) + if err != nil { + it.t.Fatal(err) + } exp := it.preparedExpectedMatrix(it.expectationsPerBackend[b.Ref()], modelMetric, bMeta.extLset) if exp == nil { it.t.Fatalf("expected metric %v, not found in expected Matrix. Did you use scrape(...).expect(...) method?", modelMetric.String()) @@ -296,11 +306,13 @@ func (it *ingestionTest) FatalOnUnexpectedPromQLResults(b Backend, metric promet } } -func toModelMetric(metric prometheus.Metric) model.Metric { +func toModelMetric(metric prometheus.Metric) (model.Metric, error) { + ret := model.Metric{} m := dto.Metric{} - metric.Write(&m) + if err := metric.Write(&m); err != nil { + return ret, fmt.Errorf("write metric: %s", err) + } - ret := model.Metric{} for _, p := range m.Label { ret[model.LabelName(p.GetName())] = model.LabelValue(p.GetValue()) } @@ -312,5 +324,5 @@ func toModelMetric(metric prometheus.Metric) model.Metric { i := strings.Index(name, "\"") ret[model.MetricNameLabel] = model.LabelValue(name[:i]) - return ret + return ret, nil } diff --git a/pkg/export/gcm/promtest/skip.go b/pkg/export/gcm/promtest/skip.go index 29c441bbad..9243cd6b9f 100644 --- a/pkg/export/gcm/promtest/skip.go +++ b/pkg/export/gcm/promtest/skip.go @@ -20,7 +20,7 @@ func (n noopBackend) start(t testing.TB, env e2e.Environment) (api v1.API, extra } func (n noopBackend) injectScrapes(t testing.TB, scrapeRecordings [][]*dto.MetricFamily, timeout time.Duration) { - return + // Noop. } // NoopBackend creates noop backend, useful when you want to skip one backend for diff --git a/pkg/export/series_cache_test.go b/pkg/export/series_cache_test.go index 57fe6eebe7..f25f49c337 100644 --- a/pkg/export/series_cache_test.go +++ b/pkg/export/series_cache_test.go @@ -167,7 +167,9 @@ func TestSeriesCache_garbageCollect(t *testing.T) { cache.get(record.RefSample{Ref: 1, T: (now - 100) * 1000}, labels.EmptyLabels(), nil) cache.get(record.RefSample{Ref: 2, T: (now - 101) * 1000}, labels.EmptyLabels(), nil) - cache.garbageCollect(100 * time.Second) + if err := cache.garbageCollect(100 * time.Second); err != nil { + t.Errorf("cache garbage collect failed: %s", err) + } // Entry for series 1 should remain while 2 got dropped. if len(cache.entries) != 1 { diff --git a/pkg/export/transform.go b/pkg/export/transform.go index 73ebc1d2c6..89c5dade23 100644 --- a/pkg/export/transform.go +++ b/pkg/export/transform.go @@ -125,7 +125,7 @@ func (b *sampleBuilder) next(metadata MetadataFunc, externalLabels labels.Labels EndTime: getTimestamp(sample.T), }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{sample.V}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: sample.V}, }, }} result = append(result, hashedSeries{hash: g.hash, proto: &ts}) @@ -155,7 +155,7 @@ func (b *sampleBuilder) next(metadata MetadataFunc, externalLabels labels.Labels } if v != nil { value = &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DistributionValue{v}, + Value: &monitoring_pb.TypedValue_DistributionValue{DistributionValue: v}, } } } else { @@ -164,7 +164,7 @@ func (b *sampleBuilder) next(metadata MetadataFunc, externalLabels labels.Labels resetTimestamp, v, ok = b.series.getResetAdjusted(storage.SeriesRef(sample.Ref), sample.T, sample.V) if ok { value = &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{v}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: v}, } discardExemplarIncIfExists(storage.SeriesRef(sample.Ref), exemplars, "counters-unsupported") } diff --git a/pkg/export/transform_test.go b/pkg/export/transform_test.go index e9111351aa..4ee8438821 100644 --- a/pkg/export/transform_test.go +++ b/pkg/export/transform_test.go @@ -109,7 +109,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 3}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{0.6}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 0.6}, }, }}, }, @@ -136,7 +136,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 4}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{math.Inf(1)}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: math.Inf(1)}, }, }}, }, @@ -178,7 +178,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 3}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{0.6}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 0.6}, }, }}, }, @@ -205,7 +205,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 4}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{100}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 100}, }, }}, }, @@ -233,7 +233,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 4}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{99.4}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 99.4}, }, }}, }, @@ -279,7 +279,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 3}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{2.5}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 2.5}, }, }}, }, @@ -307,7 +307,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 4}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{3.5}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 3.5}, }, }}, }, @@ -337,7 +337,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 5}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{7}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 7}, }, }}, }, @@ -389,7 +389,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 4}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{3.5}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 3.5}, }, }}, }, @@ -419,7 +419,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 5}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{7}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 7}, }, }}, }, @@ -448,7 +448,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 5}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{7}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 7}, }, }}, }, @@ -516,7 +516,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 2}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{2}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 2}, }, }}, }, @@ -545,7 +545,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 3}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{20}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 20}, }, }}, }, @@ -573,7 +573,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 4}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{1}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 1}, }, }}, }, @@ -600,7 +600,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 4}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{4}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 4}, }, }}, }, @@ -652,7 +652,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 2}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{2}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 2}, }, }}, }, @@ -682,7 +682,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 4}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{1}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 1}, }, }}, }, @@ -709,7 +709,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 4}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{4}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 4}, }, }}, }, @@ -891,7 +891,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 1}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{3}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 3}, }, }}, }, @@ -1145,7 +1145,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 1}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{1}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 1}, }, }}, }, { @@ -1171,7 +1171,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 2}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{2}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 2}, }, }}, }, @@ -1198,7 +1198,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 1}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{1}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 1}, }, }}, }, @@ -1469,7 +1469,7 @@ func TestSampleBuilder(t *testing.T) { EndTime: ×tamp_pb.Timestamp{Seconds: 3}, }, Value: &monitoring_pb.TypedValue{ - Value: &monitoring_pb.TypedValue_DoubleValue{2.5}, + Value: &monitoring_pb.TypedValue_DoubleValue{DoubleValue: 2.5}, }, }}, }, diff --git a/pkg/operator/apis/monitoring/v1alpha1/types.go b/pkg/operator/apis/monitoring/v1alpha1/types.go index 96d85f7f31..3b69fe13fb 100644 --- a/pkg/operator/apis/monitoring/v1alpha1/types.go +++ b/pkg/operator/apis/monitoring/v1alpha1/types.go @@ -15,18 +15,12 @@ package v1alpha1 import ( - "fmt" - corev1 "k8s.io/api/core/v1" v1 "k8s.io/api/core/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/util/intstr" ) -var ( - errInvalidCond = fmt.Errorf("condition needs both 'Type' and 'Status' fields set") -) - // OperatorConfig defines configuration of the gmp-operator. // +genclient // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object diff --git a/pkg/operator/collection.go b/pkg/operator/collection.go index f3b3a17043..54c200bf56 100644 --- a/pkg/operator/collection.go +++ b/pkg/operator/collection.go @@ -400,12 +400,6 @@ func (r *collectionReconciler) makeCollectorConfig(ctx context.Context, spec *mo cfgs, err := pmon.ScrapeConfigs(projectID, location, cluster) if err != nil { msg := "generating scrape config failed for PodMonitoring endpoint" - cond = &monitoringv1.MonitoringCondition{ - Type: monitoringv1.ConfigurationCreateSuccess, - Status: corev1.ConditionFalse, - Reason: "ScrapeConfigError", - Message: msg, - } logger.Error(err, msg, "namespace", pmon.Namespace, "name", pmon.Name) continue } @@ -439,12 +433,6 @@ func (r *collectionReconciler) makeCollectorConfig(ctx context.Context, spec *mo cfgs, err := cmon.ScrapeConfigs(projectID, location, cluster) if err != nil { msg := "generating scrape config failed for PodMonitoring endpoint" - cond = &monitoringv1.MonitoringCondition{ - Type: monitoringv1.ConfigurationCreateSuccess, - Status: corev1.ConditionFalse, - Reason: "ScrapeConfigError", - Message: msg, - } logger.Error(err, msg, "namespace", cmon.Namespace, "name", cmon.Name) continue } diff --git a/pkg/operator/collection_test.go b/pkg/operator/collection_test.go index 307ba89d53..1dcc5da0c8 100644 --- a/pkg/operator/collection_test.go +++ b/pkg/operator/collection_test.go @@ -145,15 +145,19 @@ func TestCollectionStatus(t *testing.T) { Build() collectionReconciler := newCollectionReconciler(kubeClient, opts) - collectionReconciler.Reconcile(ctx, reconcile.Request{ + if _, err := collectionReconciler.Reconcile(ctx, reconcile.Request{ NamespacedName: types.NamespacedName{ Namespace: opts.PublicNamespace, Name: NameOperatorConfig, }, - }) + }); err != nil { + t.Fatalf("collection reconcile failed: %s", err) + } var podMonitorings monitoringv1.PodMonitoringList - kubeClient.List(ctx, &podMonitorings) + if err := kubeClient.List(ctx, &podMonitorings); err != nil { + t.Fatalf("unable to get PodMonitorings: %s", err) + } switch amount := len(podMonitorings.Items); amount { case 1: status := podMonitorings.Items[0].Status diff --git a/pkg/rules/rules_test.go b/pkg/rules/rules_test.go index a6316c5891..b140b5c524 100644 --- a/pkg/rules/rules_test.go +++ b/pkg/rules/rules_test.go @@ -39,10 +39,12 @@ func TestScope(t *testing.T) { if len(errs) > 0 { t.Fatalf("Unexpected input errors: %s", errs) } - err := Scope(groups, map[string]string{ + if err := Scope(groups, map[string]string{ "l1": "v1", "l2": "v2", - }) + }); err != nil { + t.Fatalf("Unable to set scope: %s", err) + } want := `groups: - name: test rules: diff --git a/pkg/ui/ui.go b/pkg/ui/ui.go index c3d7fd8ec2..1fdfb51bbf 100644 --- a/pkg/ui/ui.go +++ b/pkg/ui/ui.go @@ -57,7 +57,9 @@ func Handler(externalURL *url.URL) http.Handler { idx = bytes.ReplaceAll(idx, []byte("CONSOLES_LINK_PLACEHOLDER"), []byte("")) idx = bytes.ReplaceAll(idx, []byte("TITLE_PLACEHOLDER"), []byte("Google Cloud Managed Service for Prometheus")) - w.Write(idx) + if _, err := w.Write(idx); err != nil { + fmt.Fprintf(w, "Error writing bytes: %s", err) + } }) }