influxdb/http/scraper_service_test.go

881 lines
26 KiB
Go
Raw Normal View History

package http
import (
"bytes"
"context"
"encoding/json"
"fmt"
"io/ioutil"
"net/http"
"net/http/httptest"
"testing"
2019-04-10 19:21:49 +00:00
"go.uber.org/zap"
2019-04-12 16:45:48 +00:00
"github.com/influxdata/influxdb"
2019-01-18 20:46:37 +00:00
platcontext "github.com/influxdata/influxdb/context"
2019-01-23 17:11:06 +00:00
httpMock "github.com/influxdata/influxdb/http/mock"
"github.com/influxdata/influxdb/inmem"
"github.com/influxdata/influxdb/mock"
platformtesting "github.com/influxdata/influxdb/testing"
"github.com/julienschmidt/httprouter"
)
const (
targetOneIDString = "0000000000000111"
targetTwoIDString = "0000000000000222"
)
var (
targetOneID = platformtesting.MustIDBase16(targetOneIDString)
targetTwoID = platformtesting.MustIDBase16(targetTwoIDString)
)
// NewMockScraperBackend returns a ScraperBackend with mock services.
func NewMockScraperBackend() *ScraperBackend {
return &ScraperBackend{
Logger: zap.NewNop().With(zap.String("handler", "scraper")),
ScraperStorageService: &mock.ScraperTargetStoreService{},
BucketService: mock.NewBucketService(),
OrganizationService: mock.NewOrganizationService(),
UserService: mock.NewUserService(),
UserResourceMappingService: &mock.UserResourceMappingService{},
LabelService: mock.NewLabelService(),
}
}
func TestService_handleGetScraperTargets(t *testing.T) {
type fields struct {
2019-04-12 16:45:48 +00:00
ScraperTargetStoreService influxdb.ScraperTargetStoreService
OrganizationService influxdb.OrganizationService
BucketService influxdb.BucketService
}
type args struct {
queryParams map[string][]string
}
type wants struct {
statusCode int
contentType string
body string
}
tests := []struct {
name string
fields fields
args args
wants wants
}{
{
name: "get all scraper targets",
fields: fields{
OrganizationService: &mock.OrganizationService{
2019-04-12 16:45:48 +00:00
FindOrganizationByIDF: func(ctx context.Context, id influxdb.ID) (*influxdb.Organization, error) {
return &influxdb.Organization{
ID: platformtesting.MustIDBase16("0000000000000211"),
Name: "org1",
}, nil
},
},
BucketService: &mock.BucketService{
2019-04-12 16:45:48 +00:00
FindBucketByIDFn: func(ctx context.Context, id influxdb.ID) (*influxdb.Bucket, error) {
return &influxdb.Bucket{
ID: platformtesting.MustIDBase16("0000000000000212"),
Name: "bucket1",
}, nil
},
},
ScraperTargetStoreService: &mock.ScraperTargetStoreService{
2019-04-12 16:45:48 +00:00
ListTargetsF: func(ctx context.Context, filter influxdb.ScraperTargetFilter) ([]influxdb.ScraperTarget, error) {
return []influxdb.ScraperTarget{
{
2019-01-10 17:39:37 +00:00
ID: targetOneID,
Name: "target-1",
2019-04-12 16:45:48 +00:00
Type: influxdb.PrometheusScraperType,
2019-01-10 17:39:37 +00:00
URL: "www.one.url",
OrgID: platformtesting.MustIDBase16("0000000000000211"),
BucketID: platformtesting.MustIDBase16("0000000000000212"),
},
{
2019-01-10 17:39:37 +00:00
ID: targetTwoID,
Name: "target-2",
2019-04-12 16:45:48 +00:00
Type: influxdb.PrometheusScraperType,
2019-01-10 17:39:37 +00:00
URL: "www.two.url",
OrgID: platformtesting.MustIDBase16("0000000000000211"),
BucketID: platformtesting.MustIDBase16("0000000000000212"),
},
}, nil
},
},
},
args: args{},
wants: wants{
statusCode: http.StatusOK,
contentType: "application/json; charset=utf-8",
body: fmt.Sprintf(
`
{
"links": {
2019-01-18 15:38:28 +00:00
"self": "/api/v2/scrapers"
},
"configurations": [
{
"id": "%s",
"name": "target-1",
"bucket": "bucket1",
2019-01-10 17:39:37 +00:00
"bucketID": "0000000000000212",
2019-04-10 19:21:49 +00:00
"org": "org1",
2019-01-10 17:39:37 +00:00
"orgID": "0000000000000211",
"type": "prometheus",
"url": "www.one.url",
"links": {
"bucket": "/api/v2/buckets/0000000000000212",
"organization": "/api/v2/orgs/0000000000000211",
2019-02-26 17:08:30 +00:00
"self": "/api/v2/scrapers/0000000000000111",
"members": "/api/v2/scrapers/0000000000000111/members",
"owners": "/api/v2/scrapers/0000000000000111/owners"
}
},
{
"id": "%s",
"name": "target-2",
"bucket": "bucket1",
2019-01-10 17:39:37 +00:00
"bucketID": "0000000000000212",
"orgID": "0000000000000211",
2019-04-10 19:21:49 +00:00
"org": "org1",
"type": "prometheus",
"url": "www.two.url",
"links": {
"bucket": "/api/v2/buckets/0000000000000212",
"organization": "/api/v2/orgs/0000000000000211",
2019-02-26 17:08:30 +00:00
"self": "/api/v2/scrapers/0000000000000222",
"members": "/api/v2/scrapers/0000000000000222/members",
"owners": "/api/v2/scrapers/0000000000000222/owners"
}
}
]
}
`,
targetOneIDString,
targetTwoIDString,
),
},
},
{
name: "get all scraper targets when there are none",
fields: fields{
OrganizationService: &mock.OrganizationService{
2019-04-12 16:45:48 +00:00
FindOrganizationByIDF: func(ctx context.Context, id influxdb.ID) (*influxdb.Organization, error) {
return &influxdb.Organization{
ID: platformtesting.MustIDBase16("0000000000000211"),
Name: "org1",
}, nil
},
},
BucketService: &mock.BucketService{
2019-04-12 16:45:48 +00:00
FindBucketByIDFn: func(ctx context.Context, id influxdb.ID) (*influxdb.Bucket, error) {
return &influxdb.Bucket{
ID: platformtesting.MustIDBase16("0000000000000212"),
Name: "bucket1",
}, nil
},
},
ScraperTargetStoreService: &mock.ScraperTargetStoreService{
2019-04-12 16:45:48 +00:00
ListTargetsF: func(ctx context.Context, filter influxdb.ScraperTargetFilter) ([]influxdb.ScraperTarget, error) {
return []influxdb.ScraperTarget{}, nil
},
},
},
args: args{},
wants: wants{
statusCode: http.StatusOK,
contentType: "application/json; charset=utf-8",
body: `
{
"links": {
2019-01-18 15:38:28 +00:00
"self": "/api/v2/scrapers"
},
"configurations": []
}
`,
},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
scraperBackend := NewMockScraperBackend()
scraperBackend.HTTPErrorHandler = ErrorHandler(0)
scraperBackend.ScraperStorageService = tt.fields.ScraperTargetStoreService
scraperBackend.OrganizationService = tt.fields.OrganizationService
scraperBackend.BucketService = tt.fields.BucketService
h := NewScraperHandler(scraperBackend)
r := httptest.NewRequest("GET", "http://any.tld", nil)
qp := r.URL.Query()
for k, vs := range tt.args.queryParams {
for _, v := range vs {
qp.Add(k, v)
}
}
r.URL.RawQuery = qp.Encode()
w := httptest.NewRecorder()
h.handleGetScraperTargets(w, r)
res := w.Result()
content := res.Header.Get("Content-Type")
body, _ := ioutil.ReadAll(res.Body)
if res.StatusCode != tt.wants.statusCode {
t.Errorf("%q. handleGetScraperTargets() = %v, want %v", tt.name, res.StatusCode, tt.wants.statusCode)
}
if tt.wants.contentType != "" && content != tt.wants.contentType {
t.Errorf("%q. handleGetScraperTargets() = %v, want %v", tt.name, content, tt.wants.contentType)
}
if tt.wants.body != "" {
if eq, diff, err := jsonEqual(string(body), tt.wants.body); err != nil {
t.Errorf("%q, handleGetScraperTargets(). error unmarshaling json %v", tt.name, err)
} else if !eq {
t.Errorf("%q. handleGetScraperTargets() = ***%s***", tt.name, diff)
}
}
})
}
}
func TestService_handleGetScraperTarget(t *testing.T) {
type fields struct {
2019-04-12 16:45:48 +00:00
OrganizationService influxdb.OrganizationService
BucketService influxdb.BucketService
ScraperTargetStoreService influxdb.ScraperTargetStoreService
}
type args struct {
id string
}
type wants struct {
statusCode int
contentType string
body string
}
tests := []struct {
name string
fields fields
args args
wants wants
}{
{
name: "get a scraper target by id",
fields: fields{
OrganizationService: &mock.OrganizationService{
2019-04-12 16:45:48 +00:00
FindOrganizationByIDF: func(ctx context.Context, id influxdb.ID) (*influxdb.Organization, error) {
return &influxdb.Organization{
ID: platformtesting.MustIDBase16("0000000000000211"),
Name: "org1",
}, nil
},
},
BucketService: &mock.BucketService{
2019-04-12 16:45:48 +00:00
FindBucketByIDFn: func(ctx context.Context, id influxdb.ID) (*influxdb.Bucket, error) {
return &influxdb.Bucket{
ID: platformtesting.MustIDBase16("0000000000000212"),
Name: "bucket1",
}, nil
},
},
ScraperTargetStoreService: &mock.ScraperTargetStoreService{
2019-04-12 16:45:48 +00:00
GetTargetByIDF: func(ctx context.Context, id influxdb.ID) (*influxdb.ScraperTarget, error) {
if id == targetOneID {
2019-04-12 16:45:48 +00:00
return &influxdb.ScraperTarget{
2019-01-10 17:39:37 +00:00
ID: targetOneID,
Name: "target-1",
2019-04-12 16:45:48 +00:00
Type: influxdb.PrometheusScraperType,
2019-01-10 17:39:37 +00:00
URL: "www.some.url",
OrgID: platformtesting.MustIDBase16("0000000000000211"),
BucketID: platformtesting.MustIDBase16("0000000000000212"),
}, nil
}
2019-04-12 16:45:48 +00:00
return nil, &influxdb.Error{
Code: influxdb.ENotFound,
Msg: "scraper target is not found",
}
},
},
},
args: args{
id: targetOneIDString,
},
wants: wants{
statusCode: http.StatusOK,
contentType: "application/json; charset=utf-8",
body: fmt.Sprintf(
`
{
"id": "%s",
"name": "target-1",
"type": "prometheus",
"url": "www.some.url",
"bucket": "bucket1",
2019-01-10 17:39:37 +00:00
"bucketID": "0000000000000212",
"orgID": "0000000000000211",
2019-04-10 19:21:49 +00:00
"org": "org1",
"links": {
"bucket": "/api/v2/buckets/0000000000000212",
"organization": "/api/v2/orgs/0000000000000211",
"self": "/api/v2/scrapers/%s",
"members": "/api/v2/scrapers/%s/members",
"owners": "/api/v2/scrapers/%s/owners"
}
}
`,
targetOneIDString, targetOneIDString, targetOneIDString, targetOneIDString,
),
},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
scraperBackend := NewMockScraperBackend()
scraperBackend.HTTPErrorHandler = ErrorHandler(0)
scraperBackend.ScraperStorageService = tt.fields.ScraperTargetStoreService
scraperBackend.OrganizationService = tt.fields.OrganizationService
scraperBackend.BucketService = tt.fields.BucketService
h := NewScraperHandler(scraperBackend)
r := httptest.NewRequest("GET", "http://any.tld", nil)
r = r.WithContext(context.WithValue(
context.Background(),
httprouter.ParamsKey,
httprouter.Params{
{
Key: "id",
Value: tt.args.id,
},
}))
w := httptest.NewRecorder()
h.handleGetScraperTarget(w, r)
res := w.Result()
content := res.Header.Get("Content-Type")
body, _ := ioutil.ReadAll(res.Body)
if res.StatusCode != tt.wants.statusCode {
t.Errorf("%q. handleGetScraperTarget() = %v, want %v", tt.name, res.StatusCode, tt.wants.statusCode)
}
if tt.wants.contentType != "" && content != tt.wants.contentType {
t.Errorf("%q. handleGetScraperTarget() = %v, want %v", tt.name, content, tt.wants.contentType)
}
if tt.wants.body != "" {
if eq, diff, err := jsonEqual(string(body), tt.wants.body); err != nil {
t.Errorf("%q, handleGetScraperTarget(). error unmarshaling json %v", tt.name, err)
} else if !eq {
t.Errorf("%q. handleGetScraperTarget() = ***%s***", tt.name, diff)
}
}
})
}
}
func TestService_handleDeleteScraperTarget(t *testing.T) {
type fields struct {
2019-04-12 16:45:48 +00:00
Service influxdb.ScraperTargetStoreService
}
type args struct {
id string
}
type wants struct {
statusCode int
contentType string
body string
}
tests := []struct {
name string
fields fields
args args
wants wants
}{
{
name: "delete a scraper target by id",
fields: fields{
Service: &mock.ScraperTargetStoreService{
2019-04-12 16:45:48 +00:00
RemoveTargetF: func(ctx context.Context, id influxdb.ID) error {
if id == targetOneID {
return nil
}
return fmt.Errorf("wrong id")
},
},
},
args: args{
id: targetOneIDString,
},
wants: wants{
statusCode: http.StatusNoContent,
},
},
{
name: "scraper target not found",
fields: fields{
Service: &mock.ScraperTargetStoreService{
2019-04-12 16:45:48 +00:00
RemoveTargetF: func(ctx context.Context, id influxdb.ID) error {
return &influxdb.Error{
Code: influxdb.ENotFound,
Msg: influxdb.ErrScraperTargetNotFound,
}
},
},
},
args: args{
id: targetTwoIDString,
},
wants: wants{
statusCode: http.StatusNotFound,
},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
scraperBackend := NewMockScraperBackend()
scraperBackend.HTTPErrorHandler = ErrorHandler(0)
scraperBackend.ScraperStorageService = tt.fields.Service
h := NewScraperHandler(scraperBackend)
r := httptest.NewRequest("GET", "http://any.tld", nil)
r = r.WithContext(context.WithValue(
context.Background(),
httprouter.ParamsKey,
httprouter.Params{
{
Key: "id",
Value: tt.args.id,
},
}))
w := httptest.NewRecorder()
h.handleDeleteScraperTarget(w, r)
res := w.Result()
content := res.Header.Get("Content-Type")
body, _ := ioutil.ReadAll(res.Body)
if res.StatusCode != tt.wants.statusCode {
t.Errorf("%q. handleDeleteScraperTarget() = %v, want %v", tt.name, res.StatusCode, tt.wants.statusCode)
}
if tt.wants.contentType != "" && content != tt.wants.contentType {
t.Errorf("%q. handleDeleteScraperTarget() = %v, want %v", tt.name, content, tt.wants.contentType)
}
if tt.wants.body != "" {
if eq, diff, err := jsonEqual(string(body), tt.wants.body); err != nil {
t.Errorf("%q, handleDeleteScraperTarget(). error unmarshaling json %v", tt.name, err)
} else if !eq {
t.Errorf("%q. handleDeleteScraperTarget() = ***%s***", tt.name, diff)
}
}
})
}
}
func TestService_handlePostScraperTarget(t *testing.T) {
type fields struct {
2019-04-12 16:45:48 +00:00
OrganizationService influxdb.OrganizationService
BucketService influxdb.BucketService
ScraperTargetStoreService influxdb.ScraperTargetStoreService
}
type args struct {
2019-04-12 16:45:48 +00:00
target *influxdb.ScraperTarget
}
type wants struct {
statusCode int
contentType string
body string
}
tests := []struct {
name string
fields fields
args args
wants wants
}{
{
name: "create a new scraper target",
fields: fields{
OrganizationService: &mock.OrganizationService{
2019-04-12 16:45:48 +00:00
FindOrganizationByIDF: func(ctx context.Context, id influxdb.ID) (*influxdb.Organization, error) {
return &influxdb.Organization{
ID: platformtesting.MustIDBase16("0000000000000211"),
Name: "org1",
}, nil
},
},
BucketService: &mock.BucketService{
2019-04-12 16:45:48 +00:00
FindBucketByIDFn: func(ctx context.Context, id influxdb.ID) (*influxdb.Bucket, error) {
return &influxdb.Bucket{
ID: platformtesting.MustIDBase16("0000000000000212"),
Name: "bucket1",
}, nil
},
},
ScraperTargetStoreService: &mock.ScraperTargetStoreService{
2019-04-12 16:45:48 +00:00
AddTargetF: func(ctx context.Context, st *influxdb.ScraperTarget, userID influxdb.ID) error {
st.ID = targetOneID
return nil
},
},
},
args: args{
2019-04-12 16:45:48 +00:00
target: &influxdb.ScraperTarget{
2019-01-10 17:39:37 +00:00
Name: "hello",
2019-04-12 16:45:48 +00:00
Type: influxdb.PrometheusScraperType,
2019-01-10 17:39:37 +00:00
BucketID: platformtesting.MustIDBase16("0000000000000212"),
OrgID: platformtesting.MustIDBase16("0000000000000211"),
URL: "www.some.url",
},
},
wants: wants{
statusCode: http.StatusCreated,
contentType: "application/json; charset=utf-8",
body: fmt.Sprintf(
`
{
"id": "%s",
"name": "hello",
"type": "prometheus",
"url": "www.some.url",
"orgID": "0000000000000211",
2019-04-10 19:21:49 +00:00
"org": "org1",
"bucket": "bucket1",
2019-01-10 17:39:37 +00:00
"bucketID": "0000000000000212",
"links": {
"bucket": "/api/v2/buckets/0000000000000212",
"organization": "/api/v2/orgs/0000000000000211",
"self": "/api/v2/scrapers/%s",
"members": "/api/v2/scrapers/%s/members",
"owners": "/api/v2/scrapers/%s/owners"
}
}
`,
targetOneIDString, targetOneIDString, targetOneIDString, targetOneIDString,
),
},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
scraperBackend := NewMockScraperBackend()
scraperBackend.HTTPErrorHandler = ErrorHandler(0)
scraperBackend.ScraperStorageService = tt.fields.ScraperTargetStoreService
scraperBackend.OrganizationService = tt.fields.OrganizationService
scraperBackend.BucketService = tt.fields.BucketService
h := NewScraperHandler(scraperBackend)
st, err := json.Marshal(tt.args.target)
if err != nil {
t.Fatalf("failed to unmarshal scraper target: %v", err)
}
r := httptest.NewRequest("GET", "http://any.tld", bytes.NewReader(st))
2019-04-12 16:45:48 +00:00
r = r.WithContext(platcontext.SetAuthorizer(r.Context(), &influxdb.Authorization{}))
w := httptest.NewRecorder()
h.handlePostScraperTarget(w, r)
res := w.Result()
content := res.Header.Get("Content-Type")
body, _ := ioutil.ReadAll(res.Body)
if res.StatusCode != tt.wants.statusCode {
t.Errorf("%q. handlePostScraperTarget() = %v, want %v", tt.name, res.StatusCode, tt.wants.statusCode)
}
if tt.wants.contentType != "" && content != tt.wants.contentType {
t.Errorf("%q. handlePostScraperTarget() = %v, want %v", tt.name, content, tt.wants.contentType)
}
if tt.wants.body != "" {
if eq, diff, err := jsonEqual(string(body), tt.wants.body); err != nil {
t.Errorf("%q, handlePostScraperTarget(). error unmarshaling json %v", tt.name, err)
} else if !eq {
t.Errorf("%q. handlePostScraperTarget() = ***%s***", tt.name, diff)
}
}
})
}
}
func TestService_handlePatchScraperTarget(t *testing.T) {
type fields struct {
2019-04-12 16:45:48 +00:00
BucketService influxdb.BucketService
OrganizationService influxdb.OrganizationService
ScraperTargetStoreService influxdb.ScraperTargetStoreService
}
type args struct {
id string
2019-04-12 16:45:48 +00:00
update *influxdb.ScraperTarget
}
type wants struct {
statusCode int
contentType string
body string
}
tests := []struct {
name string
fields fields
args args
wants wants
}{
{
name: "update a scraper target",
fields: fields{
OrganizationService: &mock.OrganizationService{
2019-04-12 16:45:48 +00:00
FindOrganizationByIDF: func(ctx context.Context, id influxdb.ID) (*influxdb.Organization, error) {
return &influxdb.Organization{
ID: platformtesting.MustIDBase16("0000000000000211"),
Name: "org1",
}, nil
},
},
BucketService: &mock.BucketService{
2019-04-12 16:45:48 +00:00
FindBucketByIDFn: func(ctx context.Context, id influxdb.ID) (*influxdb.Bucket, error) {
return &influxdb.Bucket{
ID: platformtesting.MustIDBase16("0000000000000212"),
Name: "bucket1",
}, nil
},
},
ScraperTargetStoreService: &mock.ScraperTargetStoreService{
2019-04-12 16:45:48 +00:00
UpdateTargetF: func(ctx context.Context, t *influxdb.ScraperTarget, userID influxdb.ID) (*influxdb.ScraperTarget, error) {
if t.ID == targetOneID {
return t, nil
}
2019-04-12 16:45:48 +00:00
return nil, &influxdb.Error{
Code: influxdb.ENotFound,
Msg: "scraper target is not found",
}
},
},
},
args: args{
id: targetOneIDString,
2019-04-12 16:45:48 +00:00
update: &influxdb.ScraperTarget{
2019-01-10 17:39:37 +00:00
ID: targetOneID,
Name: "name",
BucketID: platformtesting.MustIDBase16("0000000000000212"),
2019-04-12 16:45:48 +00:00
Type: influxdb.PrometheusScraperType,
2019-01-10 17:39:37 +00:00
URL: "www.example.url",
OrgID: platformtesting.MustIDBase16("0000000000000211"),
},
},
wants: wants{
statusCode: http.StatusOK,
contentType: "application/json; charset=utf-8",
body: fmt.Sprintf(
`{
"id":"%s",
"name":"name",
"type":"prometheus",
"url":"www.example.url",
2019-04-10 19:21:49 +00:00
"org": "org1",
"orgID":"0000000000000211",
"bucket": "bucket1",
"bucketID":"0000000000000212",
"links":{
"bucket": "/api/v2/buckets/0000000000000212",
"organization": "/api/v2/orgs/0000000000000211",
"self":"/api/v2/scrapers/%s",
"members":"/api/v2/scrapers/%s/members",
"owners":"/api/v2/scrapers/%s/owners"
}
}`,
targetOneIDString, targetOneIDString, targetOneIDString, targetOneIDString,
),
},
},
{
name: "scraper target not found",
fields: fields{
OrganizationService: &mock.OrganizationService{
2019-04-12 16:45:48 +00:00
FindOrganizationByIDF: func(ctx context.Context, id influxdb.ID) (*influxdb.Organization, error) {
return &influxdb.Organization{
ID: platformtesting.MustIDBase16("0000000000000211"),
Name: "org1",
}, nil
},
},
BucketService: &mock.BucketService{
2019-04-12 16:45:48 +00:00
FindBucketByIDFn: func(ctx context.Context, id influxdb.ID) (*influxdb.Bucket, error) {
return &influxdb.Bucket{
ID: platformtesting.MustIDBase16("0000000000000212"),
Name: "bucket1",
}, nil
},
},
ScraperTargetStoreService: &mock.ScraperTargetStoreService{
2019-04-12 16:45:48 +00:00
UpdateTargetF: func(ctx context.Context, upd *influxdb.ScraperTarget, userID influxdb.ID) (*influxdb.ScraperTarget, error) {
return nil, &influxdb.Error{
Code: influxdb.ENotFound,
Msg: influxdb.ErrScraperTargetNotFound,
}
},
},
},
args: args{
id: targetOneIDString,
2019-04-12 16:45:48 +00:00
update: &influxdb.ScraperTarget{
2019-01-10 17:39:37 +00:00
ID: targetOneID,
Name: "name",
BucketID: platformtesting.MustIDBase16("0000000000000212"),
2019-04-12 16:45:48 +00:00
Type: influxdb.PrometheusScraperType,
2019-01-10 17:39:37 +00:00
URL: "www.example.url",
OrgID: platformtesting.MustIDBase16("0000000000000211"),
},
},
wants: wants{
statusCode: http.StatusNotFound,
},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
scraperBackend := NewMockScraperBackend()
scraperBackend.HTTPErrorHandler = ErrorHandler(0)
scraperBackend.ScraperStorageService = tt.fields.ScraperTargetStoreService
scraperBackend.OrganizationService = tt.fields.OrganizationService
scraperBackend.BucketService = tt.fields.BucketService
h := NewScraperHandler(scraperBackend)
var err error
st := make([]byte, 0)
if tt.args.update != nil {
st, err = json.Marshal(*tt.args.update)
if err != nil {
t.Fatalf("failed to unmarshal scraper target: %v", err)
}
}
r := httptest.NewRequest("GET", "http://any.tld", bytes.NewReader(st))
r = r.WithContext(context.WithValue(
context.Background(),
httprouter.ParamsKey,
httprouter.Params{
{
Key: "id",
Value: tt.args.id,
},
}))
2019-04-12 16:45:48 +00:00
r = r.WithContext(platcontext.SetAuthorizer(r.Context(), &influxdb.Authorization{}))
w := httptest.NewRecorder()
h.handlePatchScraperTarget(w, r)
res := w.Result()
content := res.Header.Get("Content-Type")
body, _ := ioutil.ReadAll(res.Body)
if res.StatusCode != tt.wants.statusCode {
t.Errorf("%q. handlePatchScraperTarget() = %v, want %v", tt.name, res.StatusCode, tt.wants.statusCode)
}
if tt.wants.contentType != "" && content != tt.wants.contentType {
t.Errorf("%q. handlePatchScraperTarget() = %v, want %v", tt.name, content, tt.wants.contentType)
}
if tt.wants.body != "" {
if eq, diff, err := jsonEqual(string(body), tt.wants.body); err != nil {
t.Errorf("%q, handlePatchScraperTarget(). error unmarshaling json %v", tt.name, err)
} else if !eq {
t.Errorf("%q. handlePatchScraperTarget() = ***%s***", tt.name, diff)
}
}
})
}
}
2019-04-12 16:45:48 +00:00
func initScraperService(f platformtesting.TargetFields, t *testing.T) (influxdb.ScraperTargetStoreService, string, func()) {
t.Helper()
svc := inmem.NewService()
svc.IDGenerator = f.IDGenerator
ctx := context.Background()
for _, target := range f.Targets {
if err := svc.PutTarget(ctx, target); err != nil {
t.Fatalf("failed to populate scraper targets")
}
}
2019-01-18 20:46:37 +00:00
for _, m := range f.UserResourceMappings {
if err := svc.PutUserResourceMapping(ctx, m); err != nil {
2019-01-18 20:46:37 +00:00
t.Fatalf("failed to populate user resource mapping")
}
}
2019-04-12 16:45:48 +00:00
for _, o := range f.Organizations {
if err := svc.PutOrganization(ctx, o); err != nil {
t.Fatalf("failed to populate orgs")
}
}
scraperBackend := NewMockScraperBackend()
scraperBackend.HTTPErrorHandler = ErrorHandler(0)
scraperBackend.ScraperStorageService = svc
2019-04-12 16:45:48 +00:00
scraperBackend.OrganizationService = svc
scraperBackend.BucketService = &mock.BucketService{
2019-04-12 16:45:48 +00:00
FindBucketByIDFn: func(ctx context.Context, id influxdb.ID) (*influxdb.Bucket, error) {
return &influxdb.Bucket{
ID: id,
Name: "bucket1",
}, nil
},
}
handler := NewScraperHandler(scraperBackend)
2019-01-23 17:11:06 +00:00
server := httptest.NewServer(httpMock.NewAuthMiddlewareHandler(
handler,
2019-04-12 16:45:48 +00:00
&influxdb.Authorization{
UserID: platformtesting.MustIDBase16("020f755c3c082002"),
2019-01-18 20:46:37 +00:00
Token: "tok",
},
))
client := struct {
2019-04-12 16:45:48 +00:00
influxdb.UserResourceMappingService
influxdb.OrganizationService
2019-01-18 20:46:37 +00:00
ScraperService
}{
UserResourceMappingService: svc,
2019-04-12 16:45:48 +00:00
OrganizationService: svc,
2019-01-18 20:46:37 +00:00
ScraperService: ScraperService{
Token: "tok",
Addr: server.URL,
OpPrefix: inmem.OpPrefix,
},
}
done := server.Close
return &client, inmem.OpPrefix, done
}
func TestScraperService(t *testing.T) {
platformtesting.ScraperService(initScraperService, t)
}