-
Notifications
You must be signed in to change notification settings - Fork 8.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'main' into analytics-dashboard-3
- Loading branch information
Showing
1,279 changed files
with
19,769 additions
and
5,560 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
steps: | ||
- label: ':male-mechanic::skin-tone-2: Pre-Build' | ||
command: .buildkite/scripts/lifecycle/pre_build.sh | ||
agents: | ||
queue: kibana-default | ||
timeout_in_minutes: 10 | ||
|
||
- wait | ||
|
||
- label: ':kibana: Scalability Tests' | ||
command: .buildkite/scripts/steps/scalability/benchmarking.sh | ||
agents: | ||
queue: kb-static-scalability | ||
timeout_in_minutes: 90 | ||
|
||
- wait: ~ | ||
continue_on_failure: true | ||
|
||
- label: ':male_superhero::skin-tone-2: Post-Build' | ||
command: .buildkite/scripts/lifecycle/post_build.sh | ||
agents: | ||
queue: kibana-default | ||
timeout_in_minutes: 10 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,122 @@ | ||
#!/usr/bin/env bash | ||
|
||
set -euo pipefail | ||
|
||
source .buildkite/scripts/common/util.sh | ||
|
||
#.buildkite/scripts/bootstrap.sh | ||
echo "--- yarn kbn reset && yarn kbn bootstrap" | ||
yarn kbn reset && yarn kbn bootstrap | ||
|
||
GCS_BUCKET="gs://kibana-performance/scalability-tests" | ||
GCS_ARTIFACTS_REL="gcs_artifacts" | ||
GCS_ARTIFACTS_DIR="${WORKSPACE}/${GCS_ARTIFACTS_REL}" | ||
KIBANA_LOAD_TESTING_DIR="${KIBANA_DIR}/kibana-load-testing" | ||
|
||
# These tests are running on static workers so we must delete previous build, load runner and scalability artifacts | ||
rm -rf "${KIBANA_BUILD_LOCATION}" | ||
rm -rf "${KIBANA_LOAD_TESTING_DIR}" | ||
rm -rf "${GCS_ARTIFACTS_DIR}" | ||
|
||
download_artifacts() { | ||
mkdir -p "${GCS_ARTIFACTS_DIR}" | ||
|
||
gsutil cp "$GCS_BUCKET/latest" "${GCS_ARTIFACTS_DIR}/" | ||
HASH=`cat ${GCS_ARTIFACTS_DIR}/latest` | ||
gsutil cp -r "$GCS_BUCKET/$HASH" "${GCS_ARTIFACTS_DIR}/" | ||
|
||
export LATEST_RUN_ARTIFACTS_DIR="${GCS_ARTIFACTS_DIR}/${HASH}" | ||
|
||
echo "Unzip kibana build, plugins and scalability traces" | ||
cd "$WORKSPACE" | ||
mkdir -p "$KIBANA_BUILD_LOCATION" | ||
tar -xzf "${LATEST_RUN_ARTIFACTS_DIR}/kibana-default.tar.gz" -C "$KIBANA_BUILD_LOCATION" --strip=1 | ||
|
||
cd "$KIBANA_DIR" | ||
tar -xzf "${LATEST_RUN_ARTIFACTS_DIR}/kibana-default-plugins.tar.gz" | ||
tar -xzf "${LATEST_RUN_ARTIFACTS_DIR}/scalability_traces.tar.gz" | ||
} | ||
|
||
checkout_and_compile_load_runner() { | ||
mkdir -p "${KIBANA_LOAD_TESTING_DIR}" && cd "${KIBANA_LOAD_TESTING_DIR}" | ||
|
||
if [[ ! -d .git ]]; then | ||
git init | ||
git remote add origin https://github.com/elastic/kibana-load-testing.git | ||
fi | ||
git fetch origin --depth 1 "main" | ||
git reset --hard FETCH_HEAD | ||
|
||
KIBANA_LOAD_TESTING_GIT_COMMIT="$(git rev-parse HEAD)" | ||
export KIBANA_LOAD_TESTING_GIT_COMMIT | ||
|
||
mvn -q test-compile | ||
echo "Set 'GATLING_PROJECT_PATH' env var for ScalabilityTestRunner" | ||
export GATLING_PROJECT_PATH="$(pwd)" | ||
} | ||
|
||
upload_test_results() { | ||
cd "${KIBANA_DIR}" | ||
echo "--- Archive Gatling reports and upload as build artifacts" | ||
tar -czf "scalability_test_report.tar.gz" --exclude=simulation.log -C kibana-load-testing/target gatling | ||
buildkite-agent artifact upload "scalability_test_report.tar.gz" | ||
cd "${LATEST_RUN_ARTIFACTS_DIR}" | ||
echo "Upload scalability traces as build artifacts" | ||
buildkite-agent artifact upload "scalability_traces.tar.gz" | ||
} | ||
|
||
echo "--- Download the latest artifacts from single user performance pipeline" | ||
download_artifacts | ||
|
||
echo "--- Clone kibana-load-testing repo and compile project" | ||
checkout_and_compile_load_runner | ||
|
||
echo "--- Run Scalability Tests with Elasticsearch started only once and Kibana restart before each journey" | ||
cd "$KIBANA_DIR" | ||
node scripts/es snapshot& | ||
|
||
esPid=$! | ||
# Set trap on EXIT to stop Elasticsearch process | ||
trap "kill -9 $esPid" EXIT | ||
|
||
# unset env vars defined in other parts of CI for automatic APM collection of | ||
# Kibana. We manage APM config in our FTR config and performance service, and | ||
# APM treats config in the ENV with a very high precedence. | ||
unset ELASTIC_APM_ENVIRONMENT | ||
unset ELASTIC_APM_TRANSACTION_SAMPLE_RATE | ||
unset ELASTIC_APM_SERVER_URL | ||
unset ELASTIC_APM_SECRET_TOKEN | ||
unset ELASTIC_APM_ACTIVE | ||
unset ELASTIC_APM_CONTEXT_PROPAGATION_ONLY | ||
unset ELASTIC_APM_GLOBAL_LABELS | ||
unset ELASTIC_APM_MAX_QUEUE_SIZE | ||
unset ELASTIC_APM_METRICS_INTERVAL | ||
unset ELASTIC_APM_CAPTURE_SPAN_STACK_TRACES | ||
unset ELASTIC_APM_BREAKDOWN_METRICS | ||
|
||
|
||
export TEST_ES_DISABLE_STARTUP=true | ||
ES_HOST="localhost:9200" | ||
export TEST_ES_URL="http://elastic:changeme@${ES_HOST}" | ||
# Overriding Gatling default configuration | ||
export ES_URL="http://${ES_HOST}" | ||
|
||
# Pings the ES server every second for 2 mins until its status is green | ||
curl --retry 120 \ | ||
--retry-delay 1 \ | ||
--retry-connrefused \ | ||
-I -XGET "${TEST_ES_URL}/_cluster/health?wait_for_nodes=>=1&wait_for_status=yellow" | ||
|
||
export ELASTIC_APM_ACTIVE=true | ||
|
||
for journey in scalability_traces/server/*; do | ||
export SCALABILITY_JOURNEY_PATH="$KIBANA_DIR/$journey" | ||
echo "--- Run scalability file: $SCALABILITY_JOURNEY_PATH" | ||
node scripts/functional_tests \ | ||
--config x-pack/test/performance/scalability/config.ts \ | ||
--kibana-install-dir "$KIBANA_BUILD_LOCATION" \ | ||
--debug | ||
done | ||
|
||
echo "--- Upload test results" | ||
upload_test_results |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.