mirror of
https://github.com/jwetzell/showbridge-go.git
synced 2026-04-26 21:05:30 +00:00
add tests for correct module type from processors context
This commit is contained in:
@@ -38,7 +38,7 @@ func TestDbQueryFromRegistry(t *testing.T) {
|
|||||||
got, err := processorInstance.Process(t.Context(), common.GetWrappedPayload(GetContextWithModules(
|
got, err := processorInstance.Process(t.Context(), common.GetWrappedPayload(GetContextWithModules(
|
||||||
t.Context(),
|
t.Context(),
|
||||||
map[string]common.Module{
|
map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": NewTestDBModule("test"),
|
||||||
},
|
},
|
||||||
), payload))
|
), payload))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -108,7 +108,7 @@ func TestGoodDbQuery(t *testing.T) {
|
|||||||
got, err := processorInstance.Process(t.Context(), common.GetWrappedPayload(GetContextWithModules(
|
got, err := processorInstance.Process(t.Context(), common.GetWrappedPayload(GetContextWithModules(
|
||||||
t.Context(),
|
t.Context(),
|
||||||
map[string]common.Module{
|
map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": NewTestDBModule("test"),
|
||||||
},
|
},
|
||||||
), test.payload))
|
), test.payload))
|
||||||
|
|
||||||
@@ -138,7 +138,7 @@ func TestBadDbQuery(t *testing.T) {
|
|||||||
"query": "SELECT sqlite_version();",
|
"query": "SELECT sqlite_version();",
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": NewTestDBModule("test"),
|
||||||
}),
|
}),
|
||||||
errorString: "db.query module error: not found",
|
errorString: "db.query module error: not found",
|
||||||
},
|
},
|
||||||
@@ -150,7 +150,7 @@ func TestBadDbQuery(t *testing.T) {
|
|||||||
"query": "SELECT sqlite_version();",
|
"query": "SELECT sqlite_version();",
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": NewTestDBModule("test"),
|
||||||
}),
|
}),
|
||||||
errorString: "db.query module error: not a string",
|
errorString: "db.query module error: not a string",
|
||||||
},
|
},
|
||||||
@@ -161,7 +161,7 @@ func TestBadDbQuery(t *testing.T) {
|
|||||||
"module": "test",
|
"module": "test",
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": NewTestDBModule("test"),
|
||||||
}),
|
}),
|
||||||
errorString: "db.query query error: not found",
|
errorString: "db.query query error: not found",
|
||||||
},
|
},
|
||||||
@@ -173,7 +173,7 @@ func TestBadDbQuery(t *testing.T) {
|
|||||||
"query": 1,
|
"query": 1,
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": NewTestDBModule("test"),
|
||||||
}),
|
}),
|
||||||
errorString: "db.query query error: not a string",
|
errorString: "db.query query error: not a string",
|
||||||
},
|
},
|
||||||
@@ -185,7 +185,7 @@ func TestBadDbQuery(t *testing.T) {
|
|||||||
"query": "select * from {{",
|
"query": "select * from {{",
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": NewTestDBModule("test"),
|
||||||
}),
|
}),
|
||||||
errorString: "template: query:1: unclosed action",
|
errorString: "template: query:1: unclosed action",
|
||||||
},
|
},
|
||||||
@@ -197,7 +197,7 @@ func TestBadDbQuery(t *testing.T) {
|
|||||||
"query": "select * from {{.Data}}",
|
"query": "select * from {{.Data}}",
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": NewTestDBModule("test"),
|
||||||
}),
|
}),
|
||||||
errorString: "template: query:1:16: executing \"query\" at <.Data>: can't evaluate field Data in type common.WrappedPayload",
|
errorString: "template: query:1:16: executing \"query\" at <.Data>: can't evaluate field Data in type common.WrappedPayload",
|
||||||
},
|
},
|
||||||
@@ -209,7 +209,7 @@ func TestBadDbQuery(t *testing.T) {
|
|||||||
"query": "select * from asdf;",
|
"query": "select * from asdf;",
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": NewTestDBModule("test"),
|
||||||
}),
|
}),
|
||||||
errorString: "db.query error executing query: SQL logic error: no such table: asdf (1)",
|
errorString: "db.query error executing query: SQL logic error: no such table: asdf (1)",
|
||||||
},
|
},
|
||||||
@@ -233,6 +233,28 @@ func TestBadDbQuery(t *testing.T) {
|
|||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{}),
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{}),
|
||||||
errorString: "db.query unable to find module with id: test",
|
errorString: "db.query unable to find module with id: test",
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: "module not found in context",
|
||||||
|
payload: TestStruct{Data: "hello"},
|
||||||
|
params: map[string]any{
|
||||||
|
"module": "test",
|
||||||
|
"query": "select * from test;",
|
||||||
|
},
|
||||||
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{}),
|
||||||
|
errorString: "db.query unable to find module with id: test",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "module not a DatabseModule",
|
||||||
|
payload: TestStruct{Data: "hello"},
|
||||||
|
params: map[string]any{
|
||||||
|
"module": "test",
|
||||||
|
"query": "select * from test;",
|
||||||
|
},
|
||||||
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
|
"test": NewTestKVModule("test"),
|
||||||
|
}),
|
||||||
|
errorString: "db.query module with id test is not a DatabaseModule",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
|
|||||||
@@ -37,7 +37,7 @@ func TestKvGetFromRegistry(t *testing.T) {
|
|||||||
got, err := processorInstance.Process(t.Context(), common.GetWrappedPayload(GetContextWithModules(
|
got, err := processorInstance.Process(t.Context(), common.GetWrappedPayload(GetContextWithModules(
|
||||||
t.Context(),
|
t.Context(),
|
||||||
map[string]common.Module{
|
map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": NewTestKVModule("test"),
|
||||||
},
|
},
|
||||||
), payload))
|
), payload))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -97,7 +97,7 @@ func TestGoodKvGet(t *testing.T) {
|
|||||||
got, err := processorInstance.Process(t.Context(), common.GetWrappedPayload(GetContextWithModules(
|
got, err := processorInstance.Process(t.Context(), common.GetWrappedPayload(GetContextWithModules(
|
||||||
t.Context(),
|
t.Context(),
|
||||||
map[string]common.Module{
|
map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": NewTestKVModule("test"),
|
||||||
},
|
},
|
||||||
), test.payload))
|
), test.payload))
|
||||||
|
|
||||||
@@ -127,7 +127,7 @@ func TestBadKvGet(t *testing.T) {
|
|||||||
"key": "test",
|
"key": "test",
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": NewTestKVModule("test"),
|
||||||
}),
|
}),
|
||||||
errorString: "kv.get module error: not found",
|
errorString: "kv.get module error: not found",
|
||||||
},
|
},
|
||||||
@@ -139,7 +139,7 @@ func TestBadKvGet(t *testing.T) {
|
|||||||
"key": "test",
|
"key": "test",
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": NewTestKVModule("test"),
|
||||||
}),
|
}),
|
||||||
errorString: "kv.get module error: not a string",
|
errorString: "kv.get module error: not a string",
|
||||||
},
|
},
|
||||||
@@ -150,7 +150,7 @@ func TestBadKvGet(t *testing.T) {
|
|||||||
"module": "test",
|
"module": "test",
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": NewTestKVModule("test"),
|
||||||
}),
|
}),
|
||||||
errorString: "kv.get key error: not found",
|
errorString: "kv.get key error: not found",
|
||||||
},
|
},
|
||||||
@@ -162,7 +162,7 @@ func TestBadKvGet(t *testing.T) {
|
|||||||
"key": 1,
|
"key": 1,
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": NewTestKVModule("test"),
|
||||||
}),
|
}),
|
||||||
errorString: "kv.get key error: not a string",
|
errorString: "kv.get key error: not a string",
|
||||||
},
|
},
|
||||||
@@ -186,6 +186,18 @@ func TestBadKvGet(t *testing.T) {
|
|||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{}),
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{}),
|
||||||
errorString: "kv.get unable to find module with id: test",
|
errorString: "kv.get unable to find module with id: test",
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: "module not a kv module",
|
||||||
|
payload: TestStruct{Data: "hello"},
|
||||||
|
params: map[string]any{
|
||||||
|
"module": "test",
|
||||||
|
"key": "test",
|
||||||
|
},
|
||||||
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
|
"test": NewTestDBModule("test"),
|
||||||
|
}),
|
||||||
|
errorString: "kv.get module with id test is not a KeyValueModule",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
|
|||||||
@@ -38,7 +38,7 @@ func TestKvSetFromRegistry(t *testing.T) {
|
|||||||
got, err := processorInstance.Process(t.Context(), common.GetWrappedPayload(GetContextWithModules(
|
got, err := processorInstance.Process(t.Context(), common.GetWrappedPayload(GetContextWithModules(
|
||||||
t.Context(),
|
t.Context(),
|
||||||
map[string]common.Module{
|
map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": &TestKVModule{},
|
||||||
},
|
},
|
||||||
), payload))
|
), payload))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -88,7 +88,7 @@ func TestGoodKvSet(t *testing.T) {
|
|||||||
got, err := processorInstance.Process(t.Context(), common.GetWrappedPayload(GetContextWithModules(
|
got, err := processorInstance.Process(t.Context(), common.GetWrappedPayload(GetContextWithModules(
|
||||||
t.Context(),
|
t.Context(),
|
||||||
map[string]common.Module{
|
map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": &TestKVModule{},
|
||||||
},
|
},
|
||||||
), test.payload))
|
), test.payload))
|
||||||
|
|
||||||
@@ -119,7 +119,7 @@ func TestBadKvSet(t *testing.T) {
|
|||||||
"value": "test",
|
"value": "test",
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": &TestKVModule{},
|
||||||
}),
|
}),
|
||||||
errorString: "kv.set module error: not found",
|
errorString: "kv.set module error: not found",
|
||||||
},
|
},
|
||||||
@@ -132,7 +132,7 @@ func TestBadKvSet(t *testing.T) {
|
|||||||
"value": "test",
|
"value": "test",
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": &TestKVModule{},
|
||||||
}),
|
}),
|
||||||
errorString: "kv.set module error: not a string",
|
errorString: "kv.set module error: not a string",
|
||||||
},
|
},
|
||||||
@@ -144,7 +144,7 @@ func TestBadKvSet(t *testing.T) {
|
|||||||
"value": "test",
|
"value": "test",
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": &TestKVModule{},
|
||||||
}),
|
}),
|
||||||
errorString: "kv.set key error: not found",
|
errorString: "kv.set key error: not found",
|
||||||
},
|
},
|
||||||
@@ -157,7 +157,7 @@ func TestBadKvSet(t *testing.T) {
|
|||||||
"value": "test",
|
"value": "test",
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": &TestKVModule{},
|
||||||
}),
|
}),
|
||||||
errorString: "kv.set key error: not a string",
|
errorString: "kv.set key error: not a string",
|
||||||
},
|
},
|
||||||
@@ -169,7 +169,7 @@ func TestBadKvSet(t *testing.T) {
|
|||||||
"key": "test",
|
"key": "test",
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": &TestKVModule{},
|
||||||
}),
|
}),
|
||||||
errorString: "kv.set value error: not found",
|
errorString: "kv.set value error: not found",
|
||||||
},
|
},
|
||||||
@@ -182,7 +182,7 @@ func TestBadKvSet(t *testing.T) {
|
|||||||
"value": 1,
|
"value": 1,
|
||||||
},
|
},
|
||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
"test": &TestModule{},
|
"test": &TestKVModule{},
|
||||||
}),
|
}),
|
||||||
errorString: "kv.set value error: not a string",
|
errorString: "kv.set value error: not a string",
|
||||||
},
|
},
|
||||||
@@ -197,6 +197,32 @@ func TestBadKvSet(t *testing.T) {
|
|||||||
wrappedPayloadCtx: t.Context(),
|
wrappedPayloadCtx: t.Context(),
|
||||||
errorString: "kv.set wrapped payload has no modules",
|
errorString: "kv.set wrapped payload has no modules",
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: "value template syntax error",
|
||||||
|
payload: TestStruct{Data: "hello"},
|
||||||
|
params: map[string]any{
|
||||||
|
"module": "test",
|
||||||
|
"key": "test",
|
||||||
|
"value": "{{",
|
||||||
|
},
|
||||||
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
|
"test": &TestKVModule{},
|
||||||
|
}),
|
||||||
|
errorString: "template: template:1: unclosed action",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "value template execution error",
|
||||||
|
payload: TestStruct{Data: "hello"},
|
||||||
|
params: map[string]any{
|
||||||
|
"module": "test",
|
||||||
|
"key": "test",
|
||||||
|
"value": "{{.Data}}",
|
||||||
|
},
|
||||||
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
|
"test": &TestKVModule{},
|
||||||
|
}),
|
||||||
|
errorString: "template: template:1:2: executing \"template\" at <.Data>: can't evaluate field Data in type common.WrappedPayload",
|
||||||
|
},
|
||||||
{
|
{
|
||||||
name: "module not found in context",
|
name: "module not found in context",
|
||||||
payload: TestStruct{Data: "hello"},
|
payload: TestStruct{Data: "hello"},
|
||||||
@@ -208,6 +234,19 @@ func TestBadKvSet(t *testing.T) {
|
|||||||
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{}),
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{}),
|
||||||
errorString: "kv.set unable to find module with id: test",
|
errorString: "kv.set unable to find module with id: test",
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: "module not a kv module",
|
||||||
|
payload: TestStruct{Data: "hello"},
|
||||||
|
params: map[string]any{
|
||||||
|
"module": "test",
|
||||||
|
"key": "test",
|
||||||
|
"value": "hello",
|
||||||
|
},
|
||||||
|
wrappedPayloadCtx: GetContextWithModules(t.Context(), map[string]common.Module{
|
||||||
|
"test": NewTestDBModule("test"),
|
||||||
|
}),
|
||||||
|
errorString: "kv.set module with id test is not a KeyValueModule",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
|
|||||||
@@ -59,17 +59,60 @@ func (p *TestProcessor) Process(ctx context.Context, wrappedPayload common.Wrapp
|
|||||||
return wrappedPayload, nil
|
return wrappedPayload, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
type TestModule struct {
|
func NewTestKVModule(id string) *TestKVModule {
|
||||||
kvData map[string]any
|
return &TestKVModule{
|
||||||
db *sql.DB
|
id: id,
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *TestModule) Start(ctx context.Context) error {
|
type TestKVModule struct {
|
||||||
|
id string
|
||||||
|
kvData map[string]any
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *TestKVModule) Start(ctx context.Context) error {
|
||||||
<-ctx.Done()
|
<-ctx.Done()
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *TestModule) Database() *sql.DB {
|
func (m *TestKVModule) Stop() {}
|
||||||
|
|
||||||
|
func (m *TestKVModule) Type() string {
|
||||||
|
return "module.test.kv"
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *TestKVModule) Id() string {
|
||||||
|
return m.id
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *TestKVModule) Get(key string) (any, error) {
|
||||||
|
return key, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *TestKVModule) Set(key string, value any) error {
|
||||||
|
if m.kvData == nil {
|
||||||
|
m.kvData = make(map[string]any)
|
||||||
|
}
|
||||||
|
m.kvData[key] = value
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
func NewTestDBModule(id string) *TestDBModule {
|
||||||
|
return &TestDBModule{
|
||||||
|
id: id,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
type TestDBModule struct {
|
||||||
|
id string
|
||||||
|
db *sql.DB
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *TestDBModule) Start(ctx context.Context) error {
|
||||||
|
<-ctx.Done()
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *TestDBModule) Database() *sql.DB {
|
||||||
if m.db == nil {
|
if m.db == nil {
|
||||||
db, _ := sql.Open("sqlite", ":memory:")
|
db, _ := sql.Open("sqlite", ":memory:")
|
||||||
|
|
||||||
@@ -86,26 +129,14 @@ func (m *TestModule) Database() *sql.DB {
|
|||||||
return m.db
|
return m.db
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *TestModule) Stop() {}
|
func (m *TestDBModule) Stop() {}
|
||||||
|
|
||||||
func (m *TestModule) Type() string {
|
func (m *TestDBModule) Type() string {
|
||||||
return "module.test"
|
return "module.test.db"
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *TestModule) Id() string {
|
func (m *TestDBModule) Id() string {
|
||||||
return "test"
|
return m.id
|
||||||
}
|
|
||||||
|
|
||||||
func (m *TestModule) Get(key string) (any, error) {
|
|
||||||
return key, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *TestModule) Set(key string, value any) error {
|
|
||||||
if m.kvData == nil {
|
|
||||||
m.kvData = make(map[string]any)
|
|
||||||
}
|
|
||||||
m.kvData[key] = value
|
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetContextWithModules(ctx context.Context, modules map[string]common.Module) context.Context {
|
func GetContextWithModules(ctx context.Context, modules map[string]common.Module) context.Context {
|
||||||
|
|||||||
Reference in New Issue
Block a user