Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Downgrade go pg #374

Merged
merged 24 commits into from
Aug 26, 2024
Merged
Show file tree
Hide file tree
Changes from 20 commits
Commits
Show all changes
24 commits
Select commit Hold shift + click to select a range
3758b3d
downgrade go-pg from v10 to v6.14.5
Aug 23, 2024
21fe0b2
update modules.txt
Aug 23, 2024
fd03501
fix linting
Aug 23, 2024
75e4545
update golang CI version from 1.21.3 to 1.21.12 to fix some vulnarabi…
Aug 23, 2024
d257391
update golang.org/x/net from v0.20.0 to 0.23.0 to fix a vulnarability
Aug 23, 2024
6ca68f8
add installation of docker-compose to golang-ci.yml
Aug 23, 2024
ecdba7e
go back to docker/login-action v1 in golang-ci.yml
Aug 23, 2024
57afc4c
actually run the integration tests
Aug 23, 2024
6f82328
DEBUG skip the livetest
Aug 23, 2024
4898219
call integration in the ci Makefile command
Aug 23, 2024
7977e66
revert: call integration in the ci Makefile command
Aug 23, 2024
7c4e94d
increase wait time in integration test
Aug 23, 2024
ca950ea
increase wait time in integration test
Aug 23, 2024
566b3be
DEBUG add assertions
Aug 23, 2024
a23c40d
DEBUG adjust durations in test
Aug 23, 2024
864f9e8
DEBUG remove assertion for no error
Aug 23, 2024
97ab8d9
add coverage related flags to make test
Aug 23, 2024
3f72b08
don't skip one specific integration test anymore
Aug 23, 2024
c5c7aa7
go back to v3 of docker/login-action
Aug 23, 2024
4d2da8c
add linting step to CI
Aug 23, 2024
fb2bd81
execute gofumpt on the whole project
Aug 26, 2024
a9e8326
Revert "execute gofumpt on the whole project"
Aug 26, 2024
73d226b
execute gofumpt on the whole project - without generated files that m…
Aug 26, 2024
effb66d
add .golangci.yml that only - for now - applies the gofumpt linter
Aug 26, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
10 changes: 8 additions & 2 deletions .github/workflows/golang-ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ jobs:
strategy:
fail-fast: false
matrix:
go: [ '1.21.3' ]
go: [ '1.21.12' ]
steps:
- uses: actions/checkout@v2
- uses: actions/setup-go@v2
Expand All @@ -17,12 +17,18 @@ jobs:
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Linting
run: make lint
- name: Unit tests
run: make test
- name: (Experimental) Vulnerability Scan
run: make vuln-scan
- name: Install Docker Compose
run: |
sudo apt-get update
sudo apt-get install -y docker-compose
- name: Integration tests
run: docker-compose run testserver make ci
run: docker-compose run testserver make integration
- name: Send coverage
uses: shogo82148/actions-goveralls@v1
with:
Expand Down
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@ lint:
$(GO) run -mod=vendor github.com/golangci/golangci-lint/cmd/golangci-lint run --timeout 2m

test:
$(GO) test $(GO_TEST_FLAGS) -short ./...
$(GO) test $(GO_TEST_FLAGS) -covermode=atomic -coverprofile=coverage.out -short ./...

integration:
$(GO) test $(GO_TEST_FLAGS) -run TestIntegration ./...
Expand Down
2 changes: 1 addition & 1 deletion backend/postgres/errors.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import (
"io"
"net"

"github.com/go-pg/pg/v10"
"github.com/go-pg/pg"
)

