summaryrefslogtreecommitdiff
path: root/client/httpsclient_test.go
diff options
context:
space:
mode:
authorMikhail Mazurskiy <mmazurskiy@gitlab.com>2021-09-09 21:05:25 +1000
committerMikhail Mazurskiy <mmazurskiy@gitlab.com>2021-09-09 21:05:25 +1000
commit44737afce375d68a3c122991f6d94e3a84233dbb (patch)
tree7d5b299ce6bcddcb0bdf33fa24a1c42c5e65e882 /client/httpsclient_test.go
parent5edb579c23a06a2795c199478c88782b25f34d0d (diff)
downloadgitlab-shell-ash2k/use-moved-gitlab-client.tar.gz
Use moved GitLab client from Gitalyash2k/use-moved-gitlab-client
See https://gitlab.com/gitlab-org/gitaly/-/merge_requests/3850
Diffstat (limited to 'client/httpsclient_test.go')
-rw-r--r--client/httpsclient_test.go133
1 files changed, 0 insertions, 133 deletions
diff --git a/client/httpsclient_test.go b/client/httpsclient_test.go
deleted file mode 100644
index d2c2293..0000000
--- a/client/httpsclient_test.go
+++ /dev/null
@@ -1,133 +0,0 @@
-package client
-
-import (
- "context"
- "fmt"
- "io"
- "net/http"
- "path"
- "testing"
-
- "github.com/stretchr/testify/require"
- "gitlab.com/gitlab-org/gitlab-shell/client/testserver"
- "gitlab.com/gitlab-org/gitlab-shell/internal/testhelper"
-)
-
-//go:generate openssl req -newkey rsa:4096 -new -nodes -x509 -days 3650 -out ../internal/testhelper/testdata/testroot/certs/client/server.crt -keyout ../internal/testhelper/testdata/testroot/certs/client/key.pem -subj "/C=US/ST=California/L=San Francisco/O=GitLab/OU=GitLab-Shell/CN=localhost"
-func TestSuccessfulRequests(t *testing.T) {
- testCases := []struct {
- desc string
- caFile, caPath string
- selfSigned bool
- clientCAPath, clientCertPath, clientKeyPath string // used for TLS client certs
- }{
- {
- desc: "Valid CaFile",
- caFile: path.Join(testhelper.TestRoot, "certs/valid/server.crt"),
- },
- {
- desc: "Valid CaPath",
- caPath: path.Join(testhelper.TestRoot, "certs/valid"),
- caFile: path.Join(testhelper.TestRoot, "certs/valid/server.crt"),
- },
- {
- desc: "Invalid cert with self signed cert option enabled",
- caFile: path.Join(testhelper.TestRoot, "certs/valid/server.crt"),
- selfSigned: true,
- },
- {
- desc: "Client certs with CA",
- caFile: path.Join(testhelper.TestRoot, "certs/valid/server.crt"),
- // Run the command "go generate httpsclient_test.go" to
- // regenerate the following test fixtures:
- clientCAPath: path.Join(testhelper.TestRoot, "certs/client/server.crt"),
- clientCertPath: path.Join(testhelper.TestRoot, "certs/client/server.crt"),
- clientKeyPath: path.Join(testhelper.TestRoot, "certs/client/key.pem"),
- },
- }
-
- for _, tc := range testCases {
- t.Run(tc.desc, func(t *testing.T) {
- client, err := setupWithRequests(t, tc.caFile, tc.caPath, tc.clientCAPath, tc.clientCertPath, tc.clientKeyPath, tc.selfSigned)
- require.NoError(t, err)
-
- response, err := client.Get(context.Background(), "/hello")
- require.NoError(t, err)
- require.NotNil(t, response)
-
- defer response.Body.Close()
-
- responseBody, err := io.ReadAll(response.Body)
- require.NoError(t, err)
- require.Equal(t, string(responseBody), "Hello")
- })
- }
-}
-
-func TestFailedRequests(t *testing.T) {
- testCases := []struct {
- desc string
- caFile string
- caPath string
- expectedError string
- }{
- {
- desc: "Invalid CaFile",
- caFile: path.Join(testhelper.TestRoot, "certs/invalid/server.crt"),
- expectedError: "Internal API unreachable",
- },
- {
- desc: "Invalid CaPath",
- caPath: path.Join(testhelper.TestRoot, "certs/invalid"),
- },
- {
- desc: "Empty config",
- },
- }
-
- for _, tc := range testCases {
- t.Run(tc.desc, func(t *testing.T) {
- client, err := setupWithRequests(t, tc.caFile, tc.caPath, "", "", "", false)
- if tc.caFile == "" {
- require.Error(t, err)
- require.ErrorIs(t, err, ErrCafileNotFound)
- } else {
- _, err = client.Get(context.Background(), "/hello")
- require.Error(t, err)
-
- require.Equal(t, err.Error(), tc.expectedError)
- }
- })
- }
-}
-
-func setupWithRequests(t *testing.T, caFile, caPath, clientCAPath, clientCertPath, clientKeyPath string, selfSigned bool) (*GitlabNetClient, error) {
- testhelper.PrepareTestRootDir(t)
-
- requests := []testserver.TestRequestHandler{
- {
- Path: "/api/v4/internal/hello",
- Handler: func(w http.ResponseWriter, r *http.Request) {
- require.Equal(t, http.MethodGet, r.Method)
-
- fmt.Fprint(w, "Hello")
- },
- },
- }
-
- url := testserver.StartHttpsServer(t, requests, clientCAPath)
-
- var opts []HTTPClientOpt
- if clientCertPath != "" && clientKeyPath != "" {
- opts = append(opts, WithClientCert(clientCertPath, clientKeyPath))
- }
-
- httpClient, err := NewHTTPClientWithOpts(url, "", caFile, caPath, selfSigned, 1, opts)
- if err != nil {
- return nil, err
- }
-
- client, err := NewGitlabNetClient("", "", "", httpClient)
-
- return client, err
-}