Skip to content

Commit

Permalink
Merge branch 'main' into dependabot/go_modules/github.com/elastic/ela…
Browse files Browse the repository at this point in the history
…stic-agent-system-metrics-0.8.1
  • Loading branch information
cmacknz authored Nov 24, 2023
2 parents 40c1bdf + 97e8217 commit 569bd06
Show file tree
Hide file tree
Showing 84 changed files with 2,532 additions and 1,071 deletions.
71 changes: 58 additions & 13 deletions .buildkite/pipeline.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,14 +4,24 @@ env:
VAULT_PATH: "kv/ci-shared/observability-ingest/cloud/gcp"
DOCKER_REGISTRY: "docker.elastic.co"
steps:
- label: "check-ci"
key: "check-ci"
command: ".buildkite/scripts/steps/check-ci.sh"
agents:
provider: "gcp"
image: "family/core-ubuntu-2204"
retry:
manual:
allowed: true
- group: "Unit tests"
key: "unit-tests"
steps:
- label: "Unit tests - Ubuntu 22.04"
key: "unit-tests-2204"
command: ".buildkite/scripts/steps/unit-tests.sh"
artifact_paths:
- "build/TEST-**"
- "build/TEST-go-unit.html"
- "build/TEST-go-unit.xml"
- "build/diagnostics/*"
- "coverage.out"
agents:
Expand All @@ -25,7 +35,8 @@ steps:
key: "unit-tests-2204-arm64"
command: ".buildkite/scripts/steps/unit-tests.sh"
artifact_paths:
- "build/TEST-**"
- "build/TEST-go-unit.html"
- "build/TEST-go-unit.xml"
- "build/diagnostics/*"
- "coverage.out"
agents:
Expand All @@ -41,7 +52,8 @@ steps:
key: "unit-tests-win2022"
command: ".\\.buildkite\\scripts\\steps\\unit-tests.ps1"
artifact_paths:
- "build/TEST-**"
- "build/TEST-go-unit.html"
- "build/TEST-go-unit.xml"
- "build/diagnostics/*"
- "coverage.out"
agents:
Expand All @@ -58,7 +70,8 @@ steps:
key: "unit-tests-win2016"
command: ".\\.buildkite\\scripts\\steps\\unit-tests.ps1"
artifact_paths:
- "build/TEST-**"
- "build/TEST-go-unit.html"
- "build/TEST-go-unit.xml"
- "build/diagnostics/*"
- "coverage.out"
agents:
Expand All @@ -77,7 +90,8 @@ steps:
command: ".buildkite/scripts/steps/unit-tests.sh"
branches: main
artifact_paths:
- "build/TEST-**"
- "build/TEST-go-unit.html"
- "build/TEST-go-unit.xml"
- "build/diagnostics/*"
- "coverage.out"
agents:
Expand All @@ -91,7 +105,8 @@ steps:
key: "unit-tests-macos-13"
command: ".buildkite/scripts/steps/unit-tests.sh"
artifact_paths:
- "build/TEST-**"
- "build/TEST-go-unit.html"
- "build/TEST-go-unit.xml"
- "build/diagnostics/*"
- "coverage.out"
agents:
Expand All @@ -108,7 +123,8 @@ steps:
key: "unit-tests-win10"
command: ".\\.buildkite\\scripts\\steps\\unit-tests.ps1"
artifact_paths:
- "build/TEST-**"
- "build/TEST-go-unit.html"
- "build/TEST-go-unit.xml"
- "build/diagnostics/*"
- "coverage.out"
agents:
Expand All @@ -124,7 +140,8 @@ steps:
key: "unit-tests-win11"
command: ".\\.buildkite\\scripts\\steps\\unit-tests.ps1"
artifact_paths:
- "build/TEST-**"
- "build/TEST-go-unit.html"
- "build/TEST-go-unit.xml"
- "build/diagnostics/*"
- "coverage.out"
agents:
Expand Down Expand Up @@ -152,7 +169,7 @@ steps:
unit-tests-win11
"
artifact_paths:
- "build/TEST-**"
- "build/TEST-go-unit.cov"
agents:
image: "golang:1.20.10"
depends_on:
Expand All @@ -168,10 +185,6 @@ steps:
K8S_VERSION: "v{{matrix.k8s_version}}"
KIND_VERSION: "v0.20.0"
command: ".buildkite/scripts/steps/k8s-tests.sh"
artifact_paths:
- "build/TEST-**"
- "build/diagnostics/*"
- "coverage.out"
agents:
provider: "gcp"
image: "family/core-ubuntu-2204"
Expand Down Expand Up @@ -219,6 +232,18 @@ steps:
provider: "gcp"
machineType: "n1-standard-8"

