From 45d6a23cf043084301154090607b526cf669b541 Mon Sep 17 00:00:00 2001 From: Mike Ball Date: Sun, 19 Jul 2020 10:44:06 -0400 Subject: [PATCH] provide basic pattern for integration testing This seeks to address issue #58. It also illustrates the problem outlined in issue #56, as `TestAnnotationsIntegration` will fail until PR #57 is merged. --- README.md | 18 ++++++- annotation_integration_test.go | 85 ++++++++++++++++++++++++++++++++++ 2 files changed, 101 insertions(+), 2 deletions(-) create mode 100644 annotation_integration_test.go diff --git a/README.md b/README.md index 18f7314..38abd2d 100644 --- a/README.md +++ b/README.md @@ -6,8 +6,22 @@ Grafana HTTP API Client for Go ## Tests -To run the tests: +To run unit tests: ``` -go test +make test +``` + +To run integration tests: + +Start a `localhost:3000` Grafana: + +``` +make serve-grafana +``` + +Run the integration tests: + +``` +make integration-test: ``` diff --git a/annotation_integration_test.go b/annotation_integration_test.go new file mode 100644 index 0000000..0467877 --- /dev/null +++ b/annotation_integration_test.go @@ -0,0 +1,85 @@ +// +build integration + +package gapi + +import ( + "fmt" + "net/url" + "testing" +) + +func TestAnnotationsIntegration(t *testing.T) { + client, err := New("admin:admin", "http://localhost:3000") + if err != nil { + t.Error(err) + } + + _, err = client.Annotations(url.Values{}) + if err != nil { + t.Error(err) + } +} + +func TestNewAnnotationIntegration(t *testing.T) { + client, err := New("admin:admin", "http://localhost:3000") + if err != nil { + t.Error(err) + } + + _, err = client.NewAnnotation(&Annotation{ + Text: "integration-test-new", + }) + if err != nil { + t.Error(err) + } +} + +func TestUpdateAnnotationIntegration(t *testing.T) { + client, err := New("admin:admin", "http://localhost:3000") + if err != nil { + t.Error(err) + } + + id, err := client.NewAnnotation(&Annotation{ + Text: "integration-test-update", + }) + if err != nil { + t.Error(err) + } + + message, err := client.UpdateAnnotation(id, &Annotation{ + Text: "integration-test-updated", + }) + if err != nil { + t.Error(err) + } + + expected := "Annotation updated" + if message != expected { + t.Error(fmt.Sprintf("expected UpdateAnnotation message to be %s; got %s", expected, message)) + } +} + +func TestDeleteAnnotationIntegration(t *testing.T) { + client, err := New("admin:admin", "http://localhost:3000") + if err != nil { + t.Error(err) + } + + id, err := client.NewAnnotation(&Annotation{ + Text: "integration-test-delete", + }) + if err != nil { + t.Error(err) + } + + message, err := client.DeleteAnnotation(id) + if err != nil { + t.Error(err) + } + + expected := "Annotation deleted" + if message != expected { + t.Error(fmt.Sprintf("expected DeleteAnnotation message to be %s; got %s", expected, message)) + } +}