mirror of
https://github.com/coder/coder.git
synced 2025-07-06 15:41:45 +00:00
Connections could fail when massive payloads were transmitted. This fixes an upstream bug in dRPC where the connection would end with a context canceled if a message was too large. This adds retransmission of completion and failures too. If Coder somehow loses connection with a provisioner daemon, upon the next connection the state will be properly reported.
49 lines
1.3 KiB
Go
49 lines
1.3 KiB
Go
package coderd_test
|
|
|
|
import (
|
|
"context"
|
|
"crypto/rand"
|
|
"runtime"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/coder/coder/coderd/coderdtest"
|
|
"github.com/coder/coder/coderd/database"
|
|
"github.com/coder/coder/codersdk"
|
|
"github.com/coder/coder/provisionersdk"
|
|
)
|
|
|
|
func TestProvisionerDaemons(t *testing.T) {
|
|
t.Parallel()
|
|
t.Run("PayloadTooBig", func(t *testing.T) {
|
|
t.Parallel()
|
|
if runtime.GOOS == "windows" {
|
|
// Takes too long to allocate memory on Windows!
|
|
t.Skip()
|
|
}
|
|
client := coderdtest.New(t, nil)
|
|
user := coderdtest.CreateFirstUser(t, client)
|
|
coderdtest.NewProvisionerDaemon(t, client)
|
|
data := make([]byte, provisionersdk.MaxMessageSize)
|
|
rand.Read(data)
|
|
resp, err := client.Upload(context.Background(), codersdk.ContentTypeTar, data)
|
|
require.NoError(t, err)
|
|
t.Log(resp.Hash)
|
|
|
|
version, err := client.CreateTemplateVersion(context.Background(), user.OrganizationID, codersdk.CreateTemplateVersionRequest{
|
|
StorageMethod: database.ProvisionerStorageMethodFile,
|
|
StorageSource: resp.Hash,
|
|
Provisioner: database.ProvisionerTypeEcho,
|
|
})
|
|
require.NoError(t, err)
|
|
require.Eventually(t, func() bool {
|
|
var err error
|
|
version, err = client.TemplateVersion(context.Background(), version.ID)
|
|
require.NoError(t, err)
|
|
return version.Job.Error != ""
|
|
}, 5*time.Second, 25*time.Millisecond)
|
|
})
|
|
}
|