systemtest/intake.go (70 lines of code) (raw):

// Licensed to Elasticsearch B.V. under one or more contributor // license agreements. See the NOTICE file distributed with // this work for additional information regarding copyright // ownership. Elasticsearch B.V. licenses this file to you 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. package systemtest import ( "encoding/json" "io" "net/http" "net/url" "os" "strings" "testing" "github.com/stretchr/testify/require" ) type IntakeResponse struct { Accepted int } func SendRUMEventsPayload(t *testing.T, serverURL string, payloadFile string) IntakeResponse { f := openFile(t, payloadFile) return sendEventsPayload(t, serverURL, "/intake/v2/rum/events", f) } func SendRUMEventsLiteral(t *testing.T, serverURL string, raw string) IntakeResponse { return sendEventsPayload(t, serverURL, "/intake/v2/rum/events", strings.NewReader(raw)) } func SendBackendEventsPayload(t *testing.T, serverURL string, payloadFile string) IntakeResponse { f := openFile(t, payloadFile) return sendEventsPayload(t, serverURL, "/intake/v2/events", f) } func SendBackendEventsAsyncPayloadError(t *testing.T, serverURL string, payloadFile string) { f := openFile(t, payloadFile) resp := doRequest(t, serverURL+"/intake/v2/events?async=true", f) defer resp.Body.Close() respBody, err := io.ReadAll(resp.Body) require.NoError(t, err) require.Equal(t, http.StatusServiceUnavailable, resp.StatusCode, string(respBody)) } func SendBackendEventsLiteral(t *testing.T, serverURL string, raw string) IntakeResponse { return sendEventsPayload(t, serverURL, "/intake/v2/events", strings.NewReader(raw)) } func sendEventsPayload(t *testing.T, serverURL, urlPath string, f io.Reader) IntakeResponse { t.Helper() u, _ := url.Parse(serverURL + urlPath) query := u.Query() query.Set("verbose", "true") u.RawQuery = query.Encode() resp := doRequest(t, u.String(), f) defer resp.Body.Close() respBody, err := io.ReadAll(resp.Body) require.NoError(t, err) require.Equal(t, http.StatusAccepted, resp.StatusCode, string(respBody)) var response IntakeResponse err = json.Unmarshal(respBody, &response) require.NoError(t, err) return response } func doRequest(t *testing.T, url string, f io.Reader) *http.Response { req, _ := http.NewRequest("POST", url, f) req.Header.Add("Content-Type", "application/x-ndjson") resp, err := http.DefaultClient.Do(req) require.NoError(t, err) return resp } func openFile(t *testing.T, p string) *os.File { f, err := os.Open(p) if err != nil { t.Fatal(err) } else { t.Cleanup(func() { f.Close() }) } return f }