-
Notifications
You must be signed in to change notification settings - Fork 148
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add serverless beats tests #3658
Changes from 106 commits
c55bbde
12ac235
e939383
2afe998
413c0d7
a16767d
7e8970a
9e26b7c
3aab6e6
369f62e
0b7afae
ef23b3a
a20930d
7d5da83
e75b495
85b4ba5
0051120
fd88bf2
ec9c8c5
e312d0b
27f8814
5611ff9
8267e47
a733070
acff625
3196a39
a79b814
de89941
6a5277b
a5039e6
5a49c56
918fec6
459206a
a7c0c0a
d158d76
b2e4e87
f359ef0
bf3e5f4
1e00bd0
203491c
0903608
875bbd1
c1cadb1
2b0d84d
8c07f05
9edc32c
0c7d0cb
ea4d684
4fe9a58
c3c8255
0a0ea06
d9b62c0
4165bdb
1194e06
c09e3f6
bf89a85
6dc7c94
421e35f
ee2a073
99ac425
a7f4383
d62781c
27f1701
a590d3b
38775b1
ac2d445
587def0
3e0eb23
94b3961
d8f17aa
5cf68f5
e9d8404
03d3705
18523dc
8da7a0b
40bea83
4ad1f14
77186df
c6ce641
537c81f
03aabf9
48d6c5a
04d501d
a81c543
75437d9
6bd9190
cdf67cf
a9ed68c
478e357
2bf8b9d
860829c
1c522ff
c55b000
f4f69ea
1ad5919
4823f2b
ff33974
9664cb3
882bc6e
af010c5
e5e7b69
2b8f099
97a60d4
b86305e
8454892
72567f4
48d7ea2
374cc74
fac8582
5cef809
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,73 @@ | ||
#!/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 [email protected]:elastic/beats.git | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why do we need to clone and build Beats? Why don't we just download the latest SNAPSHOT image using the artifacts API? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. +1 If we need to clone the repo, maybe we can get by with a partial clone (for example |
||
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..." | ||
if ! run_test_for_beat metricbeat; then | ||
exit 1 | ||
fi | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Nitpick: the script would fail anyway if There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ah, good point! |
||
|
||
echo "testing filebeat..." | ||
if ! run_test_for_beat filebeat; then | ||
exit 1 | ||
fi | ||
|
||
|
||
echo "testing auditbeat..." | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We can skip testing auditbeat since our team doesn't maintain it. None of the code we are testing is really Beat specific regardless. |
||
if ! run_test_for_beat auditbeat; then | ||
exit 1 | ||
fi |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Where is the cron schedule controlled? Can you link to it here?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So, I was going to add it once the PR was merged, but the control panel for it is here: https://buildkite.com/elastic/elastic-agent/settings/schedules
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Add a link to that as a comment right above this so future us can find it easily