summaryrefslogtreecommitdiff
path: root/internal/command/uploadpack/gitalycall_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'internal/command/uploadpack/gitalycall_test.go')
-rw-r--r--internal/command/uploadpack/gitalycall_test.go94
1 files changed, 50 insertions, 44 deletions
diff --git a/internal/command/uploadpack/gitalycall_test.go b/internal/command/uploadpack/gitalycall_test.go
index 6b6f009..874d12e 100644
--- a/internal/command/uploadpack/gitalycall_test.go
+++ b/internal/command/uploadpack/gitalycall_test.go
@@ -3,6 +3,7 @@ package uploadpack
import (
"bytes"
"context"
+ "fmt"
"testing"
"github.com/stretchr/testify/require"
@@ -17,60 +18,65 @@ import (
)
func TestUploadPack(t *testing.T) {
- gitalyAddress, testServer := testserver.StartGitalyServer(t)
+ for _, network := range []string{"unix", "tcp", "dns"} {
+ t.Run(fmt.Sprintf("via %s network", network), func(t *testing.T) {
+ gitalyAddress, testServer := testserver.StartGitalyServer(t, network)
+ t.Log(fmt.Sprintf("Server address: %s", gitalyAddress))
- requests := requesthandlers.BuildAllowedWithGitalyHandlers(t, gitalyAddress)
- url := testserver.StartHttpServer(t, requests)
+ requests := requesthandlers.BuildAllowedWithGitalyHandlers(t, gitalyAddress)
+ url := testserver.StartHttpServer(t, requests)
- output := &bytes.Buffer{}
- input := &bytes.Buffer{}
+ output := &bytes.Buffer{}
+ input := &bytes.Buffer{}
- userId := "1"
- repo := "group/repo"
+ userId := "1"
+ repo := "group/repo"
- env := sshenv.Env{
- IsSSHConnection: true,
- OriginalCommand: "git-upload-pack " + repo,
- RemoteAddr: "127.0.0.1",
- }
+ env := sshenv.Env{
+ IsSSHConnection: true,
+ OriginalCommand: "git-upload-pack " + repo,
+ RemoteAddr: "127.0.0.1",
+ }
- args := &commandargs.Shell{
- GitlabKeyId: userId,
- CommandType: commandargs.UploadPack,
- SshArgs: []string{"git-upload-pack", repo},
- Env: env,
- }
+ args := &commandargs.Shell{
+ GitlabKeyId: userId,
+ CommandType: commandargs.UploadPack,
+ SshArgs: []string{"git-upload-pack", repo},
+ Env: env,
+ }
- ctx := correlation.ContextWithCorrelation(context.Background(), "a-correlation-id")
- ctx = correlation.ContextWithClientName(ctx, "gitlab-shell-tests")
+ ctx := correlation.ContextWithCorrelation(context.Background(), "a-correlation-id")
+ ctx = correlation.ContextWithClientName(ctx, "gitlab-shell-tests")
- cfg := &config.Config{GitlabUrl: url}
- cfg.GitalyClient.InitSidechannelRegistry(ctx)
+ cfg := &config.Config{GitlabUrl: url}
+ cfg.GitalyClient.InitSidechannelRegistry(ctx)
- cmd := &Command{
- Config: cfg,
- Args: args,
- ReadWriter: &readwriter.ReadWriter{ErrOut: output, Out: output, In: input},
- }
+ cmd := &Command{
+ Config: cfg,
+ Args: args,
+ ReadWriter: &readwriter.ReadWriter{ErrOut: output, Out: output, In: input},
+ }
- err := cmd.Execute(ctx)
- require.NoError(t, err)
+ err := cmd.Execute(ctx)
+ require.NoError(t, err)
- require.Equal(t, "SSHUploadPackWithSidechannel: "+repo, output.String())
+ require.Equal(t, "SSHUploadPackWithSidechannel: "+repo, output.String())
- for k, v := range map[string]string{
- "gitaly-feature-cache_invalidator": "true",
- "gitaly-feature-inforef_uploadpack_cache": "false",
- "x-gitlab-client-name": "gitlab-shell-tests-git-upload-pack",
- "key_id": "123",
- "user_id": "1",
- "remote_ip": "127.0.0.1",
- "key_type": "key",
- } {
- actual := testServer.ReceivedMD[k]
- require.Len(t, actual, 1)
- require.Equal(t, v, actual[0])
+ for k, v := range map[string]string{
+ "gitaly-feature-cache_invalidator": "true",
+ "gitaly-feature-inforef_uploadpack_cache": "false",
+ "x-gitlab-client-name": "gitlab-shell-tests-git-upload-pack",
+ "key_id": "123",
+ "user_id": "1",
+ "remote_ip": "127.0.0.1",
+ "key_type": "key",
+ } {
+ actual := testServer.ReceivedMD[k]
+ require.Len(t, actual, 1)
+ require.Equal(t, v, actual[0])
+ }
+ require.Empty(t, testServer.ReceivedMD["some-other-ff"])
+ require.Equal(t, testServer.ReceivedMD["x-gitlab-correlation-id"][0], "a-correlation-id")
+ })
}
- require.Empty(t, testServer.ReceivedMD["some-other-ff"])
- require.Equal(t, testServer.ReceivedMD["x-gitlab-correlation-id"][0], "a-correlation-id")
}