1
0
mirror of https://github.com/go-micro/go-micro.git synced 2025-06-30 22:33:49 +02:00

Plugins and profiles (#2764)

* feat: more plugins

* chore(ci): split out benchmarks

Attempt to resolve too many open files in ci

* chore(ci): split out benchmarks

* fix(ci): Attempt to resolve too many open files in ci

* fix: set DefaultX for cli flag and service option

* fix: restore http broker

* fix: default http broker

* feat: full nats profile

* chore: still ugly, not ready

* fix: better initialization for profiles

* fix(tests): comment out flaky listen tests

* fix: disable benchmarks on gha

* chore: cleanup, comments

* chore: add nats config source
This commit is contained in:
Brian Ketelsen
2025-05-20 13:24:06 -04:00
committed by GitHub
parent e12504ce3a
commit ddc34801ee
58 changed files with 6792 additions and 218 deletions

View File

@ -0,0 +1,139 @@
//go:build integration
// +build integration
package pgx
import (
"encoding/json"
"testing"
"github.com/stretchr/testify/assert"
"go-micro.dev/v5/store"
)
type testObj struct {
One string
Two int64
}
func TestPostgres(t *testing.T) {
t.Run("ReadWrite", func(t *testing.T) {
s := NewStore(store.Nodes("postgresql://postgres@localhost:5432/?sslmode=disable"))
b, _ := json.Marshal(testObj{
One: "1",
Two: 2,
})
err := s.Write(&store.Record{
Key: "foobar/baz",
Value: b,
Metadata: map[string]interface{}{
"meta1": "val1",
},
})
assert.NoError(t, err)
recs, err := s.Read("foobar/baz")
assert.NoError(t, err)
assert.Len(t, recs, 1)
assert.Equal(t, "foobar/baz", recs[0].Key)
assert.Len(t, recs[0].Metadata, 1)
assert.Equal(t, "val1", recs[0].Metadata["meta1"])
var tobj testObj
assert.NoError(t, json.Unmarshal(recs[0].Value, &tobj))
assert.Equal(t, "1", tobj.One)
assert.Equal(t, int64(2), tobj.Two)
})
t.Run("Prefix", func(t *testing.T) {
s := NewStore(store.Nodes("postgresql://postgres@localhost:5432/?sslmode=disable"))
b, _ := json.Marshal(testObj{
One: "1",
Two: 2,
})
err := s.Write(&store.Record{
Key: "foo/bar",
Value: b,
Metadata: map[string]interface{}{
"meta1": "val1",
},
})
assert.NoError(t, err)
err = s.Write(&store.Record{
Key: "foo/baz",
Value: b,
Metadata: map[string]interface{}{
"meta1": "val1",
},
})
assert.NoError(t, err)
recs, err := s.Read("foo/", store.ReadPrefix())
assert.NoError(t, err)
assert.Len(t, recs, 2)
assert.Equal(t, "foo/bar", recs[0].Key)
assert.Equal(t, "foo/baz", recs[1].Key)
})
t.Run("MultipleTables", func(t *testing.T) {
s1 := NewStore(store.Nodes("postgresql://postgres@localhost:5432/?sslmode=disable"), store.Table("t1"))
s2 := NewStore(store.Nodes("postgresql://postgres@localhost:5432/?sslmode=disable"), store.Table("t2"))
b1, _ := json.Marshal(testObj{
One: "1",
Two: 2,
})
err := s1.Write(&store.Record{
Key: "foo/bar",
Value: b1,
})
assert.NoError(t, err)
b2, _ := json.Marshal(testObj{
One: "1",
Two: 2,
})
err = s2.Write(&store.Record{
Key: "foo/baz",
Value: b2,
})
assert.NoError(t, err)
recs1, err := s1.List()
assert.NoError(t, err)
assert.Len(t, recs1, 1)
assert.Equal(t, "foo/bar", recs1[0])
recs2, err := s2.List()
assert.NoError(t, err)
assert.Len(t, recs2, 1)
assert.Equal(t, "foo/baz", recs2[0])
})
t.Run("MultipleDBs", func(t *testing.T) {
s1 := NewStore(store.Nodes("postgresql://postgres@localhost:5432/?sslmode=disable"), store.Database("d1"))
s2 := NewStore(store.Nodes("postgresql://postgres@localhost:5432/?sslmode=disable"), store.Database("d2"))
b1, _ := json.Marshal(testObj{
One: "1",
Two: 2,
})
err := s1.Write(&store.Record{
Key: "foo/bar",
Value: b1,
})
assert.NoError(t, err)
b2, _ := json.Marshal(testObj{
One: "1",
Two: 2,
})
err = s2.Write(&store.Record{
Key: "foo/baz",
Value: b2,
})
assert.NoError(t, err)
recs1, err := s1.List()
assert.NoError(t, err)
assert.Len(t, recs1, 1)
assert.Equal(t, "foo/bar", recs1[0])
recs2, err := s2.List()
assert.NoError(t, err)
assert.Len(t, recs2, 1)
assert.Equal(t, "foo/baz", recs2[0])
})
}