Commit 7d5229db authored by Nick Thomas's avatar Nick Thomas

Merge branch 'id-refactor-handlers' into 'master'

Remove handler functions which aren't used

See merge request gitlab-org/gitlab-shell!349
parents 9ed13ca8 67b25d66
...@@ -9,17 +9,10 @@ import ( ...@@ -9,17 +9,10 @@ import (
"gitlab.com/gitlab-org/gitaly/client" "gitlab.com/gitlab-org/gitaly/client"
"gitlab.com/gitlab-org/gitlab-shell/go/internal/config" "gitlab.com/gitlab-org/gitlab-shell/go/internal/config"
"gitlab.com/gitlab-org/gitlab-shell/go/internal/logger"
"gitlab.com/gitlab-org/labkit/tracing" "gitlab.com/gitlab-org/labkit/tracing"
"google.golang.org/grpc" "google.golang.org/grpc"
) )
// GitalyHandlerFuncWithJSON implementations are responsible for deserializing
// the request JSON into a GRPC request message, making an appropriate Gitaly
// call with the request, using the provided client, and returning the exit code
// or error from the Gitaly call.
type GitalyHandlerFuncWithJSON func(ctx context.Context, client *grpc.ClientConn, requestJSON string) (int32, error)
// GitalyHandlerFunc implementations are responsible for making // GitalyHandlerFunc implementations are responsible for making
// an appropriate Gitaly call using the provided client and context // an appropriate Gitaly call using the provided client and context
// and returning an error from the Gitaly call. // and returning an error from the Gitaly call.
...@@ -38,22 +31,6 @@ type GitalyCommand struct { ...@@ -38,22 +31,6 @@ type GitalyCommand struct {
Token string Token string
} }
// RunGitalyCommand provides a bootstrap for Gitaly commands executed
// through GitLab-Shell. It ensures that logging, tracing and other
// common concerns are configured before executing the `handler`.
// RunGitalyCommand will handle errors internally and call
// `os.Exit()` on completion. This method will never return to
// the caller.
func RunGitalyCommand(handler GitalyHandlerFuncWithJSON) {
exitCode, err := internalRunGitalyCommand(os.Args, handler)
if err != nil {
logger.Fatal("error: %v", err)
}
os.Exit(exitCode)
}
// RunGitalyCommand provides a bootstrap for Gitaly commands executed // RunGitalyCommand provides a bootstrap for Gitaly commands executed
// through GitLab-Shell. It ensures that logging, tracing and other // through GitLab-Shell. It ensures that logging, tracing and other
// common concerns are configured before executing the `handler`. // common concerns are configured before executing the `handler`.
...@@ -71,42 +48,6 @@ func (gc *GitalyCommand) RunGitalyCommand(handler GitalyHandlerFunc) error { ...@@ -71,42 +48,6 @@ func (gc *GitalyCommand) RunGitalyCommand(handler GitalyHandlerFunc) error {
return err return err
} }
// internalRunGitalyCommand runs Gitaly's command by particular Gitaly address and token
func internalRunGitalyCommand(args []string, handler GitalyHandlerFuncWithJSON) (int, error) {
if len(args) != 3 {
return 1, fmt.Errorf("expected 2 arguments, got %v", args)
}
cfg, err := config.New()
if err != nil {
return 1, err
}
if err := logger.Configure(cfg); err != nil {
return 1, err
}
gc := &GitalyCommand{
Config: cfg,
ServiceName: args[0],
Address: args[1],
Token: os.Getenv("GITALY_TOKEN"),
}
requestJSON := string(args[2])
gitalyConn, err := getConn(gc)
if err != nil {
return 1, err
}
exitCode, err := handler(gitalyConn.ctx, gitalyConn.conn, requestJSON)
gitalyConn.close()
return int(exitCode), err
}
func getConn(gc *GitalyCommand) (*GitalyConn, error) { func getConn(gc *GitalyCommand) (*GitalyConn, error) {
if gc.Address == "" { if gc.Address == "" {
return nil, fmt.Errorf("no gitaly_address given") return nil, fmt.Errorf("no gitaly_address given")
......
...@@ -2,102 +2,41 @@ package handler ...@@ -2,102 +2,41 @@ package handler
import ( import (
"context" "context"
"fmt" "errors"
"testing" "testing"
"github.com/stretchr/testify/require" "github.com/stretchr/testify/require"
"gitlab.com/gitlab-org/gitlab-shell/go/internal/testhelper"
"google.golang.org/grpc" "google.golang.org/grpc"
"gitlab.com/gitlab-org/gitlab-shell/go/internal/config"
) )
func TestInteralRunHandler(t *testing.T) { func makeHandler(t *testing.T, err error) func(context.Context, *grpc.ClientConn) (int32, error) {
type testCase struct { return func(ctx context.Context, client *grpc.ClientConn) (int32, error) {
name string require.NotNil(t, ctx)
args []string require.NotNil(t, client)
handler func(context.Context, *grpc.ClientConn, string) (int32, error)
want int
wantErr bool
}
var currentTest *testCase return 0, err
makeHandler := func(r1 int32, r2 error) func(context.Context, *grpc.ClientConn, string) (int32, error) {
return func(ctx context.Context, client *grpc.ClientConn, requestJSON string) (int32, error) {
require.NotNil(t, ctx)
require.NotNil(t, client)
require.Equal(t, currentTest.args[2], requestJSON)
return r1, r2
}
} }
tests := []testCase{ }
{
name: "expected", func TestRunGitalyCommand(t *testing.T) {
args: []string{"test", "tcp://localhost:9999", "{}"}, cmd := GitalyCommand{
handler: makeHandler(0, nil), Config: &config.Config{},
want: 0, Address: "tcp://localhost:9999",
wantErr: false,
},
{
name: "handler_error",
args: []string{"test", "tcp://localhost:9999", "{}"},
handler: makeHandler(0, fmt.Errorf("error")),
want: 0,
wantErr: true,
},
{
name: "handler_exitcode",
args: []string{"test", "tcp://localhost:9999", "{}"},
handler: makeHandler(1, nil),
want: 1,
wantErr: false,
},
{
name: "handler_error_exitcode",
args: []string{"test", "tcp://localhost:9999", "{}"},
handler: makeHandler(1, fmt.Errorf("error")),
want: 1,
wantErr: true,
},
{
name: "too_few_arguments",
args: []string{"test"},
handler: makeHandler(10, nil),
want: 1,
wantErr: true,
},
{
name: "too_many_arguments",
args: []string{"test", "1", "2", "3"},
handler: makeHandler(10, nil),
want: 1,
wantErr: true,
},
{
name: "empty_gitaly_address",
args: []string{"test", "", "{}"},
handler: makeHandler(10, nil),
want: 1,
wantErr: true,
},
} }
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
currentTest = &tt
defer func() {
currentTest = nil
}()
done, err := testhelper.PrepareTestRootDir() err := cmd.RunGitalyCommand(makeHandler(t, nil))
defer done() require.NoError(t, err)
require.NoError(t, err)
got, err := internalRunGitalyCommand(tt.args, tt.handler) expectedErr := errors.New("error")
if tt.wantErr { err = cmd.RunGitalyCommand(makeHandler(t, expectedErr))
require.Error(t, err) require.Equal(t, err, expectedErr)
} else { }
require.NoError(t, err)
}
require.Equal(t, tt.want, got) func TestMissingGitalyAddress(t *testing.T) {
}) cmd := GitalyCommand{Config: &config.Config{}}
}
err := cmd.RunGitalyCommand(makeHandler(t, nil))
require.EqualError(t, err, "no gitaly_address given")
} }
package handler
import (
"context"
"os"
"gitlab.com/gitlab-org/gitaly/client"
pb "gitlab.com/gitlab-org/gitaly/proto/go/gitalypb"
"google.golang.org/grpc"
)
// ReceivePack issues a Gitaly receive-pack rpc to the provided address
func ReceivePack(ctx context.Context, conn *grpc.ClientConn, request *pb.SSHReceivePackRequest) (int32, error) {
ctx, cancel := context.WithCancel(ctx)
defer cancel()
return client.ReceivePack(ctx, conn, os.Stdin, os.Stdout, os.Stderr, request)
}
package handler
import (
"context"
"os"
"gitlab.com/gitlab-org/gitaly/client"
pb "gitlab.com/gitlab-org/gitaly/proto/go/gitalypb"
"google.golang.org/grpc"
)
// UploadArchive issues a Gitaly upload-archive rpc to the provided address
func UploadArchive(ctx context.Context, conn *grpc.ClientConn, request *pb.SSHUploadArchiveRequest) (int32, error) {
ctx, cancel := context.WithCancel(ctx)
defer cancel()
return client.UploadArchive(ctx, conn, os.Stdin, os.Stdout, os.Stderr, request)
}
package handler
import (
"context"
"os"
"gitlab.com/gitlab-org/gitaly/client"
pb "gitlab.com/gitlab-org/gitaly/proto/go/gitalypb"
"google.golang.org/grpc"
)
// UploadPack issues a Gitaly upload-pack rpc to the provided address
func UploadPack(ctx context.Context, conn *grpc.ClientConn, request *pb.SSHUploadPackRequest) (int32, error) {
ctx, cancel := context.WithCancel(ctx)
defer cancel()
return client.UploadPack(ctx, conn, os.Stdin, os.Stdout, os.Stderr, request)
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment