-
Notifications
You must be signed in to change notification settings - Fork 1.3k
fix password prompt during kmt.launch-stack #37903
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
base: main
Are you sure you want to change the base?
Conversation
Gitlab CI Configuration ChangesModified Jobs.kmt_setup_env .kmt_setup_env:
after_script:
- DD_API_KEY=$($CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_API_KEY_ORG2 token)
|| exit $?; export DD_API_KEY
- export AWS_PROFILE=agent-qa-ci
- FILTER_TEAM="Name=tag:team,Values=ebpf-platform"
- FILTER_MANAGED="Name=tag:managed-by,Values=pulumi"
- FILTER_STATE="Name=instance-state-name,Values=running"
- FILTER_PIPELINE="Name=tag:pipeline-id,Values=${CI_PIPELINE_ID}"
- FILTER_ARCH="Name=tag:arch,Values=${ARCH}"
- FILTER_INSTANCE_TYPE="Name=tag:instance-type,Values=${INSTANCE_TYPE}"
- FILTER_TEST_COMPONENT="Name=tag:test-component,Values=${TEST_COMPONENT}"
- QUERY_INSTANCE_IDS='Reservations[*].Instances[*].InstanceId'
- QUERY_PRIVATE_IPS='Reservations[*].Instances[*].PrivateIpAddress'
- mkdir -p $CI_PROJECT_DIR/libvirt/log/$ARCH $CI_PROJECT_DIR/libvirt/xml $CI_PROJECT_DIR/libvirt/qemu
$CI_PROJECT_DIR/libvirt/dnsmasq
- INSTANCE_IP=$(aws ec2 describe-instances --filters $FILTER_TEAM $FILTER_MANAGED
$FILTER_STATE $FILTER_PIPELINE $FILTER_TEST_COMPONENT $FILTER_INSTANCE_TYPE --output
text --query $QUERY_PRIVATE_IPS)
- echo "$ARCH-instance-ip" $INSTANCE_IP
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"sudo virsh list --name | grep -v -E '^$' | xargs -I '{}' sh -c \"sudo virsh dumpxml
'{}' > /tmp/ddvm-xml-'{}'.txt\""
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"sudo virsh list --name | xargs -I '{}' sh -c \"sudo cp /var/log/libvirt/qemu/'{}'.log
/tmp/qemu-ddvm-'{}'.log && sudo chown 1000:1000 /tmp/qemu-ddvm*\""
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"mkdir /tmp/dnsmasq && sudo cp /var/lib/libvirt/dnsmasq/* /tmp/dnsmasq/ && sudo
chown 1000:1000 /tmp/dnsmasq/*"
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/ddvm-*.log"
$CI_PROJECT_DIR/libvirt/log
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/ddvm-xml-*"
$CI_PROJECT_DIR/libvirt/xml
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/qemu-ddvm-*.log"
$CI_PROJECT_DIR/libvirt/qemu
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/dnsmasq/*"
$CI_PROJECT_DIR/libvirt/dnsmasq
- "GO_ARCH=$ARCH\nif [ \"${ARCH}\" == \"x86_64\" ]; then\n GO_ARCH=amd64\nfi\n"
- cd test/new-e2e && GOOS=linux GOARCH="${GO_ARCH}" go build system-probe/vm-metrics/vm-metrics.go
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE $CI_PROJECT_DIR/test/new-e2e/vm-metrics
"ubuntu@$INSTANCE_IP:/home/ubuntu/vm-metrics"
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"/home/ubuntu/vm-metrics -statsd-host=127.0.0.1 -statsd-port=8125 -libvirt-uri=/var/run/libvirt/libvirt-sock-ro
--tag \"arch:${ARCH}\" --tag \"test-component:${TEST_COMPONENT}\" --tag \"ci-pipeline-id:${CI_PIPELINE_ID}\"
--daemon -log-file /home/ubuntu/daemon.log"
- dda inv -- -e kmt.tag-ci-job
artifacts:
paths:
- $CI_PROJECT_DIR/stack.output
- $CI_PROJECT_DIR/libvirt
- $VMCONFIG_FILE
reports:
annotations:
- $EXTERNAL_LINKS_PATH
when: always
before_script:
- DD_API_KEY=$($CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_API_KEY_ORG2 token)
|| exit $?; export DD_API_KEY
- mkdir -p $GOPATH/pkg/mod/cache && tar xJf modcache.tar.xz -C $GOPATH/pkg/mod/cache
|| exit 101
- rm -f modcache.tar.xz
- mkdir -p ~/.aws
- $CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_QA_E2E profile >> ~/.aws/config
|| exit $?
- export AWS_PROFILE=agent-qa-ci
- touch $AWS_EC2_SSH_KEY_FILE && chmod 600 $AWS_EC2_SSH_KEY_FILE
- $CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_QA_E2E ssh_key > $AWS_EC2_SSH_KEY_FILE
|| exit $?
- echo "" >> $AWS_EC2_SSH_KEY_FILE
- chmod 600 $AWS_EC2_SSH_KEY_FILE
- dda inv -- -e gitlab.generate-ci-visibility-links --output=$EXTERNAL_LINKS_PATH
|| true
image: registry.ddbuild.io/ci/test-infra-definitions/runner$TEST_INFRA_DEFINITIONS_BUILDIMAGES_SUFFIX:$TEST_INFRA_DEFINITIONS_BUILDIMAGES
needs:
- go_deps
- go_tools_deps
script:
- echo "s3://dd-pulumi-state?region=us-east-1&awssdk=v2&profile=$AWS_PROFILE" >
$STACK_DIR
- pulumi login $(cat $STACK_DIR | tr -d '\n')
- dda inv -- -e kmt.gen-config --ci --arch=$ARCH --output-file=$VMCONFIG_FILE --vmconfig-template=$TEST_COMPONENT
--memory=12288
- - dda inv -- -e system-probe.start-microvms --provision-instance --provision-microvms
? ^^^ --------
+ - dda inv -- -e kmt.start-microvms --provision-instance --provision-microvms --vmconfig=$VMCONFIG_FILE
? ^^ ++++++++++++++++++++++++++
- --vmconfig=$VMCONFIG_FILE $INSTANCE_TYPE_ARG $AMI_ID_ARG --ssh-key-name=$AWS_EC2_SSH_KEY_NAME
+ $INSTANCE_TYPE_ARG $AMI_ID_ARG --ssh-key-name=$AWS_EC2_SSH_KEY_NAME --ssh-key-path=$AWS_EC2_SSH_KEY_FILE
- --ssh-key-path=$AWS_EC2_SSH_KEY_FILE --infra-env=$INFRA_ENV --stack-name=kernel-matrix-testing-${TEST_COMPONENT}-${ARCH}-${CI_PIPELINE_ID}
? -------------------------------------
+ --infra-env=$INFRA_ENV --stack-name=kernel-matrix-testing-${TEST_COMPONENT}-${ARCH}-${CI_PIPELINE_ID}
--run-agent
- jq "." $CI_PROJECT_DIR/stack.output
- pulumi logout
stage: kernel_matrix_testing_prepare
tags:
- arch:amd64
variables:
AWS_EC2_SSH_KEY_FILE: $CI_PROJECT_DIR/ssh_key
AWS_EC2_SSH_KEY_NAME: datadog-agent-ci
AWS_REGION: us-east-1
EXTERNAL_LINKS_PATH: external_links_$CI_JOB_ID.json
INFRA_ENV: aws/agent-qa
KITCHEN_EC2_REGION: us-east-1
KITCHEN_EC2_SG_IDS: sg-019917348cb0eb7e7
KITCHEN_EC2_SUBNET: subnet-05d7c6b1b5cfea811
KUBERNETES_MEMORY_LIMIT: 16Gi
KUBERNETES_MEMORY_REQUEST: 12Gi
PIPELINE_ID: $CI_PIPELINE_ID
RESOURCE_TAGS: instance-type:${INSTANCE_TYPE},arch:${ARCH},test-component:${TEST_COMPONENT},git-branch:${CI_COMMIT_REF_NAME}
STACK_DIR: $CI_PROJECT_DIR/stack.dir
TEAM: ebpf-platform
VMCONFIG_FILE: ${CI_PROJECT_DIR}/vmconfig-${CI_PIPELINE_ID}-${ARCH}.json kmt_setup_env_secagent_arm64 kmt_setup_env_secagent_arm64:
after_script:
- DD_API_KEY=$($CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_API_KEY_ORG2 token)
|| exit $?; export DD_API_KEY
- export AWS_PROFILE=agent-qa-ci
- FILTER_TEAM="Name=tag:team,Values=ebpf-platform"
- FILTER_MANAGED="Name=tag:managed-by,Values=pulumi"
- FILTER_STATE="Name=instance-state-name,Values=running"
- FILTER_PIPELINE="Name=tag:pipeline-id,Values=${CI_PIPELINE_ID}"
- FILTER_ARCH="Name=tag:arch,Values=${ARCH}"
- FILTER_INSTANCE_TYPE="Name=tag:instance-type,Values=${INSTANCE_TYPE}"
- FILTER_TEST_COMPONENT="Name=tag:test-component,Values=${TEST_COMPONENT}"
- QUERY_INSTANCE_IDS='Reservations[*].Instances[*].InstanceId'
- QUERY_PRIVATE_IPS='Reservations[*].Instances[*].PrivateIpAddress'
- mkdir -p $CI_PROJECT_DIR/libvirt/log/$ARCH $CI_PROJECT_DIR/libvirt/xml $CI_PROJECT_DIR/libvirt/qemu
$CI_PROJECT_DIR/libvirt/dnsmasq
- INSTANCE_IP=$(aws ec2 describe-instances --filters $FILTER_TEAM $FILTER_MANAGED
$FILTER_STATE $FILTER_PIPELINE $FILTER_TEST_COMPONENT $FILTER_INSTANCE_TYPE --output
text --query $QUERY_PRIVATE_IPS)
- echo "$ARCH-instance-ip" $INSTANCE_IP
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"sudo virsh list --name | grep -v -E '^$' | xargs -I '{}' sh -c \"sudo virsh dumpxml
'{}' > /tmp/ddvm-xml-'{}'.txt\""
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"sudo virsh list --name | xargs -I '{}' sh -c \"sudo cp /var/log/libvirt/qemu/'{}'.log
/tmp/qemu-ddvm-'{}'.log && sudo chown 1000:1000 /tmp/qemu-ddvm*\""
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"mkdir /tmp/dnsmasq && sudo cp /var/lib/libvirt/dnsmasq/* /tmp/dnsmasq/ && sudo
chown 1000:1000 /tmp/dnsmasq/*"
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/ddvm-*.log"
$CI_PROJECT_DIR/libvirt/log
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/ddvm-xml-*"
$CI_PROJECT_DIR/libvirt/xml
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/qemu-ddvm-*.log"
$CI_PROJECT_DIR/libvirt/qemu
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/dnsmasq/*"
$CI_PROJECT_DIR/libvirt/dnsmasq
- "GO_ARCH=$ARCH\nif [ \"${ARCH}\" == \"x86_64\" ]; then\n GO_ARCH=amd64\nfi\n"
- cd test/new-e2e && GOOS=linux GOARCH="${GO_ARCH}" go build system-probe/vm-metrics/vm-metrics.go
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE $CI_PROJECT_DIR/test/new-e2e/vm-metrics
"ubuntu@$INSTANCE_IP:/home/ubuntu/vm-metrics"
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"/home/ubuntu/vm-metrics -statsd-host=127.0.0.1 -statsd-port=8125 -libvirt-uri=/var/run/libvirt/libvirt-sock-ro
--tag \"arch:${ARCH}\" --tag \"test-component:${TEST_COMPONENT}\" --tag \"ci-pipeline-id:${CI_PIPELINE_ID}\"
--daemon -log-file /home/ubuntu/daemon.log"
- dda inv -- -e kmt.tag-ci-job
artifacts:
paths:
- $CI_PROJECT_DIR/stack.output
- $CI_PROJECT_DIR/libvirt
- $VMCONFIG_FILE
reports:
annotations:
- $EXTERNAL_LINKS_PATH
when: always
before_script:
- DD_API_KEY=$($CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_API_KEY_ORG2 token)
|| exit $?; export DD_API_KEY
- mkdir -p $GOPATH/pkg/mod/cache && tar xJf modcache.tar.xz -C $GOPATH/pkg/mod/cache
|| exit 101
- rm -f modcache.tar.xz
- mkdir -p ~/.aws
- $CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_QA_E2E profile >> ~/.aws/config
|| exit $?
- export AWS_PROFILE=agent-qa-ci
- touch $AWS_EC2_SSH_KEY_FILE && chmod 600 $AWS_EC2_SSH_KEY_FILE
- $CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_QA_E2E ssh_key > $AWS_EC2_SSH_KEY_FILE
|| exit $?
- echo "" >> $AWS_EC2_SSH_KEY_FILE
- chmod 600 $AWS_EC2_SSH_KEY_FILE
- dda inv -- -e gitlab.generate-ci-visibility-links --output=$EXTERNAL_LINKS_PATH
|| true
image: registry.ddbuild.io/ci/test-infra-definitions/runner$TEST_INFRA_DEFINITIONS_BUILDIMAGES_SUFFIX:$TEST_INFRA_DEFINITIONS_BUILDIMAGES
needs:
- go_deps
- go_tools_deps
rules:
- allow_failure: true
if: $CI_COMMIT_BRANCH == "main"
- if: $CI_COMMIT_BRANCH =~ /^mq-working-branch-/
when: never
- if: $RUN_KMT_TESTS == 'on'
- changes:
compare_to: $COMPARE_TO_BRANCH
paths:
- pkg/ebpf/**/*
- pkg/security/**/*
- pkg/eventmonitor/**/*
- .gitlab/kernel_matrix_testing/security_agent.yml
- .gitlab/kernel_matrix_testing/common.yml
- .gitlab/source_test/ebpf.yml
- test/new-e2e/tests/cws/**/*
- test/new-e2e/system-probe/**/*
- test/new-e2e/scenarios/system-probe/**/*
- test/new-e2e/pkg/runner/**/*
- test/new-e2e/pkg/utils/**/*
- test/new-e2e/go.mod
- tasks/security_agent.py
- tasks/kmt.py
- tasks/kernel_matrix_testing/*
- allow_failure: true
when: manual
script:
- echo "s3://dd-pulumi-state?region=us-east-1&awssdk=v2&profile=$AWS_PROFILE" >
$STACK_DIR
- pulumi login $(cat $STACK_DIR | tr -d '\n')
- dda inv -- -e kmt.gen-config --ci --arch=$ARCH --output-file=$VMCONFIG_FILE --vmconfig-template=$TEST_COMPONENT
--memory=12288
- - dda inv -- -e system-probe.start-microvms --provision-instance --provision-microvms
? ^^^ --------
+ - dda inv -- -e kmt.start-microvms --provision-instance --provision-microvms --vmconfig=$VMCONFIG_FILE
? ^^ ++++++++++++++++++++++++++
- --vmconfig=$VMCONFIG_FILE $INSTANCE_TYPE_ARG $AMI_ID_ARG --ssh-key-name=$AWS_EC2_SSH_KEY_NAME
+ $INSTANCE_TYPE_ARG $AMI_ID_ARG --ssh-key-name=$AWS_EC2_SSH_KEY_NAME --ssh-key-path=$AWS_EC2_SSH_KEY_FILE
- --ssh-key-path=$AWS_EC2_SSH_KEY_FILE --infra-env=$INFRA_ENV --stack-name=kernel-matrix-testing-${TEST_COMPONENT}-${ARCH}-${CI_PIPELINE_ID}
? -------------------------------------
+ --infra-env=$INFRA_ENV --stack-name=kernel-matrix-testing-${TEST_COMPONENT}-${ARCH}-${CI_PIPELINE_ID}
--run-agent
- jq "." $CI_PROJECT_DIR/stack.output
- pulumi logout
stage: kernel_matrix_testing_prepare
tags:
- arch:amd64
variables:
AMI_ID_ARG: --arm-ami-id=$KERNEL_MATRIX_TESTING_ARM_AMI_ID
ARCH: arm64
AWS_EC2_SSH_KEY_FILE: $CI_PROJECT_DIR/ssh_key
AWS_EC2_SSH_KEY_NAME: datadog-agent-ci
AWS_REGION: us-east-1
EXTERNAL_LINKS_PATH: external_links_$CI_JOB_ID.json
INFRA_ENV: aws/agent-qa
INSTANCE_TYPE: m6gd.metal
INSTANCE_TYPE_ARG: --instance-type-arm=$INSTANCE_TYPE
KITCHEN_EC2_REGION: us-east-1
KITCHEN_EC2_SG_IDS: sg-019917348cb0eb7e7
KITCHEN_EC2_SUBNET: subnet-05d7c6b1b5cfea811
KUBERNETES_MEMORY_LIMIT: 16Gi
KUBERNETES_MEMORY_REQUEST: 12Gi
LibvirtSSHKey: $CI_PROJECT_DIR/libvirt_rsa-arm
PIPELINE_ID: $CI_PIPELINE_ID
RESOURCE_TAGS: instance-type:${INSTANCE_TYPE},arch:${ARCH},test-component:${TEST_COMPONENT},git-branch:${CI_COMMIT_REF_NAME}
STACK_DIR: $CI_PROJECT_DIR/stack.dir
TEAM: ebpf-platform
TEST_COMPONENT: security-agent
VMCONFIG_FILE: ${CI_PROJECT_DIR}/vmconfig-${CI_PIPELINE_ID}-${ARCH}.json kmt_setup_env_secagent_x64 kmt_setup_env_secagent_x64:
after_script:
- DD_API_KEY=$($CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_API_KEY_ORG2 token)
|| exit $?; export DD_API_KEY
- export AWS_PROFILE=agent-qa-ci
- FILTER_TEAM="Name=tag:team,Values=ebpf-platform"
- FILTER_MANAGED="Name=tag:managed-by,Values=pulumi"
- FILTER_STATE="Name=instance-state-name,Values=running"
- FILTER_PIPELINE="Name=tag:pipeline-id,Values=${CI_PIPELINE_ID}"
- FILTER_ARCH="Name=tag:arch,Values=${ARCH}"
- FILTER_INSTANCE_TYPE="Name=tag:instance-type,Values=${INSTANCE_TYPE}"
- FILTER_TEST_COMPONENT="Name=tag:test-component,Values=${TEST_COMPONENT}"
- QUERY_INSTANCE_IDS='Reservations[*].Instances[*].InstanceId'
- QUERY_PRIVATE_IPS='Reservations[*].Instances[*].PrivateIpAddress'
- mkdir -p $CI_PROJECT_DIR/libvirt/log/$ARCH $CI_PROJECT_DIR/libvirt/xml $CI_PROJECT_DIR/libvirt/qemu
$CI_PROJECT_DIR/libvirt/dnsmasq
- INSTANCE_IP=$(aws ec2 describe-instances --filters $FILTER_TEAM $FILTER_MANAGED
$FILTER_STATE $FILTER_PIPELINE $FILTER_TEST_COMPONENT $FILTER_INSTANCE_TYPE --output
text --query $QUERY_PRIVATE_IPS)
- echo "$ARCH-instance-ip" $INSTANCE_IP
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"sudo virsh list --name | grep -v -E '^$' | xargs -I '{}' sh -c \"sudo virsh dumpxml
'{}' > /tmp/ddvm-xml-'{}'.txt\""
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"sudo virsh list --name | xargs -I '{}' sh -c \"sudo cp /var/log/libvirt/qemu/'{}'.log
/tmp/qemu-ddvm-'{}'.log && sudo chown 1000:1000 /tmp/qemu-ddvm*\""
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"mkdir /tmp/dnsmasq && sudo cp /var/lib/libvirt/dnsmasq/* /tmp/dnsmasq/ && sudo
chown 1000:1000 /tmp/dnsmasq/*"
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/ddvm-*.log"
$CI_PROJECT_DIR/libvirt/log
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/ddvm-xml-*"
$CI_PROJECT_DIR/libvirt/xml
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/qemu-ddvm-*.log"
$CI_PROJECT_DIR/libvirt/qemu
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/dnsmasq/*"
$CI_PROJECT_DIR/libvirt/dnsmasq
- "GO_ARCH=$ARCH\nif [ \"${ARCH}\" == \"x86_64\" ]; then\n GO_ARCH=amd64\nfi\n"
- cd test/new-e2e && GOOS=linux GOARCH="${GO_ARCH}" go build system-probe/vm-metrics/vm-metrics.go
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE $CI_PROJECT_DIR/test/new-e2e/vm-metrics
"ubuntu@$INSTANCE_IP:/home/ubuntu/vm-metrics"
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"/home/ubuntu/vm-metrics -statsd-host=127.0.0.1 -statsd-port=8125 -libvirt-uri=/var/run/libvirt/libvirt-sock-ro
--tag \"arch:${ARCH}\" --tag \"test-component:${TEST_COMPONENT}\" --tag \"ci-pipeline-id:${CI_PIPELINE_ID}\"
--daemon -log-file /home/ubuntu/daemon.log"
- dda inv -- -e kmt.tag-ci-job
artifacts:
paths:
- $CI_PROJECT_DIR/stack.output
- $CI_PROJECT_DIR/libvirt
- $VMCONFIG_FILE
reports:
annotations:
- $EXTERNAL_LINKS_PATH
when: always
before_script:
- DD_API_KEY=$($CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_API_KEY_ORG2 token)
|| exit $?; export DD_API_KEY
- mkdir -p $GOPATH/pkg/mod/cache && tar xJf modcache.tar.xz -C $GOPATH/pkg/mod/cache
|| exit 101
- rm -f modcache.tar.xz
- mkdir -p ~/.aws
- $CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_QA_E2E profile >> ~/.aws/config
|| exit $?
- export AWS_PROFILE=agent-qa-ci
- touch $AWS_EC2_SSH_KEY_FILE && chmod 600 $AWS_EC2_SSH_KEY_FILE
- $CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_QA_E2E ssh_key > $AWS_EC2_SSH_KEY_FILE
|| exit $?
- echo "" >> $AWS_EC2_SSH_KEY_FILE
- chmod 600 $AWS_EC2_SSH_KEY_FILE
- dda inv -- -e gitlab.generate-ci-visibility-links --output=$EXTERNAL_LINKS_PATH
|| true
image: registry.ddbuild.io/ci/test-infra-definitions/runner$TEST_INFRA_DEFINITIONS_BUILDIMAGES_SUFFIX:$TEST_INFRA_DEFINITIONS_BUILDIMAGES
needs:
- go_deps
- go_tools_deps
rules:
- allow_failure: true
if: $CI_COMMIT_BRANCH == "main"
- if: $CI_COMMIT_BRANCH =~ /^mq-working-branch-/
when: never
- if: $RUN_KMT_TESTS == 'on'
- changes:
compare_to: $COMPARE_TO_BRANCH
paths:
- pkg/ebpf/**/*
- pkg/security/**/*
- pkg/eventmonitor/**/*
- .gitlab/kernel_matrix_testing/security_agent.yml
- .gitlab/kernel_matrix_testing/common.yml
- .gitlab/source_test/ebpf.yml
- test/new-e2e/tests/cws/**/*
- test/new-e2e/system-probe/**/*
- test/new-e2e/scenarios/system-probe/**/*
- test/new-e2e/pkg/runner/**/*
- test/new-e2e/pkg/utils/**/*
- test/new-e2e/go.mod
- tasks/security_agent.py
- tasks/kmt.py
- tasks/kernel_matrix_testing/*
- allow_failure: true
when: manual
script:
- echo "s3://dd-pulumi-state?region=us-east-1&awssdk=v2&profile=$AWS_PROFILE" >
$STACK_DIR
- pulumi login $(cat $STACK_DIR | tr -d '\n')
- dda inv -- -e kmt.gen-config --ci --arch=$ARCH --output-file=$VMCONFIG_FILE --vmconfig-template=$TEST_COMPONENT
--memory=12288
- - dda inv -- -e system-probe.start-microvms --provision-instance --provision-microvms
? ^^^ --------
+ - dda inv -- -e kmt.start-microvms --provision-instance --provision-microvms --vmconfig=$VMCONFIG_FILE
? ^^ ++++++++++++++++++++++++++
- --vmconfig=$VMCONFIG_FILE $INSTANCE_TYPE_ARG $AMI_ID_ARG --ssh-key-name=$AWS_EC2_SSH_KEY_NAME
+ $INSTANCE_TYPE_ARG $AMI_ID_ARG --ssh-key-name=$AWS_EC2_SSH_KEY_NAME --ssh-key-path=$AWS_EC2_SSH_KEY_FILE
- --ssh-key-path=$AWS_EC2_SSH_KEY_FILE --infra-env=$INFRA_ENV --stack-name=kernel-matrix-testing-${TEST_COMPONENT}-${ARCH}-${CI_PIPELINE_ID}
? -------------------------------------
+ --infra-env=$INFRA_ENV --stack-name=kernel-matrix-testing-${TEST_COMPONENT}-${ARCH}-${CI_PIPELINE_ID}
--run-agent
- jq "." $CI_PROJECT_DIR/stack.output
- pulumi logout
stage: kernel_matrix_testing_prepare
tags:
- arch:amd64
variables:
AMI_ID_ARG: --x86-ami-id=$KERNEL_MATRIX_TESTING_X86_AMI_ID
ARCH: x86_64
AWS_EC2_SSH_KEY_FILE: $CI_PROJECT_DIR/ssh_key
AWS_EC2_SSH_KEY_NAME: datadog-agent-ci
AWS_REGION: us-east-1
EXTERNAL_LINKS_PATH: external_links_$CI_JOB_ID.json
INFRA_ENV: aws/agent-qa
INSTANCE_TYPE: m5d.metal
INSTANCE_TYPE_ARG: --instance-type-x86=$INSTANCE_TYPE
KITCHEN_EC2_REGION: us-east-1
KITCHEN_EC2_SG_IDS: sg-019917348cb0eb7e7
KITCHEN_EC2_SUBNET: subnet-05d7c6b1b5cfea811
KUBERNETES_MEMORY_LIMIT: 16Gi
KUBERNETES_MEMORY_REQUEST: 12Gi
LibvirtSSHKey: $CI_PROJECT_DIR/libvirt_rsa-x86
PIPELINE_ID: $CI_PIPELINE_ID
RESOURCE_TAGS: instance-type:${INSTANCE_TYPE},arch:${ARCH},test-component:${TEST_COMPONENT},git-branch:${CI_COMMIT_REF_NAME}
STACK_DIR: $CI_PROJECT_DIR/stack.dir
TEAM: ebpf-platform
TEST_COMPONENT: security-agent
VMCONFIG_FILE: ${CI_PROJECT_DIR}/vmconfig-${CI_PIPELINE_ID}-${ARCH}.json kmt_setup_env_sysprobe_arm64 kmt_setup_env_sysprobe_arm64:
after_script:
- DD_API_KEY=$($CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_API_KEY_ORG2 token)
|| exit $?; export DD_API_KEY
- export AWS_PROFILE=agent-qa-ci
- FILTER_TEAM="Name=tag:team,Values=ebpf-platform"
- FILTER_MANAGED="Name=tag:managed-by,Values=pulumi"
- FILTER_STATE="Name=instance-state-name,Values=running"
- FILTER_PIPELINE="Name=tag:pipeline-id,Values=${CI_PIPELINE_ID}"
- FILTER_ARCH="Name=tag:arch,Values=${ARCH}"
- FILTER_INSTANCE_TYPE="Name=tag:instance-type,Values=${INSTANCE_TYPE}"
- FILTER_TEST_COMPONENT="Name=tag:test-component,Values=${TEST_COMPONENT}"
- QUERY_INSTANCE_IDS='Reservations[*].Instances[*].InstanceId'
- QUERY_PRIVATE_IPS='Reservations[*].Instances[*].PrivateIpAddress'
- mkdir -p $CI_PROJECT_DIR/libvirt/log/$ARCH $CI_PROJECT_DIR/libvirt/xml $CI_PROJECT_DIR/libvirt/qemu
$CI_PROJECT_DIR/libvirt/dnsmasq
- INSTANCE_IP=$(aws ec2 describe-instances --filters $FILTER_TEAM $FILTER_MANAGED
$FILTER_STATE $FILTER_PIPELINE $FILTER_TEST_COMPONENT $FILTER_INSTANCE_TYPE --output
text --query $QUERY_PRIVATE_IPS)
- echo "$ARCH-instance-ip" $INSTANCE_IP
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"sudo virsh list --name | grep -v -E '^$' | xargs -I '{}' sh -c \"sudo virsh dumpxml
'{}' > /tmp/ddvm-xml-'{}'.txt\""
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"sudo virsh list --name | xargs -I '{}' sh -c \"sudo cp /var/log/libvirt/qemu/'{}'.log
/tmp/qemu-ddvm-'{}'.log && sudo chown 1000:1000 /tmp/qemu-ddvm*\""
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"mkdir /tmp/dnsmasq && sudo cp /var/lib/libvirt/dnsmasq/* /tmp/dnsmasq/ && sudo
chown 1000:1000 /tmp/dnsmasq/*"
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/ddvm-*.log"
$CI_PROJECT_DIR/libvirt/log
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/ddvm-xml-*"
$CI_PROJECT_DIR/libvirt/xml
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/qemu-ddvm-*.log"
$CI_PROJECT_DIR/libvirt/qemu
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/dnsmasq/*"
$CI_PROJECT_DIR/libvirt/dnsmasq
- "GO_ARCH=$ARCH\nif [ \"${ARCH}\" == \"x86_64\" ]; then\n GO_ARCH=amd64\nfi\n"
- cd test/new-e2e && GOOS=linux GOARCH="${GO_ARCH}" go build system-probe/vm-metrics/vm-metrics.go
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE $CI_PROJECT_DIR/test/new-e2e/vm-metrics
"ubuntu@$INSTANCE_IP:/home/ubuntu/vm-metrics"
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"/home/ubuntu/vm-metrics -statsd-host=127.0.0.1 -statsd-port=8125 -libvirt-uri=/var/run/libvirt/libvirt-sock-ro
--tag \"arch:${ARCH}\" --tag \"test-component:${TEST_COMPONENT}\" --tag \"ci-pipeline-id:${CI_PIPELINE_ID}\"
--daemon -log-file /home/ubuntu/daemon.log"
- dda inv -- -e kmt.tag-ci-job
artifacts:
paths:
- $CI_PROJECT_DIR/stack.output
- $CI_PROJECT_DIR/libvirt
- $VMCONFIG_FILE
reports:
annotations:
- $EXTERNAL_LINKS_PATH
when: always
before_script:
- DD_API_KEY=$($CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_API_KEY_ORG2 token)
|| exit $?; export DD_API_KEY
- mkdir -p $GOPATH/pkg/mod/cache && tar xJf modcache.tar.xz -C $GOPATH/pkg/mod/cache
|| exit 101
- rm -f modcache.tar.xz
- mkdir -p ~/.aws
- $CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_QA_E2E profile >> ~/.aws/config
|| exit $?
- export AWS_PROFILE=agent-qa-ci
- touch $AWS_EC2_SSH_KEY_FILE && chmod 600 $AWS_EC2_SSH_KEY_FILE
- $CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_QA_E2E ssh_key > $AWS_EC2_SSH_KEY_FILE
|| exit $?
- echo "" >> $AWS_EC2_SSH_KEY_FILE
- chmod 600 $AWS_EC2_SSH_KEY_FILE
- dda inv -- -e gitlab.generate-ci-visibility-links --output=$EXTERNAL_LINKS_PATH
|| true
image: registry.ddbuild.io/ci/test-infra-definitions/runner$TEST_INFRA_DEFINITIONS_BUILDIMAGES_SUFFIX:$TEST_INFRA_DEFINITIONS_BUILDIMAGES
needs:
- go_deps
- go_tools_deps
rules:
- if: $CI_COMMIT_BRANCH == "main"
- if: $CI_COMMIT_BRANCH =~ /^mq-working-branch-/
when: never
- if: $RUN_KMT_TESTS == 'on'
- changes:
compare_to: $COMPARE_TO_BRANCH
paths:
- cmd/system-probe/**/*
- pkg/collector/corechecks/ebpf/**/*
- pkg/collector/corechecks/servicediscovery/module/*
- pkg/ebpf/**/*
- pkg/network/**/*
- pkg/process/monitor/*
- pkg/util/kernel/**/*
- pkg/dynamicinstrumentation/**/*
- pkg/dyninst/**/*
- pkg/gpu/**/*
- .gitlab/kernel_matrix_testing/system_probe.yml
- .gitlab/kernel_matrix_testing/common.yml
- .gitlab/source_test/ebpf.yml
- test/new-e2e/system-probe/**/*
- test/new-e2e/scenarios/system-probe/**/*
- test/new-e2e/pkg/runner/**/*
- test/new-e2e/pkg/utils/**/*
- test/new-e2e/go.mod
- tasks/system_probe.py
- tasks/kmt.py
- tasks/kernel_matrix_testing/*
script:
- echo "s3://dd-pulumi-state?region=us-east-1&awssdk=v2&profile=$AWS_PROFILE" >
$STACK_DIR
- pulumi login $(cat $STACK_DIR | tr -d '\n')
- dda inv -- -e kmt.gen-config --ci --arch=$ARCH --output-file=$VMCONFIG_FILE --vmconfig-template=$TEST_COMPONENT
--memory=12288
- - dda inv -- -e system-probe.start-microvms --provision-instance --provision-microvms
? ^^^ --------
+ - dda inv -- -e kmt.start-microvms --provision-instance --provision-microvms --vmconfig=$VMCONFIG_FILE
? ^^ ++++++++++++++++++++++++++
- --vmconfig=$VMCONFIG_FILE $INSTANCE_TYPE_ARG $AMI_ID_ARG --ssh-key-name=$AWS_EC2_SSH_KEY_NAME
+ $INSTANCE_TYPE_ARG $AMI_ID_ARG --ssh-key-name=$AWS_EC2_SSH_KEY_NAME --ssh-key-path=$AWS_EC2_SSH_KEY_FILE
- --ssh-key-path=$AWS_EC2_SSH_KEY_FILE --infra-env=$INFRA_ENV --stack-name=kernel-matrix-testing-${TEST_COMPONENT}-${ARCH}-${CI_PIPELINE_ID}
? -------------------------------------
+ --infra-env=$INFRA_ENV --stack-name=kernel-matrix-testing-${TEST_COMPONENT}-${ARCH}-${CI_PIPELINE_ID}
--run-agent
- jq "." $CI_PROJECT_DIR/stack.output
- pulumi logout
stage: kernel_matrix_testing_prepare
tags:
- arch:amd64
variables:
AMI_ID_ARG: --arm-ami-id=$KERNEL_MATRIX_TESTING_ARM_AMI_ID
ARCH: arm64
AWS_EC2_SSH_KEY_FILE: $CI_PROJECT_DIR/ssh_key
AWS_EC2_SSH_KEY_NAME: datadog-agent-ci
AWS_REGION: us-east-1
EXTERNAL_LINKS_PATH: external_links_$CI_JOB_ID.json
INFRA_ENV: aws/agent-qa
INSTANCE_TYPE: m6gd.metal
INSTANCE_TYPE_ARG: --instance-type-arm=$INSTANCE_TYPE
KITCHEN_EC2_REGION: us-east-1
KITCHEN_EC2_SG_IDS: sg-019917348cb0eb7e7
KITCHEN_EC2_SUBNET: subnet-05d7c6b1b5cfea811
KUBERNETES_MEMORY_LIMIT: 16Gi
KUBERNETES_MEMORY_REQUEST: 12Gi
LibvirtSSHKey: $CI_PROJECT_DIR/libvirt_rsa-arm
PIPELINE_ID: $CI_PIPELINE_ID
RESOURCE_TAGS: instance-type:${INSTANCE_TYPE},arch:${ARCH},test-component:${TEST_COMPONENT},git-branch:${CI_COMMIT_REF_NAME}
STACK_DIR: $CI_PROJECT_DIR/stack.dir
TEAM: ebpf-platform
TEST_COMPONENT: system-probe
VMCONFIG_FILE: ${CI_PROJECT_DIR}/vmconfig-${CI_PIPELINE_ID}-${ARCH}.json kmt_setup_env_sysprobe_x64 kmt_setup_env_sysprobe_x64:
after_script:
- DD_API_KEY=$($CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_API_KEY_ORG2 token)
|| exit $?; export DD_API_KEY
- export AWS_PROFILE=agent-qa-ci
- FILTER_TEAM="Name=tag:team,Values=ebpf-platform"
- FILTER_MANAGED="Name=tag:managed-by,Values=pulumi"
- FILTER_STATE="Name=instance-state-name,Values=running"
- FILTER_PIPELINE="Name=tag:pipeline-id,Values=${CI_PIPELINE_ID}"
- FILTER_ARCH="Name=tag:arch,Values=${ARCH}"
- FILTER_INSTANCE_TYPE="Name=tag:instance-type,Values=${INSTANCE_TYPE}"
- FILTER_TEST_COMPONENT="Name=tag:test-component,Values=${TEST_COMPONENT}"
- QUERY_INSTANCE_IDS='Reservations[*].Instances[*].InstanceId'
- QUERY_PRIVATE_IPS='Reservations[*].Instances[*].PrivateIpAddress'
- mkdir -p $CI_PROJECT_DIR/libvirt/log/$ARCH $CI_PROJECT_DIR/libvirt/xml $CI_PROJECT_DIR/libvirt/qemu
$CI_PROJECT_DIR/libvirt/dnsmasq
- INSTANCE_IP=$(aws ec2 describe-instances --filters $FILTER_TEAM $FILTER_MANAGED
$FILTER_STATE $FILTER_PIPELINE $FILTER_TEST_COMPONENT $FILTER_INSTANCE_TYPE --output
text --query $QUERY_PRIVATE_IPS)
- echo "$ARCH-instance-ip" $INSTANCE_IP
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"sudo virsh list --name | grep -v -E '^$' | xargs -I '{}' sh -c \"sudo virsh dumpxml
'{}' > /tmp/ddvm-xml-'{}'.txt\""
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"sudo virsh list --name | xargs -I '{}' sh -c \"sudo cp /var/log/libvirt/qemu/'{}'.log
/tmp/qemu-ddvm-'{}'.log && sudo chown 1000:1000 /tmp/qemu-ddvm*\""
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"mkdir /tmp/dnsmasq && sudo cp /var/lib/libvirt/dnsmasq/* /tmp/dnsmasq/ && sudo
chown 1000:1000 /tmp/dnsmasq/*"
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/ddvm-*.log"
$CI_PROJECT_DIR/libvirt/log
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/ddvm-xml-*"
$CI_PROJECT_DIR/libvirt/xml
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/qemu-ddvm-*.log"
$CI_PROJECT_DIR/libvirt/qemu
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP:/tmp/dnsmasq/*"
$CI_PROJECT_DIR/libvirt/dnsmasq
- "GO_ARCH=$ARCH\nif [ \"${ARCH}\" == \"x86_64\" ]; then\n GO_ARCH=amd64\nfi\n"
- cd test/new-e2e && GOOS=linux GOARCH="${GO_ARCH}" go build system-probe/vm-metrics/vm-metrics.go
- scp -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE $CI_PROJECT_DIR/test/new-e2e/vm-metrics
"ubuntu@$INSTANCE_IP:/home/ubuntu/vm-metrics"
- ssh -o StrictHostKeyChecking=no -i $AWS_EC2_SSH_KEY_FILE "ubuntu@$INSTANCE_IP"
"/home/ubuntu/vm-metrics -statsd-host=127.0.0.1 -statsd-port=8125 -libvirt-uri=/var/run/libvirt/libvirt-sock-ro
--tag \"arch:${ARCH}\" --tag \"test-component:${TEST_COMPONENT}\" --tag \"ci-pipeline-id:${CI_PIPELINE_ID}\"
--daemon -log-file /home/ubuntu/daemon.log"
- dda inv -- -e kmt.tag-ci-job
artifacts:
paths:
- $CI_PROJECT_DIR/stack.output
- $CI_PROJECT_DIR/libvirt
- $VMCONFIG_FILE
reports:
annotations:
- $EXTERNAL_LINKS_PATH
when: always
before_script:
- DD_API_KEY=$($CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_API_KEY_ORG2 token)
|| exit $?; export DD_API_KEY
- mkdir -p $GOPATH/pkg/mod/cache && tar xJf modcache.tar.xz -C $GOPATH/pkg/mod/cache
|| exit 101
- rm -f modcache.tar.xz
- mkdir -p ~/.aws
- $CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_QA_E2E profile >> ~/.aws/config
|| exit $?
- export AWS_PROFILE=agent-qa-ci
- touch $AWS_EC2_SSH_KEY_FILE && chmod 600 $AWS_EC2_SSH_KEY_FILE
- $CI_PROJECT_DIR/tools/ci/fetch_secret.sh $AGENT_QA_E2E ssh_key > $AWS_EC2_SSH_KEY_FILE
|| exit $?
- echo "" >> $AWS_EC2_SSH_KEY_FILE
- chmod 600 $AWS_EC2_SSH_KEY_FILE
- dda inv -- -e gitlab.generate-ci-visibility-links --output=$EXTERNAL_LINKS_PATH
|| true
image: registry.ddbuild.io/ci/test-infra-definitions/runner$TEST_INFRA_DEFINITIONS_BUILDIMAGES_SUFFIX:$TEST_INFRA_DEFINITIONS_BUILDIMAGES
needs:
- go_deps
- go_tools_deps
rules:
- if: $CI_COMMIT_BRANCH == "main"
- if: $CI_COMMIT_BRANCH =~ /^mq-working-branch-/
when: never
- if: $RUN_KMT_TESTS == 'on'
- changes:
compare_to: $COMPARE_TO_BRANCH
paths:
- cmd/system-probe/**/*
- pkg/collector/corechecks/ebpf/**/*
- pkg/collector/corechecks/servicediscovery/module/*
- pkg/ebpf/**/*
- pkg/network/**/*
- pkg/process/monitor/*
- pkg/util/kernel/**/*
- pkg/dynamicinstrumentation/**/*
- pkg/dyninst/**/*
- pkg/gpu/**/*
- .gitlab/kernel_matrix_testing/system_probe.yml
- .gitlab/kernel_matrix_testing/common.yml
- .gitlab/source_test/ebpf.yml
- test/new-e2e/system-probe/**/*
- test/new-e2e/scenarios/system-probe/**/*
- test/new-e2e/pkg/runner/**/*
- test/new-e2e/pkg/utils/**/*
- test/new-e2e/go.mod
- tasks/system_probe.py
- tasks/kmt.py
- tasks/kernel_matrix_testing/*
script:
- echo "s3://dd-pulumi-state?region=us-east-1&awssdk=v2&profile=$AWS_PROFILE" >
$STACK_DIR
- pulumi login $(cat $STACK_DIR | tr -d '\n')
- dda inv -- -e kmt.gen-config --ci --arch=$ARCH --output-file=$VMCONFIG_FILE --vmconfig-template=$TEST_COMPONENT
--memory=12288
- - dda inv -- -e system-probe.start-microvms --provision-instance --provision-microvms
? ^^^ --------
+ - dda inv -- -e kmt.start-microvms --provision-instance --provision-microvms --vmconfig=$VMCONFIG_FILE
? ^^ ++++++++++++++++++++++++++
- --vmconfig=$VMCONFIG_FILE $INSTANCE_TYPE_ARG $AMI_ID_ARG --ssh-key-name=$AWS_EC2_SSH_KEY_NAME
+ $INSTANCE_TYPE_ARG $AMI_ID_ARG --ssh-key-name=$AWS_EC2_SSH_KEY_NAME --ssh-key-path=$AWS_EC2_SSH_KEY_FILE
- --ssh-key-path=$AWS_EC2_SSH_KEY_FILE --infra-env=$INFRA_ENV --stack-name=kernel-matrix-testing-${TEST_COMPONENT}-${ARCH}-${CI_PIPELINE_ID}
? -------------------------------------
+ --infra-env=$INFRA_ENV --stack-name=kernel-matrix-testing-${TEST_COMPONENT}-${ARCH}-${CI_PIPELINE_ID}
--run-agent
- jq "." $CI_PROJECT_DIR/stack.output
- pulumi logout
stage: kernel_matrix_testing_prepare
tags:
- arch:amd64
variables:
AMI_ID_ARG: --x86-ami-id=$KERNEL_MATRIX_TESTING_X86_AMI_ID
ARCH: x86_64
AWS_EC2_SSH_KEY_FILE: $CI_PROJECT_DIR/ssh_key
AWS_EC2_SSH_KEY_NAME: datadog-agent-ci
AWS_REGION: us-east-1
EXTERNAL_LINKS_PATH: external_links_$CI_JOB_ID.json
INFRA_ENV: aws/agent-qa
INSTANCE_TYPE: m5d.metal
INSTANCE_TYPE_ARG: --instance-type-x86=$INSTANCE_TYPE
KITCHEN_EC2_REGION: us-east-1
KITCHEN_EC2_SG_IDS: sg-019917348cb0eb7e7
KITCHEN_EC2_SUBNET: subnet-05d7c6b1b5cfea811
KUBERNETES_MEMORY_LIMIT: 16Gi
KUBERNETES_MEMORY_REQUEST: 12Gi
LibvirtSSHKey: $CI_PROJECT_DIR/libvirt_rsa-x86
PIPELINE_ID: $CI_PIPELINE_ID
RESOURCE_TAGS: instance-type:${INSTANCE_TYPE},arch:${ARCH},test-component:${TEST_COMPONENT},git-branch:${CI_COMMIT_REF_NAME}
STACK_DIR: $CI_PROJECT_DIR/stack.dir
TEAM: ebpf-platform
TEST_COMPONENT: system-probe
VMCONFIG_FILE: ${CI_PROJECT_DIR}/vmconfig-${CI_PIPELINE_ID}-${ARCH}.json Changes Summary
ℹ️ Diff available in the job log. |
Regression DetectorRegression Detector ResultsMetrics dashboard Baseline: 1b8705a Optimization Goals: ✅ No significant changes detected
|
perf | experiment | goal | Δ mean % | Δ mean % CI | trials | links |
---|---|---|---|---|---|---|
➖ | docker_containers_cpu | % cpu utilization | +2.29 | [-0.70, +5.28] | 1 | Logs |
➖ | uds_dogstatsd_20mb_12k_contexts_20_senders | memory utilization | +1.03 | [+0.95, +1.10] | 1 | Logs |
➖ | otlp_ingest_logs | memory utilization | +0.52 | [+0.39, +0.65] | 1 | Logs |
➖ | otlp_ingest_metrics | memory utilization | +0.32 | [+0.15, +0.49] | 1 | Logs |
➖ | file_to_blackhole_0ms_latency | egress throughput | +0.15 | [-0.47, +0.77] | 1 | Logs |
➖ | file_to_blackhole_0ms_latency_http2 | egress throughput | +0.14 | [-0.40, +0.69] | 1 | Logs |
➖ | file_to_blackhole_300ms_latency | egress throughput | +0.06 | [-0.52, +0.64] | 1 | Logs |
➖ | file_to_blackhole_100ms_latency | egress throughput | +0.03 | [-0.59, +0.65] | 1 | Logs |
➖ | tcp_dd_logs_filter_exclude | ingress throughput | +0.01 | [-0.01, +0.03] | 1 | Logs |
➖ | uds_dogstatsd_to_api | ingress throughput | +0.00 | [-0.27, +0.28] | 1 | Logs |
➖ | docker_containers_memory | memory utilization | +0.00 | [-0.09, +0.09] | 1 | Logs |
➖ | tcp_syslog_to_blackhole | ingress throughput | -0.00 | [-0.06, +0.06] | 1 | Logs |
➖ | file_to_blackhole_1000ms_latency | egress throughput | -0.01 | [-0.61, +0.59] | 1 | Logs |
➖ | file_to_blackhole_500ms_latency | egress throughput | -0.02 | [-0.60, +0.57] | 1 | Logs |
➖ | file_to_blackhole_0ms_latency_http1 | egress throughput | -0.03 | [-0.66, +0.59] | 1 | Logs |
➖ | file_to_blackhole_1000ms_latency_linear_load | egress throughput | -0.04 | [-0.27, +0.20] | 1 | Logs |
➖ | quality_gate_idle_all_features | memory utilization | -0.19 | [-0.30, -0.09] | 1 | Logs bounds checks dashboard |
➖ | ddot_metrics | memory utilization | -0.28 | [-0.40, -0.16] | 1 | Logs |
➖ | ddot_logs | memory utilization | -0.51 | [-0.63, -0.40] | 1 | Logs |
➖ | quality_gate_idle | memory utilization | -0.88 | [-0.96, -0.81] | 1 | Logs bounds checks dashboard |
➖ | uds_dogstatsd_to_api_cpu | % cpu utilization | -1.17 | [-2.04, -0.30] | 1 | Logs |
➖ | quality_gate_logs | % cpu utilization | -2.00 | [-4.75, +0.74] | 1 | Logs bounds checks dashboard |
➖ | file_tree | memory utilization | -2.38 | [-2.56, -2.19] | 1 | Logs |
Bounds Checks: ✅ Passed
perf | experiment | bounds_check_name | replicates_passed | links |
---|---|---|---|---|
✅ | docker_containers_cpu | simple_check_run | 10/10 | |
✅ | docker_containers_memory | memory_usage | 10/10 | |
✅ | docker_containers_memory | simple_check_run | 10/10 | |
✅ | file_to_blackhole_0ms_latency | lost_bytes | 10/10 | |
✅ | file_to_blackhole_0ms_latency | memory_usage | 10/10 | |
✅ | file_to_blackhole_0ms_latency_http1 | lost_bytes | 10/10 | |
✅ | file_to_blackhole_0ms_latency_http1 | memory_usage | 10/10 | |
✅ | file_to_blackhole_0ms_latency_http2 | lost_bytes | 10/10 | |
✅ | file_to_blackhole_0ms_latency_http2 | memory_usage | 10/10 | |
✅ | file_to_blackhole_1000ms_latency | memory_usage | 10/10 | |
✅ | file_to_blackhole_1000ms_latency_linear_load | memory_usage | 10/10 | |
✅ | file_to_blackhole_100ms_latency | lost_bytes | 10/10 | |
✅ | file_to_blackhole_100ms_latency | memory_usage | 10/10 | |
✅ | file_to_blackhole_300ms_latency | lost_bytes | 10/10 | |
✅ | file_to_blackhole_300ms_latency | memory_usage | 10/10 | |
✅ | file_to_blackhole_500ms_latency | lost_bytes | 10/10 | |
✅ | file_to_blackhole_500ms_latency | memory_usage | 10/10 | |
✅ | quality_gate_idle | intake_connections | 10/10 | bounds checks dashboard |
✅ | quality_gate_idle | memory_usage | 10/10 | bounds checks dashboard |
✅ | quality_gate_idle_all_features | intake_connections | 10/10 | bounds checks dashboard |
✅ | quality_gate_idle_all_features | memory_usage | 10/10 | bounds checks dashboard |
✅ | quality_gate_logs | intake_connections | 10/10 | bounds checks dashboard |
✅ | quality_gate_logs | lost_bytes | 10/10 | bounds checks dashboard |
✅ | quality_gate_logs | memory_usage | 10/10 | bounds checks dashboard |
Explanation
Confidence level: 90.00%
Effect size tolerance: |Δ mean %| ≥ 5.00%
Performance changes are noted in the perf column of each table:
- ✅ = significantly better comparison variant performance
- ❌ = significantly worse comparison variant performance
- ➖ = no significant change in performance
A regression test is an A/B test of target performance in a repeatable rig, where "performance" is measured as "comparison variant minus baseline variant" for an optimization goal (e.g., ingress throughput). Due to intrinsic variability in measuring that goal, we can only estimate its mean value for each experiment; we report uncertainty in that value as a 90.00% confidence interval denoted "Δ mean % CI".
For each experiment, we decide whether a change in performance is a "regression" -- a change worth investigating further -- if all of the following criteria are true:
-
Its estimated |Δ mean %| ≥ 5.00%, indicating the change is big enough to merit a closer look.
-
Its 90.00% confidence interval "Δ mean % CI" does not contain zero, indicating that if our statistical model is accurate, there is at least a 90.00% chance there is a difference in performance between baseline and comparison variants.
-
Its configuration does not mark it "erratic".
CI Pass/Fail Decision
✅ Passed. All Quality Gates passed.
- quality_gate_idle_all_features, bounds check memory_usage: 10/10 replicas passed. Gate passed.
- quality_gate_idle_all_features, bounds check intake_connections: 10/10 replicas passed. Gate passed.
- quality_gate_logs, bounds check lost_bytes: 10/10 replicas passed. Gate passed.
- quality_gate_logs, bounds check intake_connections: 10/10 replicas passed. Gate passed.
- quality_gate_logs, bounds check memory_usage: 10/10 replicas passed. Gate passed.
- quality_gate_idle, bounds check intake_connections: 10/10 replicas passed. Gate passed.
- quality_gate_idle, bounds check memory_usage: 10/10 replicas passed. Gate passed.
Static quality checks✅ Please find below the results from static quality gates Successful checksInfo
|
aa33652
to
4b41ea3
Compare
4b41ea3
to
f742812
Compare
What does this PR do?
Fixes a problem with
kmt.launch-stack
where theEnter Password:
prompt was not visible. This was due to nesting of running an invoke command within an invoke task. Replaced with a direct call instead.Motivation
Confusing user experience, thinking the command was hanging.
Describe how you validated your changes
Possible Drawbacks / Trade-offs
Additional Notes