diff --git a/README.MD b/README.MD
index 74607454..a844c2a5 100644
--- a/README.MD
+++ b/README.MD
@@ -13,7 +13,6 @@ An enterprise go template application showcasing - Testing strategies, middlewar
___
-
Expert teams of digital product strategists, developers, and designers.
@@ -28,23 +27,17 @@ An enterprise go template application showcasing - Testing strategies, middlewar
-
- ___
+ ---
We’re always looking for people who value their work, so come and join
us. We are hiring!
-
---
-
-
-
-
The Go Template is a template/starter go project.
## Out of the box support for
@@ -72,24 +65,24 @@ to configure the following:
3. Install the sqlboiler, sql-migrate and gqlgen using
+```bash
+go get -v github.com/rubenv/sql-migrate/... \
+github.com/volatiletech/sqlboiler \
+github.com/99designs/gqlgen
```
- go get -v github.com/rubenv/sql-migrate/... \
- github.com/volatiletech/sqlboiler \
- github.com/99designs/gqlgen
- ```
For Go 1.16 or above, you need to install sqlboiler using
- ```
- go install github.com/volatiletech/sqlboiler/v4@latest
- go install github.com/volatiletech/sqlboiler/v4/drivers/sqlboiler-psql@latest
- ```
+```bash
+go install github.com/volatiletech/sqlboiler/v4@latest
+go install github.com/volatiletech/sqlboiler/v4/drivers/sqlboiler-psql@latest
+```
For Go 1.18 and above install the sql-migrate using
- ```
- go install github.com/rubenv/sql-migrate/...@latest
- ```
+```bash
+go install github.com/rubenv/sql-migrate/...@latest
+```
4. To run all the migrations using the script setup-local.sh as follows `make setup-local`.
@@ -101,20 +94,20 @@ For Go 1.18 and above install the sql-migrate using
go run cmd/server/main.go
```
-**NOTE:** Please do not delete ```.env.base``` file of the project and rebuild the using docker-compose everytime you
+**NOTE:** Please do not delete `.env.base` file of the project and rebuild the using docker-compose everytime you
make changes to it
# Setting up database (postgres)
- Requirement [postgresql](https://www.postgresql.org/)
-Steps to set up database with ```username``` and ```role``` using terminal
+Steps to set up database with `username` and `role` using terminal
-- Enter postgres terminal ```psql postgres```
-- Create new database ```CREATE DATABASE go_template;```
-- Create a new role with password ```CREATE ROLE go_template_role WITH LOGIN PASSWORD 'go_template_role456';```
+- Enter postgres terminal `psql postgres`
+- Create new database `CREATE DATABASE go_template;`
+- Create a new role with password `CREATE ROLE go_template_role WITH LOGIN PASSWORD 'go_template_role456';`
-**NOTE:** Replace these credentials in ```.env``` file of the project
+**NOTE:** Replace these credentials in `.env` file of the project
# Using Docker
@@ -132,27 +125,27 @@ Set up signoz locally by following the steps [here](https://signoz.io/docs/insta
# Running migrations
-Migrations are present in ```internal/migrations``` package. Run below command to run all migrations at once:
+Migrations are present in `internal/migrations` package. Run below command to run all migrations at once:
-```
+```bash
sql-migrate up -env postgres
```
To drop migration use following
-```
+```bash
sql-migrate down -env postgres -limit=0
```
To check status of migration use following
-```
+```bash
sql-migrate new -env postgres
```
To add new migration use following, it creates a new empty migration template with pattern `-.sql`
-```
+```bash
sql-migrate new -env postgres
```
@@ -203,7 +196,7 @@ go-template/
│ └──line-formatter.sh # auto format to adhere to the lll.line-length criteria
└──schema/ # this directory will have all the .graphql files which make the graphql api
└──.env.local # a sample .env file for reference
-└──.env.base # a base .env file should be included in all environments
+└──.env.base # a base .env file should be included in all environments
└──.pre-commit-config.yaml # config to run pre-commit utility
└──docker-compose.*.yml # docker-compose file corresponding to the state of project (local, prod, test)
└──docker-compose.yml # docker-compose file which serves as a base to other docker-compose files
@@ -220,7 +213,7 @@ go-template/
generate your database models
-```
+```bash
sqlboiler psql --no-hooks
```
@@ -228,8 +221,9 @@ sqlboiler psql --no-hooks
For seeding Your database models use
-```
-go run cmd/seeder/exec/seed.go
+```bash
+go run cmd/seeder/main.go ## to build the execs for seeding
+go run cmd/seeder/exec/seed.go ## to seed
```
Note: We have Seeder directory because we are using it while building docker image for application
@@ -238,19 +232,19 @@ Note: We have Seeder directory because we are using it while building docker ima
generate the graphql models from the database schema
-```
+```bash
gqlgen generate
```
## API (for graphQL to operate)
-- Graphql endpoint ```POST``` request ```/graphql```
+- Graphql endpoint `POST` request `/graphql`
-- Playground endpoint for schema ```/playground```
+- Playground endpoint for schema `/playground`
Take a look at the following file
- - [pkg/api/api.go](pkg/api/api.go)
+ - [pkg/api/api.go](pkg/api/api.go)
## Schema
@@ -258,13 +252,13 @@ gqlgen generate
Take a look at the following folder
- - [schema](./schema/)
+ - [schema](./schema/)
## Resolver
- Queries and mutation are autogenerated using gqlgen and are to be extended. Take a look at the following files
- - [resolver](./resolver)
+ - [resolver](./resolver)
## Infrastructure
@@ -279,7 +273,7 @@ gqlgen generate
Application name should container only lowercase letters. No hyphens and underscores or any other special characters.
-```
+```bash
make setup-ecs name=gotemplate env=dev
```
@@ -287,31 +281,28 @@ Please change the ENV_INJECTION variable as true in .env.base file to true, so i
Also add the environment variables to the task,add this block of yml code in ${service name}/manifest.yaml:
-```
-
-variables:
- ENVIRONMENT_NAME: develop
+```yaml
+variables:
+ ENVIRONMENT_NAME: develop
- #to inject our .env file from aws s3 inside the container
+ #to inject our .env file from aws s3 inside the container
taskdef_overrides:
- path: ContainerDefinitions[0].EnvironmentFiles[0]
value:
- type: 's3'
- value: 'arn:aws:s3:::gotemplate-dev-bucket/develop/.env'
-
+ type: "s3"
+ value: "arn:aws:s3:::gotemplate-dev-bucket/develop/.env"
```
Make sure that the manifest.yml has http.path: '/'
-```
+```yaml
http:
# Requests to this path will be forwarded to your service.
# To match all requests you can use the "/" path.
- path: '/'
+ path: "/"
# You can specify a custom health check path. The default is "/".
# healthcheck: '/'
-
```
Also make sure the execution role has an appropriate policy attached to it so it can access our .env file inside the s3
@@ -319,13 +310,13 @@ bucket, and inject it as environment variables.
### To deploy
-```
+```bash
make deploy-ecs name=gotemplate env=dev
```
### Update infrastructure
-```
+```bash
make update-ecs name=gotemplate env=dev
```
@@ -333,7 +324,7 @@ make update-ecs name=gotemplate env=dev
Get test coverage using
-```
+```bash
go test -cover
```
@@ -341,13 +332,13 @@ go test -cover
Install Mockgen Using
-```
+```bash
go install github.com/gleisonmv/mockgen@latest
```
Sample command to generate mocks
-```
+```bash
mockgen --build_flags=--mod=mod github.com/go-playground/validator FieldError
```
diff --git a/pkg/utl/rediscache/redis_test.go b/pkg/utl/rediscache/redis_test.go
index fb8ee8f0..93975fd7 100644
--- a/pkg/utl/rediscache/redis_test.go
+++ b/pkg/utl/rediscache/redis_test.go
@@ -7,7 +7,6 @@ import (
"testing"
. "github.com/agiledragon/gomonkey/v2"
- "github.com/gomodule/redigo/redis"
redigo "github.com/gomodule/redigo/redis"
redigomock "github.com/rafaeljusto/redigomock/v3"
)
@@ -38,11 +37,11 @@ func Test_redisDial(t *testing.T) {
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if tt.wantErr {
- ApplyFunc(redigo.Dial, func(string, string, ...redis.DialOption) (redis.Conn, error) {
+ ApplyFunc(redigo.Dial, func(string, string, ...redigo.DialOption) (redigo.Conn, error) {
return nil, fmt.Errorf("some error")
})
} else {
- ApplyFunc(redigo.Dial, func(string, string, ...redis.DialOption) (redis.Conn, error) {
+ ApplyFunc(redigo.Dial, func(string, string, ...redigo.DialOption) (redigo.Conn, error) {
return redigoConn, nil
})
}
@@ -92,7 +91,7 @@ func TestSetKeyValue(t *testing.T) {
wantErr: true,
},
}
- ApplyFunc(redigo.Dial, func(string, string, ...redis.DialOption) (redis.Conn, error) {
+ ApplyFunc(redigo.Dial, func(string, string, ...redigo.DialOption) (redigo.Conn, error) {
return redigoConn, nil
})
for _, tt := range tests {
@@ -100,13 +99,13 @@ func TestSetKeyValue(t *testing.T) {
var patches *Patches
b, _ := json.Marshal(tt.args.data)
if tt.name == FailedCase {
- patches = ApplyFunc(redigo.Dial, func(string, string, ...redis.DialOption) (redis.Conn, error) {
+ patches = ApplyFunc(redigo.Dial, func(string, string, ...redigo.DialOption) (redigo.Conn, error) {
return nil, fmt.Errorf("some error")
})
}
if tt.name == ErrorMarshal {
patchJson := ApplyFunc(json.Marshal, func(v any) ([]byte, error) {
- return nil, fmt.Errorf(ErrMsgMarshal)
+ return nil, fmt.Errorf("%s", ErrMsgMarshal)
})
defer patchJson.Reset()
}
@@ -150,7 +149,7 @@ func TestGetKeyValue(t *testing.T) {
t.Run(tt.name, func(t *testing.T) {
var patches *Patches
if tt.wantErr {
- patches = ApplyFunc(redigo.Dial, func(string, string, ...redis.DialOption) (redis.Conn, error) {
+ patches = ApplyFunc(redigo.Dial, func(string, string, ...redigo.DialOption) (redigo.Conn, error) {
return nil, fmt.Errorf("some error")
})
}
diff --git a/pkg/utl/rediscache/service_test.go b/pkg/utl/rediscache/service_test.go
index 79f7b9b5..ea3caedf 100644
--- a/pkg/utl/rediscache/service_test.go
+++ b/pkg/utl/rediscache/service_test.go
@@ -18,7 +18,6 @@ import (
"github.com/DATA-DOG/go-sqlmock"
"github.com/agiledragon/gomonkey/v2"
. "github.com/agiledragon/gomonkey/v2"
- "github.com/gomodule/redigo/redis"
redigo "github.com/gomodule/redigo/redis"
redigomock "github.com/rafaeljusto/redigomock/v3"
)
@@ -85,7 +84,7 @@ type userTestCaseArgs struct {
wantErr bool
errMsg error
- init func(sqlmock.Sqlmock, argsGetUser) *Patches
+ init func(sqlmock.Sqlmock, argsGetUser) *gomonkey.Patches
}
func getUserTestCases() []userTestCaseArgs {
@@ -108,9 +107,9 @@ func errorGetKeyValueCase() userTestCaseArgs {
userID: testutls.MockID,
},
wantErr: true,
- errMsg: fmt.Errorf(ErrMsgGetKeyValue),
- init: func(mock sqlmock.Sqlmock, args argsGetUser) *Patches {
- conn.Command("GET", fmt.Sprintf("user%d", args.userID)).ExpectError(fmt.Errorf(ErrMsgGetKeyValue))
+ errMsg: fmt.Errorf("%s", ErrMsgGetKeyValue),
+ init: func(mock sqlmock.Sqlmock, args argsGetUser) *gomonkey.Patches {
+ conn.Command("GET", fmt.Sprintf("user%d", args.userID)).ExpectError(fmt.Errorf("%s", ErrMsgGetKeyValue))
return nil
},
}
@@ -122,8 +121,8 @@ func errorUnmarshalCase() userTestCaseArgs {
userID: testutls.MockID,
},
wantErr: true,
- init: func(s sqlmock.Sqlmock, user argsGetUser) *Patches {
- patchJson := ApplyFunc(json.Marshal, func(v any) ([]byte, error) {
+ init: func(s sqlmock.Sqlmock, user argsGetUser) *gomonkey.Patches {
+ patchJson := gomonkey.ApplyFunc(json.Marshal, func(v any) ([]byte, error) {
return []byte{}, fmt.Errorf("json error")
})
return patchJson
@@ -136,7 +135,7 @@ func errorSetKeyValueCase() userTestCaseArgs {
args: argsGetUser{
userID: testutls.MockID,
},
- init: func(mock sqlmock.Sqlmock, args argsGetUser) *Patches {
+ init: func(mock sqlmock.Sqlmock, args argsGetUser) *gomonkey.Patches {
conn.Command("GET", fmt.Sprintf("user%d", args.userID)).Expect(nil)
b, _ := json.Marshal(testutls.MockUser())
conn.Command("SET", fmt.Sprintf("user%d", args.userID), string(b)).ExpectError(fmt.Errorf("this is an error"))
@@ -156,7 +155,7 @@ func errorSetKeyValueCase() userTestCaseArgs {
return nil
},
wantErr: true,
- errMsg: fmt.Errorf(ErrMsgSetKeyValue),
+ errMsg: fmt.Errorf("%s", ErrMsgSetKeyValue),
}
}
func errorDaosCase() userTestCaseArgs {
@@ -165,7 +164,7 @@ func errorDaosCase() userTestCaseArgs {
args: argsGetUser{
userID: testutls.MockID,
},
- init: func(mock sqlmock.Sqlmock, args argsGetUser) *Patches {
+ init: func(mock sqlmock.Sqlmock, args argsGetUser) *gomonkey.Patches {
conn.Command("GET", fmt.Sprintf("user%d", args.userID)).Expect(nil)
dbQueries := []testutls.QueryData{
{
@@ -182,7 +181,7 @@ func errorDaosCase() userTestCaseArgs {
return nil
},
wantErr: true,
- errMsg: fmt.Errorf(ErrMsgSetKeyValue),
+ errMsg: fmt.Errorf("%s", ErrMsgSetKeyValue),
}
}
func getSuccessCase() userTestCaseArgs {
@@ -192,7 +191,7 @@ func getSuccessCase() userTestCaseArgs {
userID: testutls.MockID,
want: testutls.MockUser(),
},
- init: func(mock sqlmock.Sqlmock, args argsGetUser) *Patches {
+ init: func(mock sqlmock.Sqlmock, args argsGetUser) *gomonkey.Patches {
b, _ := json.Marshal(args.want)
conn.Command("GET", fmt.Sprintf("user%d", args.userID)).Expect(b)
return nil
@@ -206,7 +205,7 @@ func successCacheMissCase() userTestCaseArgs {
userID: testutls.MockID,
want: testutls.MockUser(),
},
- init: func(mock sqlmock.Sqlmock, args argsGetUser) *Patches {
+ init: func(mock sqlmock.Sqlmock, args argsGetUser) *gomonkey.Patches {
conn.Command("GET", fmt.Sprintf("user%d", args.userID)).Expect(nil)
b, _ := json.Marshal(args.want)
conn.Command("SET", fmt.Sprintf("user%d", args.userID), string(b)).Expect(nil)
@@ -233,7 +232,7 @@ func errorFromCacheUserValueCase() userTestCaseArgs {
args: argsGetUser{
userID: testutls.MockID,
},
- init: func(s sqlmock.Sqlmock, args argsGetUser) *Patches {
+ init: func(s sqlmock.Sqlmock, args argsGetUser) *gomonkey.Patches {
conn.Command("GET", fmt.Sprintf("user%d", args.userID)).
ExpectError(fmt.Errorf("error while getting from cache"))
return nil
@@ -243,7 +242,7 @@ func errorFromCacheUserValueCase() userTestCaseArgs {
func TestGetUser(t *testing.T) {
tests := getUserTestCases()
- redisDialPatch := ApplyFunc(redisDial, func() (redis.Conn, error) {
+ redisDialPatch := ApplyFunc(redisDial, func() (redigo.Conn, error) {
return conn, nil
})
defer redisDialPatch.Reset()
@@ -294,7 +293,7 @@ type roleTestArgs struct {
wantErr bool
errMsg error
- init func(sqlmock.Sqlmock, getRoleArgs) *Patches
+ init func(sqlmock.Sqlmock, getRoleArgs) *gomonkey.Patches
}
func getRoleTestCase(
@@ -302,7 +301,7 @@ func getRoleTestCase(
args getRoleArgs,
wantErr bool,
errMsg error,
- init func(sqlmock.Sqlmock, getRoleArgs) *Patches) roleTestArgs {
+ init func(sqlmock.Sqlmock, getRoleArgs) *gomonkey.Patches) roleTestArgs {
return roleTestArgs{
name: name,
args: args,
@@ -316,7 +315,7 @@ func setupErrorCase(
name string,
roleID int,
errMsg error,
- init func(sqlmock.Sqlmock, getRoleArgs) *Patches) roleTestArgs {
+ init func(sqlmock.Sqlmock, getRoleArgs) *gomonkey.Patches) roleTestArgs {
return roleTestArgs{
name: name,
args: getRoleArgs{
@@ -335,7 +334,7 @@ func loadGetRoleSuccessCase() roleTestArgs {
},
false,
nil,
- func(mock sqlmock.Sqlmock, args getRoleArgs) *Patches {
+ func(mock sqlmock.Sqlmock, args getRoleArgs) *gomonkey.Patches {
b, _ := json.Marshal(args.want)
conn.Command("GET", fmt.Sprintf("role%d", args.roleID)).Expect(b)
return nil
@@ -352,7 +351,7 @@ func loadGetRoleCacheMissSuccessCase() roleTestArgs {
},
false,
nil,
- func(mock sqlmock.Sqlmock, args getRoleArgs) *Patches {
+ func(mock sqlmock.Sqlmock, args getRoleArgs) *gomonkey.Patches {
conn.Command("GET", fmt.Sprintf("role%d", args.roleID)).Expect(nil)
b, _ := json.Marshal(args.want)
conn.Command("SET", fmt.Sprintf("role%d", args.roleID), string(b)).Expect(nil)
@@ -376,23 +375,23 @@ func loadGetRoleCacheMissSuccessCase() roleTestArgs {
func getGetRoleTestCases() []roleTestArgs {
tests := []roleTestArgs{
setupErrorCase(ErrorGetKeyValue, testutls.MockID, errors.New(ErrMsgGetKeyValue),
- func(mock sqlmock.Sqlmock, args getRoleArgs) *Patches {
- conn.Command("GET", fmt.Sprintf("role%d", args.roleID)).ExpectError(fmt.Errorf(ErrMsgGetKeyValue))
+ func(mock sqlmock.Sqlmock, args getRoleArgs) *gomonkey.Patches {
+ conn.Command("GET", fmt.Sprintf("role%d", args.roleID)).ExpectError(fmt.Errorf("%s", ErrMsgGetKeyValue))
return nil
}),
setupErrorCase(ErrorUnmarshal, testutls.MockID, errors.New(ErrMsgUnmarshal),
- func(mock sqlmock.Sqlmock, args getRoleArgs) *Patches {
+ func(mock sqlmock.Sqlmock, args getRoleArgs) *gomonkey.Patches {
return ApplyFunc(json.Unmarshal, func(data []byte, v any) error {
- return fmt.Errorf(ErrMsgUnmarshal)
+ return fmt.Errorf("%s", ErrMsgUnmarshal)
})
}),
setupErrorCase(ErrorSetKeyValue, testutls.MockID, errors.New(ErrMsgSetKeyValue),
- func(mock sqlmock.Sqlmock, args getRoleArgs) *Patches {
+ func(mock sqlmock.Sqlmock, args getRoleArgs) *gomonkey.Patches {
conn.Command("GET", fmt.Sprintf("role%d", args.roleID)).Expect(nil)
return nil
}),
setupErrorCase(ErrorFindRoleById, testutls.MockID, errors.New(ErrMsgFindRoleById),
- func(mock sqlmock.Sqlmock, args getRoleArgs) *Patches {
+ func(mock sqlmock.Sqlmock, args getRoleArgs) *gomonkey.Patches {
conn.Command("GET", fmt.Sprintf("role%d", args.roleID)).ExpectError(fmt.Errorf("there was an error"))
return nil
}),
@@ -406,7 +405,7 @@ func TestGetRole(t *testing.T) {
tests := getGetRoleTestCases()
mock, cleanup, _ := testutls.SetupMockDB(t)
defer cleanup()
- redisDialPatches := ApplyFunc(redisDial, func() (redis.Conn, error) {
+ redisDialPatches := ApplyFunc(redisDial, func() (redigo.Conn, error) {
return conn, nil
})
defer redisDialPatches.Reset()
@@ -452,17 +451,17 @@ func TestIncVisits(t *testing.T) {
path: "test",
},
wantErr: true,
- errMsg: fmt.Errorf(ErrMsgFromRedisDial),
+ errMsg: fmt.Errorf("%s", ErrMsgFromRedisDial),
},
}
- ApplyFunc(redisDial, func() (redis.Conn, error) {
+ ApplyFunc(redisDial, func() (redigo.Conn, error) {
return conn, nil
})
for _, tt := range tests {
if tt.name == ErrorRedisDial {
patch := gomonkey.ApplyFunc(redisDial, func() (redigo.Conn, error) {
- return nil, fmt.Errorf(ErrMsgFromRedisDial)
+ return nil, fmt.Errorf("%s", ErrMsgFromRedisDial)
})
defer patch.Reset()
}
@@ -491,7 +490,7 @@ type startVisitTestArgs struct {
wantErr bool
errMsg error
- init func(startVisitArgs) *Patches
+ init func(startVisitArgs) *gomonkey.Patches
}
func TestStartVisits(t *testing.T) {
@@ -519,12 +518,12 @@ func getTestCases() []startVisitTestArgs {
path: "test",
},
wantErr: true,
- errMsg: fmt.Errorf(ErrMsgFromConnDo),
- init: func(args startVisitArgs) *Patches {
+ errMsg: fmt.Errorf("%s", ErrMsgFromConnDo),
+ init: func(args startVisitArgs) *gomonkey.Patches {
conn.Command("SETEX", args.path, int(math.Ceil(time.Second.Seconds())), 1).Expect(args.want)
return gomonkey.ApplyMethodFunc(redigomock.NewConn(), "Do",
func(commandName string, args ...interface{}) (reply interface{}, err error) {
- return nil, fmt.Errorf(ErrMsgFromConnDo)
+ return nil, fmt.Errorf("%s", ErrMsgFromConnDo)
})
},
},
@@ -534,7 +533,7 @@ func getTestCases() []startVisitTestArgs {
path: "test",
want: 10,
},
- init: func(args startVisitArgs) *Patches {
+ init: func(args startVisitArgs) *gomonkey.Patches {
return gomonkey.ApplyFunc(redisDial, func() (redigo.Conn, error) {
return conn, nil
})
@@ -546,11 +545,11 @@ func getTestCases() []startVisitTestArgs {
path: "test",
},
wantErr: true,
- errMsg: fmt.Errorf(ErrMsgFromRedisDial),
- init: func(args startVisitArgs) *Patches {
+ errMsg: fmt.Errorf("%s", ErrMsgFromRedisDial),
+ init: func(args startVisitArgs) *gomonkey.Patches {
conn.Command("SETEX", args.path, int(math.Ceil(time.Second.Seconds())), 1).Expect(args.want)
return gomonkey.ApplyFunc(redisDial, func() (redigo.Conn, error) {
- return nil, fmt.Errorf(ErrMsgFromRedisDial)
+ return nil, fmt.Errorf("%s", ErrMsgFromRedisDial)
})
},
},
diff --git a/pkg/utl/resultwrapper/error.go b/pkg/utl/resultwrapper/error.go
index 75af043f..6ece2f5f 100644
--- a/pkg/utl/resultwrapper/error.go
+++ b/pkg/utl/resultwrapper/error.go
@@ -78,7 +78,7 @@ func WrapperFromMessage(errorCode int, c echo.Context, err string) error {
if e1 != nil {
return e1
}
- return fmt.Errorf(errMessage)
+ return fmt.Errorf("%s", errMessage)
}
// InternalServerError ...
@@ -152,7 +152,7 @@ func ServiceUnavailable(c echo.Context, err error) error {
func HandleGraphQLError(errMsg string) graphql2.ResponseHandler {
return func(ctx context.Context) *graphql2.Response {
return &graphql2.Response{
- Errors: gqlerror.List{gqlerror.Errorf(errMsg)},
+ Errors: gqlerror.List{gqlerror.Errorf("%s", errMsg)},
}
}
}
@@ -196,5 +196,5 @@ func ResolverWrapperFromMessage(errorCode int, err string) error {
if e1 != nil {
return e1
}
- return fmt.Errorf(errMessage)
+ return fmt.Errorf("%s", errMessage)
}
diff --git a/pkg/utl/resultwrapper/error_test.go b/pkg/utl/resultwrapper/error_test.go
index f707b3cd..2a1cfb3f 100644
--- a/pkg/utl/resultwrapper/error_test.go
+++ b/pkg/utl/resultwrapper/error_test.go
@@ -121,7 +121,7 @@ func TestResultWrapper(t *testing.T) {
name: ErrorCase,
args: args{
errorCode: 400,
- err: fmt.Errorf(ErrMsgJSON),
+ err: fmt.Errorf("%s", ErrMsgJSON),
},
wantErr: true,
},
@@ -132,7 +132,7 @@ func TestResultWrapper(t *testing.T) {
ctx := e.NewContext(req, w)
if tt.name == ErrorCase {
patch := gomonkey.ApplyMethodFunc(ctx, "JSON", func(code int, i interface{}) error {
- return fmt.Errorf(ErrMsgJSON)
+ return fmt.Errorf("%s", ErrMsgJSON)
})
defer patch.Reset()
}
@@ -162,7 +162,7 @@ func TestInternalServerError(t *testing.T) {
name: SuccessCase,
err: ErrMsg,
args: args{
- err: fmt.Errorf(ErrMsg),
+ err: fmt.Errorf("%s", ErrMsg),
c: getContext()},
wantErr: true,
},
@@ -198,7 +198,7 @@ func TestInternalServerErrorFromMessage(t *testing.T) {
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
err := resultwrapper.InternalServerErrorFromMessage(tt.args.c, tt.args.err)
- assert.Equal(t, err, fmt.Errorf(tt.args.err))
+ assert.Equal(t, err, fmt.Errorf("%s", tt.args.err))
assert.Equal(t, http.StatusInternalServerError, tt.args.c.Response().Status)
})
}
@@ -220,7 +220,7 @@ func TestBadRequest(t *testing.T) {
name: SuccessCase,
err: errorStr,
args: args{
- err: fmt.Errorf(errorStr),
+ err: fmt.Errorf("%s", errorStr),
c: getContext()},
wantErr: true,
},
@@ -256,7 +256,7 @@ func TestBadRequestFromMessage(t *testing.T) {
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
err := resultwrapper.BadRequestFromMessage(tt.args.c, tt.args.err)
- assert.Equal(t, err, fmt.Errorf(tt.args.err))
+ assert.Equal(t, err, fmt.Errorf("%s", tt.args.err))
assert.Equal(t, http.StatusBadRequest, tt.args.c.Response().Status)
})
}
@@ -278,7 +278,7 @@ func TestConflict(t *testing.T) {
name: SuccessCase,
err: errorStr,
args: args{
- err: fmt.Errorf(errorStr),
+ err: fmt.Errorf("%s", errorStr),
c: getContext()},
wantErr: true,
},
@@ -314,7 +314,7 @@ func TestConflictFromMessage(t *testing.T) {
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
err := resultwrapper.ConflictFromMessage(tt.args.c, tt.args.err)
- assert.Equal(t, err, fmt.Errorf(tt.args.err))
+ assert.Equal(t, err, fmt.Errorf("%s", tt.args.err))
assert.Equal(t, http.StatusConflict, tt.args.c.Response().Status)
})
}
@@ -336,7 +336,7 @@ func TestTooManyRequests(t *testing.T) {
name: SuccessCase,
err: errorStr,
args: args{
- err: fmt.Errorf(errorStr),
+ err: fmt.Errorf("%s", errorStr),
c: getContext()},
wantErr: true,
},
@@ -366,7 +366,7 @@ func TestUnauthorized(t *testing.T) {
name: SuccessCase,
err: errorStr,
args: args{
- err: fmt.Errorf(errorStr),
+ err: fmt.Errorf("%s", errorStr),
c: getContext()},
wantErr: true,
},
@@ -402,7 +402,7 @@ func TestUnauthorizedFromMessage(t *testing.T) {
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
err := resultwrapper.UnauthorizedFromMessage(tt.args.c, tt.args.err)
- assert.Equal(t, err, fmt.Errorf(tt.args.err))
+ assert.Equal(t, err, fmt.Errorf("%s", tt.args.err))
assert.Equal(t, http.StatusUnauthorized, tt.args.c.Response().Status)
})
}
@@ -591,7 +591,7 @@ func TestResolverSQLError(t *testing.T) {
if tt.dontAddDetail {
errorMessage = tt.errMsg
}
- assert.Equal(t, fmt.Errorf(errorMessage), err)
+ assert.Equal(t, fmt.Errorf("%s", errorMessage), err)
})
}
}
diff --git a/pkg/utl/zaplog/zaplog_test.go b/pkg/utl/zaplog/zaplog_test.go
index fa6e5b97..06f9a591 100644
--- a/pkg/utl/zaplog/zaplog_test.go
+++ b/pkg/utl/zaplog/zaplog_test.go
@@ -131,7 +131,7 @@ func TestInitLogger(t *testing.T) {
patchProduction := gomonkey.ApplyFunc(zap.NewProduction, func(options ...zap.Option) (*zap.Logger, error) {
if tt.panicErr {
- return &mockZapLog, fmt.Errorf(ErrMsgProduction)
+ return &mockZapLog, fmt.Errorf("%s", ErrMsgProduction)
} else {
return &mockZapLog, nil
}
diff --git a/resolver/auth_mutations.resolvers_test.go b/resolver/auth_mutations.resolvers_test.go
index 158db45d..dcd0af79 100644
--- a/resolver/auth_mutations.resolvers_test.go
+++ b/resolver/auth_mutations.resolvers_test.go
@@ -83,11 +83,11 @@ func errorFindingUserCase() loginType {
Password: TestPassword,
},
wantErr: true,
- err: fmt.Errorf(ErrorMsgFindingUser),
+ err: fmt.Errorf("%s", ErrorMsgFindingUser),
init: func() *gomonkey.Patches {
return gomonkey.ApplyFunc(daos.FindUserByUserName,
func(username string, ctx context.Context) (*models.User, error) {
- return nil, fmt.Errorf(ErrorMsgFindingUser)
+ return nil, fmt.Errorf("%s", ErrorMsgFindingUser)
})
},
}
@@ -100,7 +100,7 @@ func errorPasswordValidationCase() loginType {
Password: TestPassword,
},
wantErr: true,
- err: fmt.Errorf(ErrorMsgPasswordValidation),
+ err: fmt.Errorf("%s", ErrorMsgPasswordValidation),
init: func() *gomonkey.Patches {
tg := jwt.Service{}
sec := secure.Service{}
@@ -117,7 +117,7 @@ func errorPasswordValidationCase() loginType {
user.Active = null.BoolFrom(false)
return user, nil
}).ApplyFunc(tg.GenerateToken, func(u *models.User) (string, error) {
- return "", fmt.Errorf(ErrorMsgPasswordValidation)
+ return "", fmt.Errorf("%s", ErrorMsgPasswordValidation)
})
},
}
@@ -164,7 +164,7 @@ func errorFromConfigCase() loginType {
Password: OldPassword,
},
wantErr: true,
- err: fmt.Errorf(ErrorMsgFromConfig),
+ err: fmt.Errorf("%s", ErrorMsgFromConfig),
init: func() *gomonkey.Patches {
return gomonkey.ApplyFunc(daos.FindUserByUserName,
func(username string, ctx context.Context) (*models.User, error) {
@@ -188,7 +188,7 @@ func errorWhileGeneratingToken() loginType {
Password: OldPassword,
},
wantErr: true,
- err: fmt.Errorf(ErrorMsgFromJwt),
+ err: fmt.Errorf("%s", ErrorMsgFromJwt),
init: func() *gomonkey.Patches {
tg := jwt.Service{}
sec := secure.Service{}
@@ -208,13 +208,13 @@ func errorWhileGeneratingToken() loginType {
}).ApplyMethod(reflect.TypeOf(sec), "HashMatchesPassword", func(sec secure.Service, hash string, password string) bool {
return true
}).ApplyFunc(service.JWT, func(cfg *config.Configuration) (jwt.Service, error) {
- return tg, fmt.Errorf(ErrorMsgFromJwt)
+ return tg, fmt.Errorf("%s", ErrorMsgFromJwt)
})
},
}
}
func errorUpdateUserCase() loginType {
- err := fmt.Errorf(ErrorMsgfromUpdateUser)
+ err := fmt.Errorf("%s", ErrorMsgfromUpdateUser)
return loginType{
name: ErrorUpdateUser,
req: loginArgs{
@@ -403,7 +403,7 @@ func changePasswordErrorFindingUserCase() changePasswordType {
init: func() *gomonkey.Patches {
return gomonkey.ApplyFunc(daos.FindUserByID,
func(userID int, ctx context.Context) (*models.User, error) {
- return nil, fmt.Errorf(ErrorMsgFindingUser)
+ return nil, fmt.Errorf("%s", ErrorMsgFindingUser)
})
},
}
@@ -421,7 +421,7 @@ func changePasswordErrorPasswordValidationcase() changePasswordType {
sec := secure.Service{}
return gomonkey.ApplyFunc(daos.FindUserByID,
func(userID int, ctx context.Context) (*models.User, error) {
- return nil, fmt.Errorf(ErrorMsgFindingUser)
+ return nil, fmt.Errorf("%s", ErrorMsgFindingUser)
}).ApplyMethod(reflect.TypeOf(sec), "HashMatchesPassword",
func(sec secure.Service, hash string, password string) bool {
return false
@@ -472,10 +472,10 @@ func changePasswordErrorUpdateUserCase() changePasswordType {
user := testutls.MockUser()
user.Password = null.StringFrom(OldPasswordHash)
user.Active = null.BoolFrom(false)
- return user, fmt.Errorf(ErrorInsecurePassword)
+ return user, fmt.Errorf("%s", ErrorInsecurePassword)
}).ApplyFunc(daos.UpdateUser,
func(user models.User, ctx context.Context) (*models.User, error) {
- return nil, fmt.Errorf(ErrorUpdateUser)
+ return nil, fmt.Errorf("%s", ErrorUpdateUser)
})
},
}
@@ -592,7 +592,7 @@ func refreshTokenInvalidCase() refereshTokenType {
name: ErrorInvalidToken,
req: TestToken,
wantErr: true,
- err: fmt.Errorf(ErrorMsginvalidToken),
+ err: fmt.Errorf("%s", ErrorMsginvalidToken),
init: func() *gomonkey.Patches {
tg := jwt.Service{}
return gomonkey.ApplyFunc(config.Load, func() (*config.Configuration, error) {
@@ -601,7 +601,7 @@ func refreshTokenInvalidCase() refereshTokenType {
return tg, nil
}).ApplyMethod(reflect.TypeOf(tg), "GenerateToken",
func(jwt.Service, *models.User) (string, error) {
- return "", fmt.Errorf(ErrorMsginvalidToken)
+ return "", fmt.Errorf("%s", ErrorMsginvalidToken)
}).ApplyFunc(daos.FindUserByToken, func(token string, ctx context.Context) (*models.User, error) {
return testutls.MockUser(), nil
})
@@ -613,10 +613,10 @@ func refreshTokenErrorFromConfigCase() refereshTokenType {
name: ErrorFromConfig,
req: ReqToken,
wantErr: true,
- err: fmt.Errorf(ErrorMsgFromConfig),
+ err: fmt.Errorf("%s", ErrorMsgFromConfig),
init: func() *gomonkey.Patches {
return gomonkey.ApplyFunc(config.Load, func() (*config.Configuration, error) {
- return nil, fmt.Errorf(ErrorFromConfig)
+ return nil, fmt.Errorf("%s", ErrorFromConfig)
}).ApplyFunc(daos.FindUserByToken, func(token string, ctx context.Context) (*models.User, error) {
return testutls.MockUser(), nil
})
@@ -629,13 +629,13 @@ func refereshTokenerrorWhileGeneratingToken() refereshTokenType {
name: ErrorFromJwt,
req: ReqToken,
wantErr: true,
- err: fmt.Errorf(ErrorMsgFromJwt),
+ err: fmt.Errorf("%s", ErrorMsgFromJwt),
init: func() *gomonkey.Patches {
tg := jwt.Service{}
return gomonkey.ApplyFunc(config.Load, func() (*config.Configuration, error) {
return nil, nil
}).ApplyFunc(service.JWT, func(cfg *config.Configuration) (jwt.Service, error) {
- return tg, fmt.Errorf(ErrorMsgFromJwt)
+ return tg, fmt.Errorf("%s", ErrorMsgFromJwt)
}).ApplyFunc(daos.FindUserByToken, func(token string, ctx context.Context) (*models.User, error) {
return testutls.MockUser(), nil
})
@@ -648,7 +648,7 @@ func refereshTokenErrorFromGenerateTokenCase() refereshTokenType {
name: ErrorFromGenerateToken,
req: ReqToken,
wantErr: true,
- err: fmt.Errorf(ErrorFromGenerateToken),
+ err: fmt.Errorf("%s", ErrorFromGenerateToken),
init: func() *gomonkey.Patches {
tg := jwt.Service{}
return gomonkey.ApplyFunc(config.Load, func() (*config.Configuration, error) {
@@ -657,7 +657,7 @@ func refereshTokenErrorFromGenerateTokenCase() refereshTokenType {
return tg, nil
}).ApplyMethod(reflect.TypeOf(tg), "GenerateToken",
func(jwt.Service, *models.User) (string, error) {
- return "", fmt.Errorf(ErrorFromGenerateToken)
+ return "", fmt.Errorf("%s", ErrorFromGenerateToken)
}).ApplyFunc(daos.FindUserByToken, func(token string, ctx context.Context) (*models.User, error) {
return testutls.MockUser(), nil
})