Skip to content

Commit

Permalink
fix: set default namespace for apis from config
Browse files Browse the repository at this point in the history
Signed-off-by: Enrique Lacal <[email protected]>
  • Loading branch information
EnriqueL8 committed Jul 8, 2024
1 parent 16aec0b commit 2fef8f0
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 0 deletions.
4 changes: 4 additions & 0 deletions internal/apiserver/server.go
Original file line number Diff line number Diff line change
Expand Up @@ -188,7 +188,11 @@ func (as *apiServer) getBaseURL(req *http.Request) string {
vars := mux.Vars(req)
if ns, ok := vars["ns"]; ok && ns != "" {
baseURL += `/namespaces/` + ns
} else if ns := config.GetString(coreconfig.NamespacesDefault); ns != "" {
// Use the default namespace
baseURL += `/namespaces/` + ns
}

return baseURL
}

Expand Down
26 changes: 26 additions & 0 deletions internal/apiserver/server_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -549,3 +549,29 @@ func TestGetNamespacedWebSocketHandlerUnknownNamespace(t *testing.T) {
assert.Error(t, err)
assert.Equal(t, 404, status)
}

func TestContractAPIDefaultNS(t *testing.T) {
mgr, o, as := newTestServer()
r := as.createMuxRouter(context.Background(), mgr)
mcm := &contractmocks.Manager{}
o.On("Contracts").Return(mcm)
mffi := apiservermocks.NewFFISwaggerGen(t)
as.ffiSwaggerGen = mffi
s := httptest.NewServer(r)
defer s.Close()

o.On("Authorize", mock.Anything, mock.Anything).Return(nil)

api := &core.ContractAPI{
Interface: &fftypes.FFIReference{
ID: fftypes.NewUUID(),
},
}

mcm.On("GetContractAPIs", mock.Anything, "http://127.0.0.1:5000/api/v1/namespaces/default", mock.Anything).Return([]*core.ContractAPI{api}, nil, nil)

res, err := resty.New().R().
Get(fmt.Sprintf("http://%s/api/v1/apis", s.Listener.Addr()))
assert.NoError(t, err)
assert.Equal(t, 200, res.StatusCode())
}

0 comments on commit 2fef8f0

Please sign in to comment.