Skip to content

Commit

Permalink
fix: linter errors
Browse files Browse the repository at this point in the history
  • Loading branch information
Paras-Wednesday committed Sep 26, 2024
1 parent 56cdd96 commit 5aba242
Show file tree
Hide file tree
Showing 7 changed files with 127 additions and 138 deletions.
105 changes: 48 additions & 57 deletions README.MD
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,6 @@ An enterprise go template application showcasing - Testing strategies, middlewar
</p>
___


<p>
<h4>
Expert teams of digital product strategists, developers, and designers.
Expand All @@ -28,23 +27,17 @@ An enterprise go template application showcasing - Testing strategies, middlewar
<img src="https://uploads-ssl.webflow.com/5ee36ce1473112550f1e1739/5f6ae88bb1958c3253756c39_button_follow_on_github.svg" width="168" height="34">
</a>
</div>

___
---

<span>We’re always looking for people who value their work, so come and join
us. <a href="https://www.wednesday.is/hiring/?utm_source=github&utm_medium=go-template">We are hiring!</a></span>


</div>

---

<br/>





The Go Template is a template/starter go project.

## Out of the box support for
Expand Down Expand Up @@ -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`.

Expand All @@ -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

Expand All @@ -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 <name>
```

To add new migration use following, it creates a new empty migration template with pattern `<current time>-<name>.sql`

```
```bash
sql-migrate new -env postgres <name>
```

Expand Down Expand Up @@ -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
Expand All @@ -220,16 +213,17 @@ go-template/

generate your database models

```
```bash
sqlboiler psql --no-hooks
```

# Seed your Database

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
Expand All @@ -238,33 +232,33 @@ 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

- Schema can generated or altered manually

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

Expand All @@ -279,75 +273,72 @@ 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
```

Please change the ENV_INJECTION variable as true in .env.base file to true, so it will not try to find a local .env file

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
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
```

## Testing

Get test coverage using

```
```bash
go test -cover
```

## Generate mocks

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
```

Expand Down
13 changes: 6 additions & 7 deletions pkg/utl/rediscache/redis_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -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"
)
Expand Down Expand Up @@ -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
})
}
Expand Down Expand Up @@ -92,21 +91,21 @@ 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 {
t.Run(tt.name, func(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()
}
Expand Down Expand Up @@ -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")
})
}
Expand Down
Loading

0 comments on commit 5aba242

Please sign in to comment.