- label: "Serverless Beats Tests"
key: "serverless-beats-integration-tests"
command: ".buildkite/scripts/steps/beats_tests.sh"
if: "build.env('CRON') == 'yes'"
agents:
provider: "gcp"
machineType: "n1-standard-8"
retry:
manual:
allowed: true


- wait: ~
continue_on_failure: true
- label: "Processing test results"
Expand All @@ -227,3 +252,23 @@ steps:
plugins:
- junit-annotate#v2.4.1:
artifacts: build/TEST-go-integration*.xml

# Triggers a dynamic step: Sync K8s
# Runs only on main and if k8s files are changed
- label: "Trigger k8s sync"
branches: main
plugins:
- monebag/monorepo-diff#v2.5.9:
diff: "git diff --name-only HEAD~1"
watch:
- path:
- deploy/kubernetes/*
- version/docs/version.asciidoc
config:
label: "Sync K8s"
command: ".buildkite/scripts/steps/sync-k8s.sh"
agents:
provider: "gcp"
image: "family/core-ubuntu-2204"
env:
- GH_VERSION=2.4.0
4 changes: 2 additions & 2 deletions .buildkite/scripts/common.sh
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ getOSOptions() {
# Wrapper function for executing mage
mage() {
go version
if ! [ -x "$(type -p mage | sed 's/mage is //g')" ];
if ! [ -x "$(type -P mage | sed 's/mage is //g')" ];
then
echo "installing mage ${SETUP_MAGE_VERSION}"
make mage
Expand All @@ -68,7 +68,7 @@ mage() {
# Wrapper function for executing go
go(){
# Search for the go in the Path
if ! [ -x "$(type -p go | sed 's/go is //g')" ];
if ! [ -x "$(type -P go | sed 's/go is //g')" ];
then
getOSOptions
echo "installing golang "${GO_VERSION}" for "${AGENT_OS_NAME}/${AGENT_OS_ARCH}" "
Expand Down
54 changes: 54 additions & 0 deletions .buildkite/scripts/install-gh.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
#!/usr/bin/env bash

# Required environment variables:
# - GH_VERSION - the version of gh to install
set -exuo pipefail

echo "--- Install gh cli"

MSG="environment variable missing."
DEFAULT_HOME="/usr/local"
GH_VERSION=${GH_VERSION:-$MSG}
HOME=${HOME:-$DEFAULT_HOME}
GH_CMD="${HOME}/bin/gh"

if command -v gh
then
set +e
echo "Found GH. Checking version.."
FOUND_GH_VERSION=$(gh --version 2>&1 >/dev/null | awk '{print $3}')
if [ "$FOUND_GH_VERSION" == "$GH_VERSION" ]
then
echo "GH Versions match: $GH_VERSION. No need to install gh. Exiting."
exit 0
else
echo "GH Version mismatch. Desired version: $GH_VERSION, found version: $FOUND_GH_VERSION. Installing new version."
fi
set -e
fi

source .buildkite/scripts/common.sh

OS=$(uname -s| tr '[:upper:]' '[:lower:]')
ARCH=$(uname -m| tr '[:upper:]' '[:lower:]')
if [ "${ARCH}" == "aarch64" ] ; then
ARCH_SUFFIX=arm64
else
ARCH_SUFFIX=amd64
fi

echo "Downloading gh : ${GH_VERSION}..."
TMP_DIR=$(mktemp -d)
if retry 5 curl -sL "https://github.com/cli/cli/releases/download/v${GH_VERSION}/gh_${GH_VERSION}_linux_amd64.tar.gz" | tar xz -C $TMP_DIR ; then
mkdir -p "${HOME}/bin"
mv "${TMP_DIR}/gh_${GH_VERSION}_linux_amd64/bin/gh" "${GH_CMD}"
rm -rf "${TMP_DIR}"
else
echo "Something bad with the download, deleting the binary"
if [ -e "${GH_CMD}" ] ; then
rm "${GH_CMD}"
fi
exit 1
fi


2 changes: 1 addition & 1 deletion .buildkite/scripts/install-kind.sh
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
#!/usr/bin/env bash
set -exuo pipefail
set -euo pipefail

echo "--- Install Kind"

Expand Down
70 changes: 70 additions & 0 deletions .buildkite/scripts/steps/beats_tests.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
#!/usr/bin/env bash
set -euo pipefail

#=========================
# NOTE: This entire script is a temporary hack until we have buildkite set up on the beats repo.
# until then, we need some kind of serverless integration tests, hence this script, which just clones the beats repo,
# and runs the serverless integration suite against different beats
# After buildkite is set up on beats, this file/PR should be reverted.
#==========================

source .buildkite/scripts/common.sh
STACK_PROVISIONER="${1:-"serverless"}"

run_test_for_beat(){
local beat_name=$1

#build
export WORKSPACE="build/beats/x-pack/${beat_name}"
SNAPSHOT=true PLATFORMS=linux/amd64 PACKAGES=tar.gz,zip mage package

#run
export AGENT_BUILD_DIR="build/beats/x-pack/${beat_name}/build/distributions"
export WORKSPACE=$(pwd)

set +e
TEST_INTEG_CLEAN_ON_EXIT=true TEST_PLATFORMS="linux/amd64" STACK_PROVISIONER="$STACK_PROVISIONER" SNAPSHOT=true mage integration:testBeatServerless $beat_name
TESTS_EXIT_STATUS=$?
set -e

return $TESTS_EXIT_STATUS
}
#run mage before setup, since this will install go and mage
#the setup scripts will do a few things that assume we're running out of elastic-agent and will break things for beats, so run before we do actual setup
mage -l

mkdir -p build
cd build

git clone --filter=tree:0 [email protected]:elastic/beats.git
cd ..

# export WORKSPACE=beats/x-pack/metricbeat

# SNAPSHOT=true PLATFORMS=linux/amd64,windows/amd64 PACKAGES=tar.gz,zip mage package


# cd ..

# export AGENT_BUILD_DIR=build/beats/x-pack/metricbeat/build/distributions
# export WORKSPACE=$(pwd)

# set +e
# TEST_INTEG_CLEAN_ON_EXIT=true TEST_PLATFORMS="linux/amd64" STACK_PROVISIONER="$STACK_PROVISIONER" SNAPSHOT=true mage integration:testBeatServerless metricbeat
# TESTS_EXIT_STATUS=$?
# set -e

# exit $TESTS_EXIT_STATUS

echo "testing metricbeat..."
run_test_for_beat metricbeat



echo "testing filebeat..."
run_test_for_beat filebeat



echo "testing auditbeat..."
run_test_for_beat auditbeat
12 changes: 12 additions & 0 deletions .buildkite/scripts/steps/check-ci.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
#!/usr/bin/env bash

set -euo pipefail

source .buildkite/scripts/common.sh

echo "--- Check CI"
go version
mage --version
BEAT_VERSION=$(make get-version)
echo "Beat version: $BEAT_VERSION"
make check-ci
22 changes: 22 additions & 0 deletions .buildkite/scripts/steps/sync-k8s.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
#!/bin/bash
set -euo pipefail

export PATH=$HOME/bin:${PATH}

source .buildkite/scripts/install-gh.sh
source .buildkite/scripts/common.sh

export GITHUB_TOKEN=$(retry 5 vault kv get -field token kv/ci-shared/platform-ingest/github_token)

cd deploy/kubernetes

echo "--- [File Creation] Create-Needed-Manifest"
WITHOUTCONFIG=true make generate-k8s
./creator_k8s_manifest.sh .

echo "--- [Clone] Kibana-Repository"
make ci-clone-kibana-repository
cp Makefile ./kibana
cd kibana
echo "--- Create Kibana PR"
make ci-create-kubernetes-templates-pull-request
Loading

0 comments on commit 569bd06

Please sign in to comment.