-
Notifications
You must be signed in to change notification settings - Fork 698
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Feat: Tests cases for Chaoscenter Rest handler in Chaoscenter (#4238)
* feat: Tests cases for rest handlers Signed-off-by: freedisch <[email protected]> * fixed failing tests and updated mock service Signed-off-by: freedisch <[email protected]> * added test cases Signed-off-by: freedisch <[email protected]> * fixed failling and added more negatives test cases Signed-off-by: freedisch <[email protected]> --------- Signed-off-by: freedisch <[email protected]> Signed-off-by: Magnim BATALE <[email protected]> Co-authored-by: Namkyu Park <[email protected]> Co-authored-by: Saranya Jena <[email protected]>
- Loading branch information
1 parent
bb44094
commit faa3627
Showing
5 changed files
with
992 additions
and
4 deletions.
There are no files selected for viewing
18 changes: 18 additions & 0 deletions
18
chaoscenter/authentication/api/handlers/rest/dex_auth_handler_test.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
package rest_test | ||
|
||
import ( | ||
"net/http/httptest" | ||
"testing" | ||
|
||
"github.com/litmuschaos/litmus/chaoscenter/authentication/api/handlers/rest" | ||
"github.com/stretchr/testify/assert" | ||
) | ||
|
||
func TestDexLogin(t *testing.T) { | ||
w := httptest.NewRecorder() | ||
ctx := GetTestGinContext(w) | ||
|
||
rest.DexLogin()(ctx) | ||
|
||
assert.Equal(t, 500, w.Code) | ||
} |
63 changes: 63 additions & 0 deletions
63
chaoscenter/authentication/api/handlers/rest/misc_handlers_test.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
package rest_test | ||
|
||
import ( | ||
"errors" | ||
"net/http" | ||
"net/http/httptest" | ||
"testing" | ||
|
||
"github.com/litmuschaos/litmus/chaoscenter/authentication/api/handlers/rest" | ||
"github.com/litmuschaos/litmus/chaoscenter/authentication/api/mocks" | ||
"github.com/litmuschaos/litmus/chaoscenter/authentication/pkg/entities" | ||
"github.com/stretchr/testify/assert" | ||
) | ||
|
||
func TestStatus(t *testing.T) { | ||
|
||
t.Run("Success with valid data", func(t *testing.T) { | ||
w := httptest.NewRecorder() | ||
ctx := GetTestGinContext(w) | ||
users := []entities.User{} | ||
mockService := new(mocks.MockedApplicationService) | ||
mockService.On("GetUsers").Return(&users, nil) | ||
rest.Status(mockService)(ctx) | ||
assert.Equal(t, http.StatusOK, w.Code) | ||
}) | ||
|
||
t.Run("Failed with invalid request", func(t *testing.T) { | ||
w := httptest.NewRecorder() | ||
ctx := GetTestGinContext(w) | ||
users := []entities.User{} | ||
mockService := new(mocks.MockedApplicationService) | ||
mockService.On("GetUsers").Return(&users, errors.New("Failed")) | ||
rest.Status(mockService)(ctx) | ||
assert.Equal(t, http.StatusInternalServerError, w.Code) | ||
}) | ||
|
||
} | ||
|
||
func TestReadiness(t *testing.T) { | ||
t.Run("Success with valid data", func(t *testing.T) { | ||
mockService := new(mocks.MockedApplicationService) | ||
|
||
mockService.On("ListDataBase").Return([]string{"auth", "otherDB"}, nil) | ||
mockService.On("ListCollection").Return([]string{"project", "users", "otherCollection"}, nil) | ||
|
||
w := httptest.NewRecorder() | ||
ctx := GetTestGinContext(w) | ||
rest.Readiness(mockService)(ctx) | ||
assert.Equal(t, http.StatusOK, w.Code) | ||
}) | ||
|
||
t.Run("Failed with invalid data", func(t *testing.T) { | ||
mockService := new(mocks.MockedApplicationService) | ||
|
||
mockService.On("ListDataBase").Return([]string{"auth", "otherDB"}, errors.New("Failed")) | ||
mockService.On("ListCollection").Return([]string{"project", "users", "otherCollection"}, errors.New("Failed")) | ||
|
||
w := httptest.NewRecorder() | ||
ctx := GetTestGinContext(w) | ||
rest.Readiness(mockService)(ctx) | ||
assert.Equal(t, http.StatusInternalServerError, w.Code) | ||
}) | ||
} |
198 changes: 198 additions & 0 deletions
198
chaoscenter/authentication/api/handlers/rest/project_handler_test.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,198 @@ | ||
package rest_test | ||
|
||
import ( | ||
"errors" | ||
"net/http" | ||
"net/http/httptest" | ||
"testing" | ||
|
||
"github.com/gin-gonic/gin" | ||
"github.com/litmuschaos/litmus/chaoscenter/authentication/api/handlers/rest" | ||
"github.com/litmuschaos/litmus/chaoscenter/authentication/api/mocks" | ||
"github.com/litmuschaos/litmus/chaoscenter/authentication/pkg/entities" | ||
"github.com/litmuschaos/litmus/chaoscenter/authentication/pkg/utils" | ||
"github.com/stretchr/testify/assert" | ||
"go.mongodb.org/mongo-driver/bson/primitive" | ||
) | ||
|
||
func TestGetUserWithProject(t *testing.T) { | ||
gin.SetMode(gin.TestMode) | ||
|
||
t.Run("Failed to retrieve user with projects", func(t *testing.T) { | ||
service := new(mocks.MockedApplicationService) | ||
username := "testUser" | ||
w := httptest.NewRecorder() | ||
c := GetTestGinContext(w) | ||
c.Params = gin.Params{ | ||
{"username", username}, | ||
} | ||
c.Set("username", username) | ||
|
||
user := &entities.User{ | ||
ID: "testUID", | ||
Username: "testUser", | ||
Email: "[email protected]", | ||
} | ||
project := &entities.Project{} | ||
|
||
service.On("FindUserByUsername", "testUser").Return(user, errors.New("failed")) | ||
service.On("GetProjectsByUserID", "testUID", false).Return([]*entities.Project{project}, errors.New("failed")) | ||
|
||
rest.GetUserWithProject(service)(c) | ||
|
||
assert.Equal(t, http.StatusBadRequest, w.Code) | ||
}) | ||
|
||
t.Run("Successfully retrieve user with projects", func(t *testing.T) { | ||
service := new(mocks.MockedApplicationService) | ||
username := "testUser1" | ||
f := httptest.NewRecorder() | ||
c := GetTestGinContext(f) | ||
c.Params = gin.Params{ | ||
{"username", username}, | ||
} | ||
c.Set("username", username) | ||
|
||
user := &entities.User{ | ||
ID: "testUID", | ||
Username: "testUser1", | ||
Email: "[email protected]", | ||
} | ||
project := &entities.Project{} | ||
|
||
service.On("FindUserByUsername", "testUser1").Return(user, nil) | ||
service.On("GetProjectsByUserID", "testUID", false).Return([]*entities.Project{project}, nil) | ||
|
||
rest.GetUserWithProject(service)(c) | ||
|
||
assert.Equal(t, http.StatusOK, f.Code) | ||
}) | ||
|
||
} | ||
|
||
func TestGetProjectsByUserID(t *testing.T) { | ||
gin.SetMode(gin.TestMode) | ||
|
||
t.Run("Failed with invalid data", func(t *testing.T) { | ||
|
||
w := httptest.NewRecorder() | ||
ctx := GetTestGinContext(w) | ||
ctx.Set("uid", "testUserID") | ||
projects := []*entities.Project{ | ||
{ | ||
ID: "testProjectID", | ||
Name: "Test Project", | ||
}, | ||
} | ||
service := new(mocks.MockedApplicationService) | ||
service.On("GetProjectsByUserID", "testUserID", false).Return(projects, errors.New("Failed")) | ||
rest.GetProjectsByUserID(service)(ctx) | ||
assert.Equal(t, utils.ErrorStatusCodes[utils.ErrServerError], w.Code) | ||
}) | ||
|
||
t.Run("Successful retrieve of project", func(t *testing.T) { | ||
|
||
w := httptest.NewRecorder() | ||
ctx := GetTestGinContext(w) | ||
ctx.Set("uid", "testUserID") | ||
projects := []*entities.Project{ | ||
{ | ||
ID: "testProjectID", | ||
Name: "Test Project", | ||
}, | ||
} | ||
service := new(mocks.MockedApplicationService) | ||
service.On("GetProjectsByUserID", "testUserID", false).Return(projects, nil) | ||
rest.GetProjectsByUserID(service)(ctx) | ||
assert.Equal(t, http.StatusOK, w.Code) | ||
}) | ||
|
||
} | ||
|
||
func TestGetProject(t *testing.T) { | ||
gin.SetMode(gin.TestMode) | ||
t.Run("unauthorized request to Project", func(t *testing.T) { | ||
projectID := "testUserID" | ||
w := httptest.NewRecorder() | ||
ctx := GetTestGinContext(w) | ||
ctx.Set("uid", projectID) | ||
service := new(mocks.MockedApplicationService) | ||
project := &entities.Project{ | ||
ID: "testProjectID", | ||
Name: "Test Project", | ||
} | ||
user := &entities.User{ | ||
ID: "testProjectID", | ||
Name: "Test Project", | ||
} | ||
|
||
service.On("GetProjectByProjectID", projectID).Return(project, errors.New("Failed")) | ||
service.On("GetUser", projectID).Return(user, errors.New("Failed")) | ||
rest.GetProject(service)(ctx) | ||
|
||
assert.Equal(t, utils.ErrorStatusCodes[utils.ErrUnauthorized], w.Code) | ||
}) | ||
|
||
t.Run("Successful to find Project", func(t *testing.T) { | ||
projectID := "testUserID" | ||
w := httptest.NewRecorder() | ||
ctx := GetTestGinContext(w) | ||
ctx.Set("uid", projectID) | ||
service := new(mocks.MockedApplicationService) | ||
project := &entities.Project{ | ||
ID: "testProjectID", | ||
Name: "Test Project", | ||
} | ||
user := &entities.User{ | ||
ID: "testUserID", | ||
Name: "Test User", | ||
} | ||
projects := []*entities.Project{ | ||
{ | ||
ID: "testProjectID", | ||
Name: "Test Project", | ||
}, | ||
} | ||
expectedFilter := primitive.D{ | ||
primitive.E{ | ||
Key: "_id", | ||
Value: "", | ||
}, | ||
primitive.E{ | ||
Key: "members", | ||
Value: primitive.D{ | ||
primitive.E{ | ||
Key: "$elemMatch", | ||
Value: primitive.D{ | ||
primitive.E{ | ||
Key: "user_id", | ||
Value: "testUserID", | ||
}, | ||
primitive.E{ | ||
Key: "role", | ||
Value: primitive.D{ | ||
primitive.E{ | ||
Key: "$in", | ||
Value: []string{"Owner", "Viewer", "Editor"}, | ||
}, | ||
}, | ||
}, | ||
primitive.E{ | ||
Key: "invitation", | ||
Value: "Accepted", | ||
}, | ||
}, | ||
}, | ||
}, | ||
}, | ||
} | ||
|
||
service.On("GetProjectByProjectID", "").Return(project, nil) | ||
service.On("GetUser", projectID).Return(user, nil) | ||
service.On("GetProjects", expectedFilter).Return(projects, nil) | ||
rest.GetProject(service)(ctx) | ||
|
||
assert.Equal(t, 200, w.Code) | ||
}) | ||
|
||
} |
Oops, something went wrong.