X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/d0f91b34eedec9af266ec4877a3005dd627ad38e..601b2fc51374b4ae678fc515ecabebf33f49fa70:/services/arv-git-httpd/git_handler_test.go diff --git a/services/arv-git-httpd/git_handler_test.go b/services/arv-git-httpd/git_handler_test.go index 35c2f4884f..dafe5d31d7 100644 --- a/services/arv-git-httpd/git_handler_test.go +++ b/services/arv-git-httpd/git_handler_test.go @@ -1,18 +1,37 @@ +// Copyright (C) The Arvados Authors. All rights reserved. +// +// SPDX-License-Identifier: AGPL-3.0 + package main import ( "net/http" "net/http/httptest" "net/url" - "os" "regexp" + "git.arvados.org/arvados.git/lib/config" + "git.arvados.org/arvados.git/sdk/go/arvados" + "git.arvados.org/arvados.git/sdk/go/ctxlog" check "gopkg.in/check.v1" ) var _ = check.Suite(&GitHandlerSuite{}) -type GitHandlerSuite struct{} +type GitHandlerSuite struct { + cluster *arvados.Cluster +} + +func (s *GitHandlerSuite) SetUpTest(c *check.C) { + cfg, err := config.NewLoader(nil, ctxlog.TestLogger(c)).Load() + c.Assert(err, check.Equals, nil) + s.cluster, err = cfg.GetCluster("") + c.Assert(err, check.Equals, nil) + + s.cluster.Services.GitHTTP.InternalURLs = map[arvados.URL]arvados.ServiceInstance{{Host: "localhost:80"}: {}} + s.cluster.Git.GitoliteHome = "/test/ghh" + s.cluster.Git.Repositories = "/" +} func (s *GitHandlerSuite) TestEnvVars(c *check.C) { u, err := url.Parse("git.zzzzz.arvadosapi.com/test") @@ -23,21 +42,20 @@ func (s *GitHandlerSuite) TestEnvVars(c *check.C) { URL: u, RemoteAddr: "[::1]:12345", } - h := newGitHandler() + h := newGitHandler(s.cluster) h.(*gitHandler).Path = "/bin/sh" h.(*gitHandler).Args = []string{"-c", "printf 'Content-Type: text/plain\r\n\r\n'; env"} - os.Setenv("GITOLITE_HTTP_HOME", "/test/ghh") - os.Setenv("GL_BYPASS_ACCESS_CHECKS", "yesplease") h.ServeHTTP(resp, req) c.Check(resp.Code, check.Equals, http.StatusOK) body := resp.Body.String() + c.Check(body, check.Matches, `(?ms).*^PATH=.*:/test/ghh/bin$.*`) c.Check(body, check.Matches, `(?ms).*^GITOLITE_HTTP_HOME=/test/ghh$.*`) - c.Check(body, check.Matches, `(?ms).*^GL_BYPASS_ACCESS_CHECKS=yesplease$.*`) + c.Check(body, check.Matches, `(?ms).*^GL_BYPASS_ACCESS_CHECKS=1$.*`) c.Check(body, check.Matches, `(?ms).*^REMOTE_HOST=::1$.*`) c.Check(body, check.Matches, `(?ms).*^REMOTE_PORT=12345$.*`) - c.Check(body, check.Matches, `(?ms).*^SERVER_ADDR=`+regexp.QuoteMeta(theConfig.Addr)+`$.*`) + c.Check(body, check.Matches, `(?ms).*^SERVER_ADDR=`+regexp.QuoteMeta("localhost:80")+`$.*`) } func (s *GitHandlerSuite) TestCGIErrorOnSplitHostPortError(c *check.C) { @@ -49,7 +67,7 @@ func (s *GitHandlerSuite) TestCGIErrorOnSplitHostPortError(c *check.C) { URL: u, RemoteAddr: "test.bad.address.missing.port", } - h := newGitHandler() + h := newGitHandler(s.cluster) h.ServeHTTP(resp, req) c.Check(resp.Code, check.Equals, http.StatusInternalServerError) c.Check(resp.Body.String(), check.Equals, "")