x-pack/filebeat/magefile.go (107 lines of code) (raw):

// Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one // or more contributor license agreements. Licensed under the Elastic License; // you may not use this file except in compliance with the Elastic License. //go:build mage package main import ( "context" "fmt" "os" "time" "github.com/magefile/mage/mg" devtools "github.com/elastic/beats/v7/dev-tools/mage" "github.com/elastic/beats/v7/dev-tools/mage/target/build" filebeat "github.com/elastic/beats/v7/filebeat/scripts/mage" //mage:import "github.com/elastic/beats/v7/dev-tools/mage/target/common" //mage:import generate _ "github.com/elastic/beats/v7/filebeat/scripts/mage/generate" //mage:import _ "github.com/elastic/beats/v7/dev-tools/mage/target/integtest/docker" //mage:import _ "github.com/elastic/beats/v7/dev-tools/mage/target/unittest" //mage:import "github.com/elastic/beats/v7/dev-tools/mage/target/test" ) func init() { common.RegisterCheckDeps(Update) test.RegisterDeps(IntegTest) devtools.BeatDescription = "Filebeat sends log files to Logstash or directly to Elasticsearch." devtools.BeatLicense = "Elastic License" } // Build builds the Beat binary. func Build() error { return devtools.Build(devtools.DefaultBuildArgs()) } // BuildSystemTestBinary builds a binary instrumented for use with Python system tests. func BuildSystemTestBinary() error { return devtools.BuildSystemTestBinary() } // GolangCrossBuild builds the Beat binary inside of the golang-builder. // Do not use directly, use crossBuild instead. func GolangCrossBuild() error { return filebeat.GolangCrossBuild() } // CrossBuild cross-builds the beat for all target platforms. func CrossBuild() error { return filebeat.CrossBuild() } // AssembleDarwinUniversal merges the darwin/amd64 and darwin/arm64 into a single // universal binary using `lipo`. It assumes the darwin/amd64 and darwin/arm64 // were built and only performs the merge. func AssembleDarwinUniversal() error { return build.AssembleDarwinUniversal() } // Package packages the Beat for distribution. // Use SNAPSHOT=true to build snapshots. // Use PLATFORMS to control the target platforms. // Use VERSION_QUALIFIER to control the version qualifier. func Package() { start := time.Now() defer func() { fmt.Println("package ran for", time.Since(start)) }() if v, found := os.LookupEnv("AGENT_PACKAGING"); found && v != "" { devtools.UseElasticBeatXPackReducedPackaging() } else { devtools.UseElasticBeatXPackPackaging() } devtools.PackageKibanaDashboardsFromBuildDir() filebeat.CustomizePackaging() mg.Deps(Update) mg.Deps(CrossBuild) mg.SerialDeps(devtools.Package, TestPackages) } // Package packages the Beat for IronBank distribution. // // Use SNAPSHOT=true to build snapshots. func Ironbank() error { start := time.Now() defer func() { fmt.Println("ironbank ran for", time.Since(start)) }() return devtools.Ironbank() } // TestPackages tests the generated packages (i.e. file modes, owners, groups). func TestPackages() error { return devtools.TestPackages() } // Fields generates the fields.yml file and a fields.go for each module, input, // and processor. func Fields() { mg.Deps(fieldsYML, moduleFieldsGo, inputFieldsGo, processorsFieldsGo) } func inputFieldsGo() error { return devtools.GenerateModuleFieldsGo("input") } func moduleFieldsGo() error { return devtools.GenerateModuleFieldsGo("module") } func processorsFieldsGo() error { return devtools.GenerateModuleFieldsGo("processors") } // fieldsYML generates a fields.yml based on filebeat + x-pack/filebeat/modules. func fieldsYML() error { return devtools.GenerateFieldsYAML(devtools.OSSBeatDir("module"), "module", "input", "processors") } // Dashboards collects all the dashboards and generates index patterns. func Dashboards() error { return devtools.KibanaDashboards(devtools.OSSBeatDir("module"), "module", "input") } // ExportDashboard exports a dashboard and writes it into the correct directory. // // Required environment variables: // - MODULE: Name of the module // - ID: Dashboard id func ExportDashboard() error { return devtools.ExportDashboard() } // Config generates both the short and reference configs. func Config() { mg.Deps(configYML, devtools.GenerateDirModulesD) mg.SerialDeps(devtools.ValidateDirModulesD, devtools.ValidateDirModulesDDatasetsDisabled) } func configYML() error { return devtools.Config(devtools.AllConfigTypes, filebeat.XPackConfigFileParams(), ".") } // Update is an alias for executing fields, dashboards, config. func Update() { mg.SerialDeps(Fields, Dashboards, Config, includeList, filebeat.PrepareModulePackagingXPack) } func includeList() error { options := devtools.DefaultIncludeListOptions() options.ImportDirs = []string{"input/*", "processors/*"} return devtools.GenerateIncludeListGo(options) } // IntegTest executes integration tests (it uses Docker to run the tests). func IntegTest() { mg.SerialDeps(GoIntegTest, PythonIntegTest) } // GoIntegTest starts the docker containers and executes the Go integration tests. func GoIntegTest(ctx context.Context) error { mg.Deps(BuildSystemTestBinary) return devtools.GoIntegTestFromHost(ctx, devtools.DefaultGoTestIntegrationFromHostArgs()) } // PythonIntegTest starts the docker containers and executes the Python integration tests. func PythonIntegTest(ctx context.Context) error { mg.Deps(Fields, Dashboards, devtools.BuildSystemTestBinary) return devtools.PythonIntegTestFromHost(devtools.DefaultPythonTestIntegrationFromHostArgs()) }