X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/c371555926e3f361497b2bb1c9531fcaf7283ed4..2f66d4cc05e9442a9bb69969744d0750a02a1ed4:/lib/controller/federation/login_test.go diff --git a/lib/controller/federation/login_test.go b/lib/controller/federation/login_test.go index 8ec2bd5a49..1d6e12e015 100644 --- a/lib/controller/federation/login_test.go +++ b/lib/controller/federation/login_test.go @@ -8,8 +8,9 @@ import ( "context" "net/url" - "git.curoverse.com/arvados.git/sdk/go/arvados" - "git.curoverse.com/arvados.git/sdk/go/arvadostest" + "git.arvados.org/arvados.git/sdk/go/arvados" + "git.arvados.org/arvados.git/sdk/go/arvadostest" + "git.arvados.org/arvados.git/sdk/go/auth" check "gopkg.in/check.v1" ) @@ -38,3 +39,36 @@ func (s *LoginSuite) TestDeferToLoginCluster(c *check.C) { c.Check(remotePresent, check.Equals, remote != "") } } + +func (s *LoginSuite) TestLogout(c *check.C) { + s.cluster.Services.Workbench1.ExternalURL = arvados.URL{Scheme: "https", Host: "workbench1.example.com"} + s.cluster.Services.Workbench2.ExternalURL = arvados.URL{Scheme: "https", Host: "workbench2.example.com"} + s.cluster.Login.GoogleClientID = "zzzzzzzzzzzzzz" + s.addHTTPRemote(c, "zhome", &arvadostest.APIStub{}) + s.cluster.Login.LoginCluster = "zhome" + + returnTo := "https://app.example.com/foo?bar" + for _, trial := range []struct { + token string + returnTo string + target string + }{ + {token: "", returnTo: "", target: s.cluster.Services.Workbench2.ExternalURL.String()}, + {token: "", returnTo: returnTo, target: returnTo}, + {token: "zzzzzzzzzzzzzzzzzzzzz", returnTo: returnTo, target: returnTo}, + {token: "v2/zzzzz-aaaaa-aaaaaaaaaaaaaaa/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaa", returnTo: returnTo, target: returnTo}, + {token: "v2/zhome-aaaaa-aaaaaaaaaaaaaaa/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaa", returnTo: returnTo, target: "http://" + s.cluster.RemoteClusters["zhome"].Host + "/logout?" + url.Values{"return_to": {returnTo}}.Encode()}, + } { + c.Logf("trial %#v", trial) + ctx := context.Background() + if trial.token != "" { + ctx = auth.NewContext(ctx, &auth.Credentials{Tokens: []string{trial.token}}) + } + resp, err := s.fed.Logout(ctx, arvados.LogoutOptions{ReturnTo: trial.returnTo}) + c.Assert(err, check.IsNil) + c.Logf(" RedirectLocation %q", resp.RedirectLocation) + target, err := url.Parse(resp.RedirectLocation) + c.Check(err, check.IsNil) + c.Check(target.String(), check.Equals, trial.target) + } +}