From b44ce11d1b8b7011c1019dbede6b91905f92e27b Mon Sep 17 00:00:00 2001 From: Ganesh Vernekar Date: Fri, 30 Mar 2018 11:35:12 +0530 Subject: [PATCH] Added test to check pathPrefix --- web/web.go | 2 +- web/web_test.go | 35 +++++++++++++++++++++++++++++++++++ 2 files changed, 36 insertions(+), 1 deletion(-) diff --git a/web/web.go b/web/web.go index 731850cd99..fe68e62eb5 100644 --- a/web/web.go +++ b/web/web.go @@ -666,7 +666,7 @@ func tmplFuncs(consolesPath string, opts *Options) template_text.FuncMap { return time.Since(t) / time.Millisecond * time.Millisecond }, "consolesPath": func() string { return consolesPath }, - "pathPrefix": func() string { + "pathPrefix": func() string { if opts.RoutePrefix == "/" { return "" } else { diff --git a/web/web_test.go b/web/web_test.go index a9cd7bb02c..e0c209967a 100644 --- a/web/web_test.go +++ b/web/web_test.go @@ -274,6 +274,41 @@ func TestRoutePrefix(t *testing.T) { testutil.Equals(t, http.StatusOK, resp.StatusCode) } +func TestPathPrefix(t *testing.T) { + + tests := []struct { + routePrefix string + pathPrefix string + }{ + { + routePrefix: "/", + // If we have pathPrefix as "/", URL in UI gets "//"" as prefix, + // hence doesn't remain relative path anymore. + pathPrefix: "", + }, + { + routePrefix: "/prometheus", + pathPrefix: "/prometheus", + }, + { + routePrefix: "/p1/p2/p3/p4", + pathPrefix: "/p1/p2/p3/p4", + }, + } + + for _, test := range tests { + opts := &Options{ + RoutePrefix: test.routePrefix, + } + + pathPrefix := tmplFuncs("", opts)["pathPrefix"].(func() string) + pp := pathPrefix() + + testutil.Equals(t, test.pathPrefix, pp) + } + +} + func TestDebugHandler(t *testing.T) { for _, tc := range []struct { prefix, url string