From 52ae0adf04cbbca5468315beb896dcb380eeb9df Mon Sep 17 00:00:00 2001 From: raybittu Date: Mon, 15 Feb 2021 13:01:46 +0530 Subject: [PATCH] #3 | added pagination and filter, only filter by skills remaining --- .DS_Store | Bin 6148 -> 6148 bytes panel.zip | Bin 0 -> 15644 bytes panel/http/http.go | 22 ++++- panel/service/coverage.txt | 50 +++++----- panel/service/interface.go | 2 +- panel/service/service.go | 7 +- panel/service/service_test.go | 49 +++++++++- panel/store/coverage.txt | 53 ++++++----- panel/store/interface.go | 3 +- panel/store/store.go | 29 +++++- panel/store/store_test.go | 168 ++++++++++++++++++++++++++++++++-- 11 files changed, 317 insertions(+), 66 deletions(-) create mode 100644 panel.zip diff --git a/.DS_Store b/.DS_Store index 60d43a904a8a58f551c6bada4e745c30afb7df95..cb98ecdc4912abf077d2d4c96a2c673f8ea00533 100644 GIT binary patch delta 120 zcmZoMXfc@J&&abeU^g=(&tx8!Ojafa7Y3)vaxC(jOIg-4>J~60GUPF&GUPDmF;p>R zG8A~`TPvOFbFU(FtPyYm;b?lfnl;do2fVtLoq`+P**w-rZN-(^;H6SxszE~ P6*rctGHzz)_{$FfUg;l` delta 36 scmZoMXfc@J&&atkU^g=(=VTt1%*``d)-z77Vl&uSwwZA=JI7ys0N9ia6951J diff --git a/panel.zip b/panel.zip new file mode 100644 index 0000000000000000000000000000000000000000..86a1d48a247d6c52f232d9aa883a022cae6503a9 GIT binary patch literal 15644 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 c$BxBvhE literal 0 HcmV?d00001 diff --git a/panel/http/http.go b/panel/http/http.go index 615ba05e..1d9136c5 100644 --- a/panel/http/http.go +++ b/panel/http/http.go @@ -46,7 +46,27 @@ func (p PanelHTTP) GetAllEmployee(c *gofr.Context) (interface{}, error) { return "Invalid CompanyID", customeerror.ErrInvalidCompanyID } - res, err := p.service.GetAllEmployee(c, companyID) + yoe, _ := strconv.Atoi(c.Param("yoe")) + designation := c.Param("designation") + page, err := strconv.Atoi(c.Param("page")) + if err != nil { + page = 1 + } + limit, err := strconv.Atoi(c.Param("limit")) + if err != nil { + limit = 20 + } + skills := []string{} + + queryParams := map[string]interface{}{ + "yoe": yoe, + "designation": designation, + "page": (page - 1) * limit, + "limit": limit, + "skills": skills, + } + + res, err := p.service.GetAllEmployee(c, companyID, queryParams) if err != nil { return nil, err } diff --git a/panel/service/coverage.txt b/panel/service/coverage.txt index f40eed11..98d8f90f 100644 --- a/panel/service/coverage.txt +++ b/panel/service/coverage.txt @@ -1,27 +1,29 @@ mode: set github.com/zopsmart/hiring-portal-api/panel/service/service.go:14.43,16.2 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:18.105,19.20 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:22.2,22.45 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:18.140,19.20 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:22.2,22.37 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:25.2,25.72 1 1 github.com/zopsmart/hiring-portal-api/panel/service/service.go:19.20,21.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:25.116,26.20 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:29.2,29.21 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:32.2,32.58 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:26.20,28.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:29.21,31.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:35.125,36.20 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:39.2,40.16 2 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:43.2,45.18 3 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:36.20,38.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:40.16,42.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:48.135,49.20 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:52.2,52.21 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:55.2,56.16 2 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:59.2,61.18 3 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:49.20,51.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:52.21,54.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:56.16,58.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:64.96,65.20 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:68.2,68.21 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:71.2,71.57 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:65.20,67.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/service/service.go:68.21,70.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:22.37,24.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:28.116,29.20 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:32.2,32.21 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:35.2,35.58 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:29.20,31.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:32.21,34.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:38.125,39.20 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:42.2,43.16 2 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:46.2,48.18 3 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:39.20,41.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:43.16,45.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:51.135,52.20 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:55.2,55.21 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:58.2,59.16 2 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:62.2,64.18 3 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:52.20,54.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:55.21,57.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:59.16,61.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:67.96,68.20 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:71.2,71.21 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:74.2,74.57 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:68.20,70.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/service/service.go:71.21,73.3 1 1 diff --git a/panel/service/interface.go b/panel/service/interface.go index 191cfc33..a9c88e09 100644 --- a/panel/service/interface.go +++ b/panel/service/interface.go @@ -6,7 +6,7 @@ import ( ) type PanelEmployee interface { - GetAllEmployee(*gofr.Context, int) ([]models.Employee, error) + GetAllEmployee(*gofr.Context, int, map[string]interface{}) ([]models.Employee, error) GetEmployeeByID(*gofr.Context, int, int) (models.Employee, error) CreateEmployee(*gofr.Context, int, *models.Employee) (models.Employee, error) EditEmployee(*gofr.Context, int, int, *models.Employee) (models.Employee, error) diff --git a/panel/service/service.go b/panel/service/service.go index ca8d230c..9c78059b 100644 --- a/panel/service/service.go +++ b/panel/service/service.go @@ -15,11 +15,14 @@ func New(store store.Panel) PanelEmployee { return PanelEmployeeService{store: store} } -func (p PanelEmployeeService) GetAllEmployee(c *gofr.Context, companyID int) ([]models.Employee, error) { +func (p PanelEmployeeService) GetAllEmployee(c *gofr.Context, companyID int, queryParam map[string]interface{}) ([]models.Employee, error) { if companyID <= 0 { return nil, customeerror.ErrInvalidCompanyID } - return p.store.GetAllEmployee(c, companyID) + if queryParam["designation"] == "" { + return p.store.GetAllEmployeeWithoutDesignation(c, companyID, queryParam) + } + return p.store.GetAllEmployeeWithDesignation(c, companyID, queryParam) } func (p PanelEmployeeService) GetEmployeeByID(c *gofr.Context, companyID, employeeID int) (models.Employee, error) { diff --git a/panel/service/service_test.go b/panel/service/service_test.go index 00a4f8be..d9e0c0d1 100644 --- a/panel/service/service_test.go +++ b/panel/service/service_test.go @@ -41,6 +41,7 @@ func testAllEmployeeService(t *testing.T, c *gofr.Context) { input int expectedOutput []models.Employee expectedErr error + queryParams map[string]interface{} }{ { input: 1, @@ -48,21 +49,53 @@ func testAllEmployeeService(t *testing.T, c *gofr.Context) { {2, "Bittu Ray", "bitturay@gmail.com", 7250073080, "sde2", 2, 1}, }, expectedErr: nil, + queryParams: map[string]interface{}{ + "yoe": 1, + "designation": "sde", + "page": 0, + "limit": 10, + "skills": []string{}, + }, }, { input: -1, expectedOutput: []models.Employee(nil), expectedErr: customeerror.ErrInvalidCompanyID, + queryParams: map[string]interface{}{ + "yoe": 1, + "designation": "sde", + "page": 0, + "limit": 10, + "skills": []string{}, + }, + }, + { + input: 2, + expectedErr: customeerror.ErrDBServer, + queryParams: map[string]interface{}{ + "yoe": 1, + "designation": "sde", + "page": 0, + "limit": 10, + "skills": []string{}, + }, }, { input: 2, expectedErr: customeerror.ErrDBServer, + queryParams: map[string]interface{}{ + "yoe": 1, + "designation": "", + "page": 0, + "limit": 10, + "skills": []string{}, + }, }, } for i := range testCases { dataService := New(mockStore{}) - output, err := dataService.GetAllEmployee(c, testCases[i].input) + output, err := dataService.GetAllEmployee(c, testCases[i].input, testCases[i].queryParams) CheckErrOutput(t, testCases[i].expectedErr, err, testCases[i].expectedOutput, output) } } @@ -235,7 +268,19 @@ func testDeleteEmployeeService(t *testing.T, c *gofr.Context) { type mockStore struct { } -func (m mockStore) GetAllEmployee(c *gofr.Context, companyID int) ([]models.Employee, error) { +func (m mockStore) GetAllEmployeeWithDesignation(c *gofr.Context, companyID int, queryParams map[string]interface{}) ([]models.Employee, error) { + if companyID == 2 { + return nil, customeerror.ErrDBServer + } + + res := []models.Employee{{1, "Bittu", "bittu@gmail.com", 7250073079, "sde1", 2, 1}, + {2, "Bittu Ray", "bitturay@gmail.com", 7250073080, "sde2", 2, 1}, + } + + return res, nil +} + +func (m mockStore) GetAllEmployeeWithoutDesignation(c *gofr.Context, companyID int, queryParams map[string]interface{}) ([]models.Employee, error) { if companyID == 2 { return nil, customeerror.ErrDBServer } diff --git a/panel/store/coverage.txt b/panel/store/coverage.txt index fc22581a..fc4fed50 100644 --- a/panel/store/coverage.txt +++ b/panel/store/coverage.txt @@ -1,6 +1,6 @@ mode: set github.com/zopsmart/hiring-portal-api/panel/store/store.go:11.18,13.2 1 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:15.95,20.16 5 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:15.146,20.16 5 1 github.com/zopsmart/hiring-portal-api/panel/store/store.go:23.2,25.18 3 1 github.com/zopsmart/hiring-portal-api/panel/store/store.go:32.2,32.19 1 1 github.com/zopsmart/hiring-portal-api/panel/store/store.go:35.2,35.17 1 1 @@ -9,26 +9,35 @@ github.com/zopsmart/hiring-portal-api/panel/store/store.go:25.18,27.109 2 1 github.com/zopsmart/hiring-portal-api/panel/store/store.go:30.3,30.23 1 1 github.com/zopsmart/hiring-portal-api/panel/store/store.go:27.109,29.4 1 1 github.com/zopsmart/hiring-portal-api/panel/store/store.go:32.19,34.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:38.106,43.16 5 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:38.149,43.16 5 1 github.com/zopsmart/hiring-portal-api/panel/store/store.go:46.2,48.18 3 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:53.2,53.17 1 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:57.2,57.17 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:55.2,55.19 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:58.2,58.17 1 1 github.com/zopsmart/hiring-portal-api/panel/store/store.go:43.16,45.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:48.18,49.123 1 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:49.123,51.4 1 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:53.17,56.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:60.103,65.16 5 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:68.2,69.14 2 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:72.2,72.21 1 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:65.16,67.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:69.14,71.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:75.113,80.16 5 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:83.2,84.13 2 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:87.2,87.21 1 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:80.16,82.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:84.13,86.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:90.86,94.16 4 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:98.2,99.12 2 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:103.2,103.12 1 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:94.16,97.3 1 1 -github.com/zopsmart/hiring-portal-api/panel/store/store.go:99.12,102.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:48.18,50.109 2 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:53.3,53.23 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:50.109,52.4 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:55.19,57.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:61.106,66.16 5 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:69.2,71.18 3 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:76.2,76.17 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:80.2,80.17 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:66.16,68.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:71.18,72.123 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:72.123,74.4 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:76.17,79.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:83.103,88.16 5 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:91.2,92.14 2 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:95.2,95.21 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:88.16,90.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:92.14,94.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:98.113,103.16 5 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:106.2,107.13 2 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:110.2,110.21 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:103.16,105.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:107.13,109.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:113.86,117.16 4 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:121.2,122.12 2 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:126.2,126.12 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:117.16,120.3 1 1 +github.com/zopsmart/hiring-portal-api/panel/store/store.go:122.12,125.3 1 1 diff --git a/panel/store/interface.go b/panel/store/interface.go index 8e2ba0be..124d7404 100644 --- a/panel/store/interface.go +++ b/panel/store/interface.go @@ -6,7 +6,8 @@ import ( ) type Panel interface { - GetAllEmployee(*gofr.Context, int) ([]models.Employee, error) + GetAllEmployeeWithDesignation(*gofr.Context, int, map[string]interface{}) ([]models.Employee, error) + GetAllEmployeeWithoutDesignation(*gofr.Context, int, map[string]interface{}) ([]models.Employee, error) GetEmployeeByID(*gofr.Context, int, int) (models.Employee, error) CreateEmployee(*gofr.Context, int, *models.Employee) (int, error) EditEmployee(*gofr.Context, int, int, *models.Employee) (int, error) diff --git a/panel/store/store.go b/panel/store/store.go index 9a87672c..45a1fa5b 100644 --- a/panel/store/store.go +++ b/panel/store/store.go @@ -12,10 +12,33 @@ func New() Panel { return PanelStore{} } -func (p PanelStore) GetAllEmployee(c *gofr.Context, companyID int) ([]models.Employee, error) { - const query = "select * from employee where company_id=? order by id, company_id asc" +func (p PanelStore) GetAllEmployeeWithDesignation(c *gofr.Context, companyID int, queryParams map[string]interface{}) ([]models.Employee, error) { + const query = "select * from employee where company_id=? and designation=? and yoe>=? order by id desc limit ?,?" var inputInterface []interface{} - inputInterface = append(inputInterface, companyID) + inputInterface = append(inputInterface, companyID, queryParams["designation"], queryParams["yoe"], queryParams["page"], queryParams["limit"]) + rows, err := c.DB.Query(query, inputInterface...) + if err != nil { + return nil, customeerror.ErrDBServer + } + defer rows.Close() + var res []models.Employee + for rows.Next() { + var e models.Employee + if err := rows.Scan(&e.ID, &e.Name, &e.Email, &e.Phone, &e.Designation, &e.YOE, &e.CompanyID); err != nil { + return nil, customeerror.ErrDBServer + } + res = append(res, e) + } + if len(res) == 0 { + return res, customeerror.ErrRecordNotFound + } + return res, nil +} + +func (p PanelStore) GetAllEmployeeWithoutDesignation(c *gofr.Context, companyID int, queryParams map[string]interface{}) ([]models.Employee, error) { + const query = "select * from employee where company_id=? and yoe>=? order by id desc limit ?,?" + var inputInterface []interface{} + inputInterface = append(inputInterface, companyID, queryParams["yoe"], queryParams["page"], queryParams["limit"]) rows, err := c.DB.Query(query, inputInterface...) if err != nil { return nil, customeerror.ErrDBServer diff --git a/panel/store/store_test.go b/panel/store/store_test.go index f33c8649..6a66efcb 100644 --- a/panel/store/store_test.go +++ b/panel/store/store_test.go @@ -26,7 +26,7 @@ func CheckErrOutput(t *testing.T, expectedErr, actualErr, expectedOutput, actual } } -func TestGetAllEmployeeMock(t *testing.T) { +func TestGetAllEmployeeWithDesignationMock(t *testing.T) { db, mock, err := sqlmock.New() if err != nil { fmt.Println(err) @@ -41,6 +41,7 @@ func TestGetAllEmployeeMock(t *testing.T) { input int expectedOutput []models.Employee expectedErr error + queryParams map[string]interface{} }{ { input: 1, @@ -49,23 +50,170 @@ func TestGetAllEmployeeMock(t *testing.T) { {2, "Bittu Ray", "bitturay@gmail.com", 7250073080, "sde2", 2, 1}, }, expectedErr: nil, + queryParams: map[string]interface{}{ + "yoe": 1, + "designation": "sde", + "page": 0, + "limit": 10, + "skills": []string{}, + }, + }, + + { + input: 2, + expectedOutput: []models.Employee(nil), + expectedErr: customeerror.ErrDBServer, + queryParams: map[string]interface{}{ + "yoe": 1, + "designation": "sde", + "page": 0, + "limit": 10, + "skills": []string{}, + }, + }, + { + input: 3, + expectedOutput: []models.Employee(nil), + expectedErr: customeerror.ErrRecordNotFound, + queryParams: map[string]interface{}{ + "yoe": 1, + "designation": "sde", + "page": 0, + "limit": 10, + "skills": []string{}, + }, + }, + + { + input: 4, + expectedOutput: []models.Employee(nil), + expectedErr: customeerror.ErrDBServer, + queryParams: map[string]interface{}{ + "yoe": 1, + "designation": "sde", + "page": 0, + "limit": 10, + "skills": []string{}, + }, + }, + } + + for i := range testCases { + var output, err interface{} + + if i == 3 { + table := []string{"id", "name", "email", "phone", "designation", "yoe"} + query := "select * from employee where companyid=? and designation=? and yoe>=? order by id desc limit ?,?" + rows := sqlmock.NewRows(table) + for j := range testCases[i].expectedOutput { + rows.AddRow(testCases[i].expectedOutput[j].ID, testCases[i].expectedOutput[j].Name, + testCases[i].expectedOutput[j].Email, testCases[i].expectedOutput[j].Phone, + testCases[i].expectedOutput[j].Designation, testCases[i].expectedOutput[j].YOE, + testCases[i].expectedOutput[j].CompanyID) + } + + mock.ExpectQuery(regexp.QuoteMeta(query)).WithArgs(testCases[i].input, testCases[i].queryParams["designation"], testCases[i].queryParams["yoe"], testCases[i].queryParams["page"], testCases[i].queryParams["limit"]).WillReturnRows(rows) + output, err = dataStore.GetAllEmployeeWithDesignation(c, testCases[i].input, testCases[i].queryParams) + } else if i == 1 { + table := []string{"id", "name", "email", "phone", "designation", "company_id"} + query := "select * from employee where company_id=? and designation=? and yoe>=? order by id desc limit ?,?" + rows := sqlmock.NewRows(table) + + rows.AddRow(2, "Bittu Ray", "bitturay@gmail.com", 7250073080, "sde2", 2) + + mock.ExpectQuery(regexp.QuoteMeta(query)).WithArgs(testCases[i].input, testCases[i].queryParams["designation"], testCases[i].queryParams["yoe"], testCases[i].queryParams["page"], testCases[i].queryParams["limit"]).WillReturnRows(rows) + output, err = dataStore.GetAllEmployeeWithDesignation(c, testCases[i].input, testCases[i].queryParams) + } else { + table := []string{"id", "name", "email", "phone", "designation", "yoe", "company_id"} + query := "select * from employee where company_id=? and designation=? and yoe>=? order by id desc limit ?,?" + rows := sqlmock.NewRows(table) + for j := range testCases[i].expectedOutput { + rows.AddRow(testCases[i].expectedOutput[j].ID, testCases[i].expectedOutput[j].Name, + testCases[i].expectedOutput[j].Email, testCases[i].expectedOutput[j].Phone, + testCases[i].expectedOutput[j].Designation, testCases[i].expectedOutput[j].YOE, + testCases[i].expectedOutput[j].CompanyID) + } + + mock.ExpectQuery(regexp.QuoteMeta(query)).WithArgs(testCases[i].input, testCases[i].queryParams["designation"], testCases[i].queryParams["yoe"], testCases[i].queryParams["page"], testCases[i].queryParams["limit"]).WillReturnRows(rows) + output, err = dataStore.GetAllEmployeeWithDesignation(c, testCases[i].input, testCases[i].queryParams) + + if err := mock.ExpectationsWereMet(); err != nil { + t.Errorf("there were unfulfilled expectations: %s", err) + } + } + CheckErrOutput(t, testCases[i].expectedErr, err, testCases[i].expectedOutput, output) + } +} + +func TestGetAllEmployeeWithoutDesignationMock(t *testing.T) { + db, mock, err := sqlmock.New() + if err != nil { + fmt.Println(err) + } + c := &gofr.Context{Container: &gofr.Container{ + Logger: logging.NewLogger(logging.DEBUG), + DB: &gofr.DB{db}, + }} + + dataStore := New() + testCases := []struct { + input int + expectedOutput []models.Employee + expectedErr error + queryParams map[string]interface{} + }{ + { + input: 1, + expectedOutput: []models.Employee{ + {1, "Bittu", "bittu@gmail.com", 7250073079, "sde1", 2, 1}, + {2, "Bittu Ray", "bitturay@gmail.com", 7250073080, "sde2", 2, 1}, + }, + expectedErr: nil, + queryParams: map[string]interface{}{ + "yoe": 1, + "designation": "sde", + "page": 0, + "limit": 10, + "skills": []string{}, + }, }, { input: 2, expectedOutput: []models.Employee(nil), expectedErr: customeerror.ErrDBServer, + queryParams: map[string]interface{}{ + "yoe": 1, + "designation": "sde", + "page": 0, + "limit": 10, + "skills": []string{}, + }, }, { input: 3, expectedOutput: []models.Employee(nil), expectedErr: customeerror.ErrRecordNotFound, + queryParams: map[string]interface{}{ + "yoe": 1, + "designation": "sde", + "page": 0, + "limit": 10, + "skills": []string{}, + }, }, { input: 4, expectedOutput: []models.Employee(nil), expectedErr: customeerror.ErrDBServer, + queryParams: map[string]interface{}{ + "yoe": 1, + "designation": "sde", + "page": 0, + "limit": 10, + "skills": []string{}, + }, }, } @@ -74,7 +222,7 @@ func TestGetAllEmployeeMock(t *testing.T) { if i == 3 { table := []string{"id", "name", "email", "phone", "designation", "yoe"} - query := "select * from employee where companyd=? order by id, company_id asc" + query := "select * from employee where companyid=? and yoe>=? order by id desc limit ?,?" rows := sqlmock.NewRows(table) for j := range testCases[i].expectedOutput { rows.AddRow(testCases[i].expectedOutput[j].ID, testCases[i].expectedOutput[j].Name, @@ -83,20 +231,20 @@ func TestGetAllEmployeeMock(t *testing.T) { testCases[i].expectedOutput[j].CompanyID) } - mock.ExpectQuery(regexp.QuoteMeta(query)).WithArgs(testCases[i].input).WillReturnRows(rows) - output, err = dataStore.GetAllEmployee(c, testCases[i].input) + mock.ExpectQuery(regexp.QuoteMeta(query)).WithArgs(testCases[i].input, testCases[i].queryParams["yoe"], testCases[i].queryParams["page"], testCases[i].queryParams["limit"]).WillReturnRows(rows) + output, err = dataStore.GetAllEmployeeWithoutDesignation(c, testCases[i].input, testCases[i].queryParams) } else if i == 1 { table := []string{"id", "name", "email", "phone", "designation", "company_id"} - query := "select * from employee where company_id=? order by id, company_id asc" + query := "select * from employee where company_id=? and yoe>=? order by id desc limit ?,?" rows := sqlmock.NewRows(table) rows.AddRow(2, "Bittu Ray", "bitturay@gmail.com", 7250073080, "sde2", 2) - mock.ExpectQuery(regexp.QuoteMeta(query)).WithArgs(testCases[i].input).WillReturnRows(rows) - output, err = dataStore.GetAllEmployee(c, testCases[i].input) + mock.ExpectQuery(regexp.QuoteMeta(query)).WithArgs(testCases[i].input, testCases[i].queryParams["yoe"], testCases[i].queryParams["page"], testCases[i].queryParams["limit"]).WillReturnRows(rows) + output, err = dataStore.GetAllEmployeeWithoutDesignation(c, testCases[i].input, testCases[i].queryParams) } else { table := []string{"id", "name", "email", "phone", "designation", "yoe", "company_id"} - query := "select * from employee where company_id=? order by id, company_id asc" + query := "select * from employee where company_id=? and yoe>=? order by id desc limit ?,?" rows := sqlmock.NewRows(table) for j := range testCases[i].expectedOutput { rows.AddRow(testCases[i].expectedOutput[j].ID, testCases[i].expectedOutput[j].Name, @@ -105,8 +253,8 @@ func TestGetAllEmployeeMock(t *testing.T) { testCases[i].expectedOutput[j].CompanyID) } - mock.ExpectQuery(regexp.QuoteMeta(query)).WithArgs(testCases[i].input).WillReturnRows(rows) - output, err = dataStore.GetAllEmployee(c, testCases[i].input) + mock.ExpectQuery(regexp.QuoteMeta(query)).WithArgs(testCases[i].input, testCases[i].queryParams["yoe"], testCases[i].queryParams["page"], testCases[i].queryParams["limit"]).WillReturnRows(rows) + output, err = dataStore.GetAllEmployeeWithoutDesignation(c, testCases[i].input, testCases[i].queryParams) if err := mock.ExpectationsWereMet(); err != nil { t.Errorf("there were unfulfilled expectations: %s", err)