mirror of
https://github.com/juanfont/headscale.git
synced 2025-01-12 04:23:20 -05:00
integration-test: taildrop test refactor
This commit is contained in:
parent
78039f4cea
commit
beb3e9abc2
@ -7,5 +7,5 @@ RUN apt-get update \
|
|||||||
&& curl -fsSL https://pkgs.tailscale.com/stable/ubuntu/focal.gpg | apt-key add - \
|
&& curl -fsSL https://pkgs.tailscale.com/stable/ubuntu/focal.gpg | apt-key add - \
|
||||||
&& curl -fsSL https://pkgs.tailscale.com/stable/ubuntu/focal.list | tee /etc/apt/sources.list.d/tailscale.list \
|
&& curl -fsSL https://pkgs.tailscale.com/stable/ubuntu/focal.list | tee /etc/apt/sources.list.d/tailscale.list \
|
||||||
&& apt-get update \
|
&& apt-get update \
|
||||||
&& apt-get install -y tailscale=${TAILSCALE_VERSION} \
|
&& apt-get install -y tailscale=${TAILSCALE_VERSION} dnsutils \
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
@ -604,74 +604,52 @@ func (s *IntegrationTestSuite) TestTailDrop() {
|
|||||||
for _, scales := range s.namespaces {
|
for _, scales := range s.namespaces {
|
||||||
ips, err := getIPs(scales.tailscales)
|
ips, err := getIPs(scales.tailscales)
|
||||||
assert.Nil(s.T(), err)
|
assert.Nil(s.T(), err)
|
||||||
apiURLs, err := getAPIURLs(scales.tailscales)
|
|
||||||
assert.Nil(s.T(), err)
|
assert.Nil(s.T(), err)
|
||||||
|
|
||||||
|
retry := func(times int, sleepInverval time.Duration, doWork func() error) (err error) {
|
||||||
|
for attempts := 0; attempts < times; attempts++ {
|
||||||
|
err = doWork()
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
time.Sleep(sleepInverval)
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
for hostname, tailscale := range scales.tailscales {
|
for hostname, tailscale := range scales.tailscales {
|
||||||
command := []string{"touch", fmt.Sprintf("/tmp/file_from_%s", hostname)}
|
command := []string{"touch", fmt.Sprintf("/tmp/file_from_%s", hostname)}
|
||||||
_, err := ExecuteCommand(
|
_, err := ExecuteCommand(
|
||||||
&tailscale,
|
&tailscale,
|
||||||
command,
|
command,
|
||||||
[]string{"GOMAXPROCS=32"},
|
[]string{},
|
||||||
)
|
)
|
||||||
assert.Nil(s.T(), err)
|
assert.Nil(s.T(), err)
|
||||||
for peername, ip := range ips {
|
for peername, _ := range ips {
|
||||||
s.T().Run(fmt.Sprintf("%s-%s", hostname, peername), func(t *testing.T) {
|
if peername == hostname {
|
||||||
if peername != hostname {
|
continue
|
||||||
// Under normal circumstances, we should be able to send a file
|
|
||||||
// using `tailscale file cp` - but not in userspace networking mode
|
|
||||||
// So curl!
|
|
||||||
peerAPI, ok := apiURLs[ip]
|
|
||||||
assert.True(t, ok)
|
|
||||||
|
|
||||||
// TODO(juanfont): We still have some issues with the test infrastructure, so
|
|
||||||
// lets run curl multiple times until it works.
|
|
||||||
attempts := 0
|
|
||||||
var err error
|
|
||||||
for {
|
|
||||||
command := []string{
|
|
||||||
"curl",
|
|
||||||
"--retry-connrefused",
|
|
||||||
"--retry-delay",
|
|
||||||
"30",
|
|
||||||
"--retry",
|
|
||||||
"10",
|
|
||||||
"--connect-timeout",
|
|
||||||
"60",
|
|
||||||
"-X",
|
|
||||||
"PUT",
|
|
||||||
"--upload-file",
|
|
||||||
fmt.Sprintf("/tmp/file_from_%s", hostname),
|
|
||||||
fmt.Sprintf(
|
|
||||||
"%s/v0/put/file_from_%s",
|
|
||||||
peerAPI,
|
|
||||||
hostname,
|
|
||||||
),
|
|
||||||
}
|
}
|
||||||
|
s.T().Run(fmt.Sprintf("%s-%s", hostname, peername), func(t *testing.T) {
|
||||||
|
command := []string{
|
||||||
|
"tailscale", "file", "cp",
|
||||||
|
fmt.Sprintf("/tmp/file_from_%s", hostname),
|
||||||
|
fmt.Sprintf("%s:", peername),
|
||||||
|
}
|
||||||
|
retry(10, 1*time.Second, func() error {
|
||||||
fmt.Printf(
|
fmt.Printf(
|
||||||
"Sending file from %s (%s) to %s (%s)\n",
|
"Sending file from %s to %s\n",
|
||||||
hostname,
|
hostname,
|
||||||
ips[hostname],
|
|
||||||
peername,
|
peername,
|
||||||
ip,
|
|
||||||
)
|
)
|
||||||
_, err = ExecuteCommand(
|
_, err := ExecuteCommand(
|
||||||
&tailscale,
|
&tailscale,
|
||||||
command,
|
command,
|
||||||
[]string{"ALL_PROXY=socks5://localhost:1055", "GOMAXPROCS=32"},
|
[]string{},
|
||||||
|
ExecuteCommandTimeout(60*time.Second),
|
||||||
)
|
)
|
||||||
if err == nil {
|
return err
|
||||||
break
|
})
|
||||||
} else {
|
|
||||||
time.Sleep(10 * time.Second)
|
|
||||||
attempts++
|
|
||||||
if attempts > 10 {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
}
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user