var (
Expand Down
2 changes: 1 addition & 1 deletion backend/postgres/errors_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import (
"io"
"testing"

"github.com/go-pg/pg/v10"
"github.com/go-pg/pg"
"github.com/stretchr/testify/require"

pbpostgres "github.com/pace/bricks/backend/postgres"
Expand Down
2 changes: 1 addition & 1 deletion backend/postgres/health_postgres.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import (
"context"
"time"

"github.com/go-pg/pg/v10/orm"
"github.com/go-pg/pg/orm"
"github.com/pace/bricks/maintenance/health/servicehealthcheck"
)

Expand Down
2 changes: 1 addition & 1 deletion backend/postgres/health_postgres_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import (
"testing"
"time"

"github.com/go-pg/pg/v10/orm"
"github.com/go-pg/pg/orm"
http2 "github.com/pace/bricks/http"
"github.com/pace/bricks/maintenance/errors"
"github.com/pace/bricks/maintenance/health/servicehealthcheck"
Expand Down
136 changes: 0 additions & 136 deletions backend/postgres/hooks.go

This file was deleted.

2 changes: 1 addition & 1 deletion backend/postgres/metrics.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import (
"sync"
"time"

"github.com/go-pg/pg/v10"
"github.com/go-pg/pg"
"github.com/prometheus/client_golang/prometheus"
)

Expand Down
117 changes: 113 additions & 4 deletions backend/postgres/postgres.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,10 @@ package postgres
import (
"context"
"fmt"
"github.com/opentracing/opentracing-go"
srieckhof marked this conversation as resolved.
Show resolved Hide resolved
olog "github.com/opentracing/opentracing-go/log"
"github.com/rs/zerolog"
"math"
"os"
"path/filepath"
"regexp"
Expand All @@ -14,7 +18,7 @@ import (
"time"

"github.com/caarlos0/env/v10"
"github.com/go-pg/pg/v10"
"github.com/go-pg/pg"
"github.com/prometheus/client_golang/prometheus"

"github.com/pace/bricks/maintenance/health/servicehealthcheck"
Expand Down Expand Up @@ -229,13 +233,15 @@ func CustomConnectionPool(opts *pg.Options) *pg.DB {
Msg("PostgreSQL connection pool created")
db := pg.Connect(opts)
if cfg.LogWrite || cfg.LogRead {
db.AddQueryHook(QueryLogger{})
db.OnQueryProcessed(queryLogger)
} else {
log.Logger().Warn().Msg("Connection pool has logging queries disabled completely")
}

db.AddQueryHook(OpenTracingAdapter{})
db.AddQueryHook(MetricsAdapter{opts})
db.OnQueryProcessed(openTracingAdapter)
db.OnQueryProcessed(func(event *pg.QueryProcessedEvent) {
metricsAdapter(event, opts)
})

return db
}
Expand All @@ -256,6 +262,57 @@ func determineQueryMode(qry string) queryMode {
return writeMode
}

func queryLogger(event *pg.QueryProcessedEvent) {
q, qe := event.UnformattedQuery()
if qe == nil {
if !(cfg.LogRead || cfg.LogWrite) {
return
}
// we can only and should only perfom the following check if we have the information availaible
mode := determineQueryMode(q)
if mode == readMode && !cfg.LogRead {
return
}
if mode == writeMode && !cfg.LogWrite {
return
}

}
ctx := event.DB.Context()
dur := float64(time.Since(event.StartTime)) / float64(time.Millisecond)

// check if log context is given
var logger *zerolog.Logger
if ctx != nil {
logger = log.Ctx(ctx)
} else {
logger = log.Logger()
}

// add general info
le := logger.Debug().
Str("file", event.File).
Int("line", event.Line).
Str("func", event.Func).
Int("attempt", event.Attempt).
Float64("duration", dur).
Str("sentry:category", "postgres")

// add error or result set info
if event.Error != nil {
le = le.Err(event.Error)
} else {
le = le.Int("affected", event.Result.RowsAffected()).
Int("rows", event.Result.RowsReturned())
}

if qe != nil {
// this is only a display issue not a "real" issue
le.Msgf("%v", qe)
}
le.Msg(q)
}

var reQueryType = regexp.MustCompile(`(\s)`)
var reQueryTypeCleanup = regexp.MustCompile(`(?m)(\s+|\n)`)

Expand All @@ -269,3 +326,55 @@ func getQueryType(s string) string {
}
return strings.ToUpper(s)
}

func openTracingAdapter(event *pg.QueryProcessedEvent) {
// start span with general info
q, qe := event.UnformattedQuery()
if qe != nil {
// this is only a display issue not a "real" issue
q = qe.Error()
}

span, _ := opentracing.StartSpanFromContext(event.DB.Context(), "sql: "+getQueryType(q),
opentracing.StartTime(event.StartTime))

span.SetTag("db.system", "postgres")

fields := []olog.Field{
olog.String("file", event.File),
olog.Int("line", event.Line),
olog.String("func", event.Func),
olog.Int("attempt", event.Attempt),
olog.String("query", q),
}

// add error or result set info
if event.Error != nil {
fields = append(fields, olog.Error(event.Error))
} else {
fields = append(fields,
olog.Int("affected", event.Result.RowsAffected()),
olog.Int("rows", event.Result.RowsReturned()))
}

span.LogFields(fields...)
span.Finish()
}

func metricsAdapter(event *pg.QueryProcessedEvent, opts *pg.Options) {
dur := float64(time.Since(event.StartTime)) / float64(time.Millisecond)
labels := prometheus.Labels{
"database": opts.Addr + "/" + opts.Database,
}

metricQueryTotal.With(labels).Inc()

if event.Error != nil {
metricQueryFailed.With(labels).Inc()
} else {
r := event.Result
metricQueryRowsTotal.With(labels).Add(float64(r.RowsReturned()))
metricQueryAffectedTotal.With(labels).Add(math.Max(0, float64(r.RowsAffected())))
}
metricQueryDurationSeconds.With(labels).Observe(dur)
}
4 changes: 2 additions & 2 deletions backend/postgres/query_ctx.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,8 @@ package postgres
import (
"context"

"github.com/go-pg/pg/v10"
"github.com/go-pg/pg/v10/orm"
"github.com/go-pg/pg"
"github.com/go-pg/pg/orm"
)

type pgPoolAdapter struct {
Expand Down
2 changes: 1 addition & 1 deletion backend/redis/redis.go
Original file line number Diff line number Diff line change
Expand Up @@ -183,7 +183,7 @@ func (lt *logtracer) ProcessHook(next redis.ProcessHook) redis.ProcessHook {
span: span,
})

next(ctx, cmd)
_ = next(ctx, cmd)

vals := ctx.Value(logtracerKey{}).(*logtracerValues)
le := log.Ctx(ctx).Debug().Str("cmd", cmd.Name()).Str("sentry:category", "redis")
Expand Down
Loading
Loading