Skip to content

Commit 86a7b1c

Browse files
committed
wip tests
1 parent c66201c commit 86a7b1c

File tree

3 files changed

+112
-8
lines changed

3 files changed

+112
-8
lines changed

go.mod

+12-3
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,8 @@
11
module github.com/elastic/elastic-agent
22

3-
go 1.21
3+
go 1.21.6
4+
5+
toolchain go1.22.2
46

57
require (
68
github.com/Microsoft/go-winio v0.6.1
@@ -36,6 +38,7 @@ require (
3638
github.com/joeshaw/multierror v0.0.0-20140124173710-69b34d4ec901
3739
github.com/josephspurrier/goversioninfo v0.0.0-20190209210621-63e6d1acd3dd
3840
github.com/kardianos/service v1.2.1-0.20210728001519-a323c3813bc7
41+
github.com/leehinman/mock-es v0.0.0-20240229001931-093363150049
3942
github.com/magefile/mage v1.15.0
4043
github.com/mitchellh/gox v1.0.1
4144
github.com/mitchellh/hashstructure v1.1.0
@@ -49,6 +52,7 @@ require (
4952
github.com/otiai10/copy v1.14.0
5053
github.com/pierrre/gotestcover v0.0.0-20160517101806-924dca7d15f0
5154
github.com/pkg/errors v0.9.1
55+
github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475
5256
github.com/rs/zerolog v1.27.0
5357
github.com/sajari/regression v1.0.1
5458
github.com/schollz/progressbar/v3 v3.13.1
@@ -104,6 +108,11 @@ require (
104108
k8s.io/utils v0.0.0-20221128185143-99ec85e7a448
105109
)
106110

111+
require (
112+
github.com/cavaliercoder/badio v0.0.0-20160213150051-ce5280129e9e // indirect
113+
github.com/distribution/reference v0.5.0 // indirect
114+
)
115+
107116
require (
108117
github.com/Jeffail/gabs/v2 v2.6.0 // indirect
109118
github.com/StackExchange/wmi v1.2.1 // indirect
@@ -112,11 +121,9 @@ require (
112121
github.com/armon/go-radix v1.0.0 // indirect
113122
github.com/beorn7/perks v1.0.1 // indirect
114123
github.com/bmatcuk/doublestar/v4 v4.6.1 // indirect
115-
github.com/cavaliercoder/badio v0.0.0-20160213150051-ce5280129e9e // indirect
116124
github.com/cespare/xxhash/v2 v2.3.0 // indirect
117125
github.com/cyphar/filepath-securejoin v0.2.4 // indirect
118126
github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc // indirect
119-
github.com/distribution/reference v0.5.0 // indirect
120127
github.com/dnephin/pflag v1.0.7 // indirect
121128
github.com/docker/docker v25.0.5+incompatible // indirect
122129
github.com/docker/go-connections v0.5.0 // indirect
@@ -285,3 +292,5 @@ replace (
285292
exclude github.com/docker/distribution v2.8.0+incompatible
286293

287294
replace github.com/elastic/elastic-agent-libs => github.com/belimawr/elastic-agent-libs v0.2.9-0.20240412105659-59acf2d3c5e3
295+
296+
replace github.com/leehinman/mock-es => github.com/belimawr/mock-es v0.0.0-20240423150351-ecf6421a0b11

go.sum

+4
Original file line numberDiff line numberDiff line change
@@ -512,6 +512,8 @@ github.com/aws/aws-sdk-go v1.43.16/go.mod h1:y4AeaBuwd2Lk+GepC1E9v0qOiTws0MIWAX4
512512
github.com/aymerick/raymond v2.0.2+incompatible/go.mod h1:osfaiScAUVup+UC9Nfq76eWqDhXlp+4UYaA8uhTBO6g=
513513
github.com/belimawr/elastic-agent-libs v0.2.9-0.20240412105659-59acf2d3c5e3 h1:X5oTGKS/VSK3H1Ojgly6Wp6sn+KL6kK2J8T/cIT3QXA=
514514
github.com/belimawr/elastic-agent-libs v0.2.9-0.20240412105659-59acf2d3c5e3/go.mod h1:SkMnpLm+tXybBrIWK6f3rcOhrDIztLbYCV46m8gwc8g=
515+
github.com/belimawr/mock-es v0.0.0-20240423150351-ecf6421a0b11 h1:k85u5ec4NXzzyMyEYaxzcrYz6RoMDuyOYfQ+KVDFADc=
516+
github.com/belimawr/mock-es v0.0.0-20240423150351-ecf6421a0b11/go.mod h1:Q6IJqnt4l+98QbM8b+dfxeMRYKoRBbvFe8zCRrAmK6I=
515517
github.com/benbjohnson/clock v1.0.3/go.mod h1:bGMdMPoPVvcYyt1gHDf4J2KE153Yf9BuiUKYMaxlTDM=
516518
github.com/benbjohnson/clock v1.1.0/go.mod h1:J11/hYXuz8f4ySSvYwY0FKfm+ezbsZBKZxNJlLklBHA=
517519
github.com/beorn7/perks v0.0.0-20160804104726-4c0e84591b9a/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q=
@@ -1682,6 +1684,8 @@ github.com/prometheus/procfs v0.8.0/go.mod h1:z7EfXMXOkbkqb9IINtpCn86r/to3BnA0ua
16821684
github.com/prometheus/procfs v0.13.0 h1:GqzLlQyfsPbaEHaQkO7tbDlriv/4o5Hudv6OXHGKX7o=
16831685
github.com/prometheus/procfs v0.13.0/go.mod h1:cd4PFCR54QLnGKPaKGA6l+cfuNXtht43ZKY6tow0Y1g=
16841686
github.com/prometheus/tsdb v0.7.1/go.mod h1:qhTCs0VvXwvX/y3TZrWD7rabWM+ijKTux40TwIPHuXU=
1687+
github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 h1:N/ElC8H3+5XpJzTSTfLsJV/mx9Q9g7kxmchpfZyxgzM=
1688+
github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4=
16851689
github.com/rivo/uniseg v0.2.0/go.mod h1:J6wj4VEh+S6ZtnVlnTBMWIodfgj8LQOQFoIToxlJtxc=
16861690
github.com/rivo/uniseg v0.4.3/go.mod h1:FN3SvrM+Zdj16jyLfmOkMNblXMcoc8DfTHruCPUcx88=
16871691
github.com/rivo/uniseg v0.4.4 h1:8TfxU8dW6PdqD27gjM8MVNuicgxIjxpm4K7x4jp8sis=

testing/integration/logs_ingestion_test.go

+96-5
Original file line numberDiff line numberDiff line change
@@ -12,20 +12,17 @@ import (
1212
"encoding/json"
1313
"fmt"
1414
"net/http"
15+
"net/http/httptest"
1516
"net/http/httputil"
1617
"os"
18+
"path"
1719
"path/filepath"
1820
"regexp"
1921
"strings"
2022
"testing"
2123
"text/template"
2224
"time"
2325

24-
"github.com/google/uuid"
25-
"github.com/hectane/go-acl"
26-
"github.com/stretchr/testify/assert"
27-
"github.com/stretchr/testify/require"
28-
2926
"github.com/elastic/elastic-agent-libs/kibana"
3027
"github.com/elastic/elastic-agent/pkg/control/v2/client"
3128
atesting "github.com/elastic/elastic-agent/pkg/testing"
@@ -36,6 +33,12 @@ import (
3633
"github.com/elastic/elastic-agent/pkg/testing/tools/fleettools"
3734
"github.com/elastic/elastic-agent/pkg/testing/tools/testcontext"
3835
"github.com/elastic/elastic-transport-go/v8/elastictransport"
36+
"github.com/google/uuid"
37+
"github.com/hectane/go-acl"
38+
"github.com/leehinman/mock-es/api"
39+
"github.com/rcrowley/go-metrics"
40+
"github.com/stretchr/testify/assert"
41+
"github.com/stretchr/testify/require"
3942
)
4043

4144
func TestLogIngestionFleetManaged(t *testing.T) {
@@ -236,6 +239,94 @@ func TestRpmLogIngestFleetManaged(t *testing.T) {
236239
})
237240
}
238241

242+
var eventLogConfig = `
243+
outputs:
244+
default:
245+
type: elasticsearch
246+
hosts:
247+
- %s
248+
protocol: http
249+
preset: balanced
250+
251+
inputs:
252+
- type: filestream
253+
id: your-input-id
254+
streams:
255+
- id: your-filestream-stream-id
256+
data_stream:
257+
dataset: generic
258+
paths:
259+
- %s
260+
261+
# Disable monitoring so there are less Beats running and less logs being generated.
262+
agent.monitoring:
263+
enabled: false
264+
logs: false
265+
metrics: false
266+
pprof.enabled: false
267+
use_output: default
268+
http: # Needed if you already have an Elastic-Agent running on your machine
269+
enabled: false
270+
271+
# This just reduces the amount of logs.
272+
agent.logging.metrics.enabled: false
273+
`
274+
275+
func TestEventLogFile(t *testing.T) {
276+
// info := define.Require(t, define.Requirements{
277+
// Group: Default,
278+
// Stack: &define.Stack{},
279+
// Local: true,
280+
// Sudo: false,
281+
// })
282+
283+
ctx, cancel := testcontext.WithDeadline(t, context.Background(), time.Now().Add(10*time.Minute))
284+
defer cancel()
285+
286+
agentFixture, err := define.NewFixture(t, define.Version())
287+
require.NoError(t, err)
288+
289+
esURL := startMockES(t)
290+
291+
logFilepath := path.Join(t.TempDir(), t.Name())
292+
generateLogFile(t, logFilepath, time.Millisecond*100, 1)
293+
294+
cfg := fmt.Sprintf(eventLogConfig, esURL, logFilepath)
295+
296+
// agentFixture.PrepareAgentCommand(ctx, nil)
297+
if err := agentFixture.Prepare(ctx); err != nil {
298+
t.Fatalf("cannot prepare Elastic-Agent fixture: %s", err)
299+
}
300+
// if err := agentFixture.Configure(ctx, []byte(cfg)); err != nil {
301+
// t.Fatalf("cannot configure Elastic-Agent fixture: %s", err)
302+
// }
303+
304+
if err := agentFixture.Run(ctx, atesting.State{Configure: cfg}); err != nil {
305+
t.Fatalf("error running Elastic-Agent fixture: %s", err)
306+
}
307+
308+
for i := 0; i < 25; i++ {
309+
t.Log("sleeping", i)
310+
time.Sleep(time.Second)
311+
}
312+
313+
cancel()
314+
t.FailNow()
315+
}
316+
317+
func startMockES(t *testing.T) string {
318+
mux := http.NewServeMux()
319+
registry := metrics.NewRegistry()
320+
// go metrics.WriteJSON(metrics.DefaultRegistry, 5*time.Second, os.Stdout)
321+
uid := uuid.New()
322+
mux.Handle("/", api.NewAPIHandler(uid, registry, time.Now().Add(time.Hour), 0, 0, 0, 100))
323+
s := httptest.NewServer(mux)
324+
t.Log(s.URL)
325+
t.Cleanup(s.Close)
326+
327+
return s.URL
328+
}
329+
239330
func testMonitoringLogsAreShipped(
240331
t *testing.T,
241332
ctx context.Context,

0 commit comments

Comments
 (0)