Skip to content

Commit

Permalink
[E2E] Retry Agent MSI download (DataDog#29352)
Browse files Browse the repository at this point in the history
  • Loading branch information
clarkb7 authored Sep 25, 2024
1 parent 87c9fa0 commit c5bcbc1
Show file tree
Hide file tree
Showing 8 changed files with 51 additions and 26 deletions.
2 changes: 1 addition & 1 deletion test/new-e2e/go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -105,7 +105,7 @@ require (
github.com/aws/smithy-go v1.20.4 // indirect
github.com/aymanbagabas/go-osc52/v2 v2.0.1 // indirect
github.com/blang/semver v3.5.1+incompatible // indirect
github.com/cenkalti/backoff/v4 v4.3.0 // indirect
github.com/cenkalti/backoff/v4 v4.3.0
github.com/chai2010/gettext-go v1.0.2 // indirect
github.com/charmbracelet/bubbles v0.18.0 // indirect
github.com/charmbracelet/bubbletea v0.25.0 // indirect
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,6 @@ import (
"github.com/DataDog/datadog-agent/test/new-e2e/pkg/environments"
awshost "github.com/DataDog/datadog-agent/test/new-e2e/pkg/environments/aws/host"
"github.com/DataDog/datadog-agent/test/new-e2e/tests/windows"
windowsCommon "github.com/DataDog/datadog-agent/test/new-e2e/tests/windows/common"
windowsAgent "github.com/DataDog/datadog-agent/test/new-e2e/tests/windows/common/agent"
)

Expand Down Expand Up @@ -76,13 +75,7 @@ func (v *vmSuite) TestSystemProbeCWSSuite() {
// install the agent (just so we can get the driver(s) installed)
agentPackage, err := windowsAgent.GetPackageFromEnv()
require.NoError(t, err)
remoteMSIPath, err := windowsCommon.GetTemporaryFile(vm)
require.NoError(t, err)
t.Logf("Getting install package %s...", agentPackage.URL)
err = windowsCommon.PutOrDownloadFile(vm, agentPackage.URL, remoteMSIPath)
require.NoError(t, err)

err = windowsCommon.InstallMSI(vm, remoteMSIPath, "", "")
_, err = windowsAgent.InstallAgent(vm, windowsAgent.WithPackage(agentPackage))
t.Log("Install complete")
require.NoError(t, err)

Expand Down
9 changes: 1 addition & 8 deletions test/new-e2e/tests/sysprobe-functional/sysprobe_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@ import (
"github.com/DataDog/datadog-agent/test/new-e2e/pkg/environments"
awshost "github.com/DataDog/datadog-agent/test/new-e2e/pkg/environments/aws/host"
"github.com/DataDog/datadog-agent/test/new-e2e/tests/windows"
windowsCommon "github.com/DataDog/datadog-agent/test/new-e2e/tests/windows/common"
windowsAgent "github.com/DataDog/datadog-agent/test/new-e2e/tests/windows/common/agent"
componentsos "github.com/DataDog/test-infra-definitions/components/os"
"github.com/DataDog/test-infra-definitions/scenarios/aws/ec2"
Expand Down Expand Up @@ -106,13 +105,7 @@ func (v *vmSuite) TestSystemProbeNPMSuite() {
// install the agent (just so we can get the driver(s) installed)
agentPackage, err := windowsAgent.GetPackageFromEnv()
require.NoError(t, err)
remoteMSIPath, err := windowsCommon.GetTemporaryFile(vm)
require.NoError(t, err)
t.Logf("Getting install package %s...", agentPackage.URL)
err = windowsCommon.PutOrDownloadFile(vm, agentPackage.URL, remoteMSIPath)
require.NoError(t, err)

err = windowsCommon.InstallMSI(vm, remoteMSIPath, "", "")
_, err = windowsAgent.InstallAgent(vm, windowsAgent.WithPackage(agentPackage))
t.Log("Install complete")
require.NoError(t, err)

Expand Down
14 changes: 13 additions & 1 deletion test/new-e2e/tests/windows/common/agent/agent.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import (
"path/filepath"
"strings"
"testing"
"time"

"github.com/DataDog/datadog-agent/pkg/version"
"github.com/DataDog/datadog-agent/test/new-e2e/pkg/components"
Expand All @@ -20,6 +21,7 @@ import (
windowsCommon "github.com/DataDog/datadog-agent/test/new-e2e/tests/windows/common"
infraCommon "github.com/DataDog/test-infra-definitions/common"

"github.com/cenkalti/backoff/v4"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
Expand Down Expand Up @@ -72,13 +74,23 @@ func InstallAgent(host *components.RemoteHost, options ...InstallAgentOption) (s
p.LocalInstallLogFile = filepath.Join(os.TempDir(), "install.log")
}

downloadBackOff := p.DownloadMSIBackOff
if downloadBackOff == nil {
// 5s, 7s, 11s, 17s, 25s, 38s, 60s, 60s...for up to 5 minutes
downloadBackOff = backoff.NewExponentialBackOff(
backoff.WithInitialInterval(5*time.Second),
backoff.WithMaxInterval(60*time.Second),
backoff.WithMaxElapsedTime(5*time.Minute),
)
}

args := p.toArgs()

remoteMSIPath, err := windowsCommon.GetTemporaryFile(host)
if err != nil {
return "", err
}
err = windowsCommon.PutOrDownloadFile(host, p.Package.URL, remoteMSIPath)
err = windowsCommon.PutOrDownloadFileWithRetry(host, p.Package.URL, remoteMSIPath, downloadBackOff)
if err != nil {
return "", err
}
Expand Down
14 changes: 13 additions & 1 deletion test/new-e2e/tests/windows/common/agent/agent_install_params.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,11 +13,15 @@ import (
"github.com/DataDog/datadog-agent/test/new-e2e/pkg/runner"
"github.com/DataDog/datadog-agent/test/new-e2e/pkg/runner/parameters"
"github.com/DataDog/test-infra-definitions/components/datadog/agentparams/msi"

"github.com/cenkalti/backoff/v4"
)

// InstallAgentParams are the parameters used for installing the Agent using msiexec.
type InstallAgentParams struct {
Package *Package
Package *Package
DownloadMSIBackOff backoff.BackOff

// Path on local test runner to save the MSI install log
LocalInstallLogFile string

Expand Down Expand Up @@ -146,6 +150,14 @@ func WithLastStablePackage() InstallAgentOption {
}
}

// WithDownloadMSIBackoff specifies the backoff strategy for downloading the MSI.
func WithDownloadMSIBackoff(backoff backoff.BackOff) InstallAgentOption {
return func(i *InstallAgentParams) error {
i.DownloadMSIBackOff = backoff
return nil
}
}

// WithFakeIntake configures the Agent to use a fake intake URL.
func WithFakeIntake(fakeIntake *components.FakeIntake) InstallAgentOption {
return func(i *InstallAgentParams) error {
Expand Down
23 changes: 22 additions & 1 deletion test/new-e2e/tests/windows/common/network.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ import (
"strings"

"github.com/DataDog/datadog-agent/test/new-e2e/pkg/components"

"github.com/cenkalti/backoff/v4"
)

// BoundPort represents a port that is bound to a process
Expand Down Expand Up @@ -80,8 +82,27 @@ func ListBoundPorts(host *components.RemoteHost) ([]*BoundPort, error) {
// If the URL is a local file, it will be uploaded to the VM.
// If the URL is a remote file, it will be downloaded from the VM
func PutOrDownloadFile(host *components.RemoteHost, url string, destination string) error {
// no retry
return PutOrDownloadFileWithRetry(host, url, destination, &backoff.StopBackOff{})
}

// PutOrDownloadFileWithRetry is similar to PutOrDownloadFile but retries on download failure,
// local file copy is not retried.
func PutOrDownloadFileWithRetry(host *components.RemoteHost, url string, destination string, b backoff.BackOff) error {
if strings.HasPrefix(url, "http://") || strings.HasPrefix(url, "https://") {
return DownloadFile(host, url, destination)
err := backoff.Retry(func() error {
return DownloadFile(host, url, destination)
// TODO: it would be neat to only retry on web related errors but
// we don't have a way to distinguish them since DownloadFile
// throws a WebException for non web related errors such as
// filename is null or Empty.
// https://learn.microsoft.com/en-us/dotnet/api/system.net.webclient.downloadfile
// example error: Exception calling "DownloadFile" with "2" argument(s): "The remote server returned an error: (503)
}, b)
if err != nil {
return err
}
return nil
}

if strings.HasPrefix(url, "file://") {
Expand Down
3 changes: 0 additions & 3 deletions test/new-e2e/tests/windows/install-test/npm_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@ import (
"path/filepath"
"time"

"github.com/DataDog/datadog-agent/pkg/util/testutil/flake"
"github.com/DataDog/datadog-agent/test/new-e2e/pkg/components"
windowsCommon "github.com/DataDog/datadog-agent/test/new-e2e/tests/windows/common"
windowsAgent "github.com/DataDog/datadog-agent/test/new-e2e/tests/windows/common/agent"
Expand Down Expand Up @@ -111,8 +110,6 @@ func (s *testNPMInstallWithAddLocalSuite) TestNPMInstallWithAddLocal() {
//
// Old name: Scenario 10
func TestNPMUpgradeFromBeta(t *testing.T) {
// incident-30584
flake.Mark(t)
s := &testNPMUpgradeFromBeta{}
s.previousVersion = "7.23.2-beta1-1"
s.url = "https://ddagent-windows-unstable.s3.amazonaws.com/datadog-agent-7.23.2-beta1-1-x86_64.msi"
Expand Down
3 changes: 0 additions & 3 deletions test/new-e2e/tests/windows/install-test/upgrade_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@ import (
"slices"
"strings"

"github.com/DataDog/datadog-agent/pkg/util/testutil/flake"
windowsCommon "github.com/DataDog/datadog-agent/test/new-e2e/tests/windows/common"
windowsAgent "github.com/DataDog/datadog-agent/test/new-e2e/tests/windows/common/agent"
servicetest "github.com/DataDog/datadog-agent/test/new-e2e/tests/windows/install-test/service-test"
Expand All @@ -24,8 +23,6 @@ import (

// TestUpgrade tests upgrading the agent from LAST_STABLE_VERSION to WINDOWS_AGENT_VERSION
func TestUpgrade(t *testing.T) {
// incident-30584
flake.Mark(t)
s := &testUpgradeSuite{}
previousAgentPackage, err := windowsAgent.GetLastStablePackageFromEnv()
require.NoError(t, err, "should get last stable agent package from env")
Expand Down

0 comments on commit c5bcbc1

Please sign in to comment.