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

imp(core): allow huckleberry events with a prefix #5541

Merged
merged 21 commits into from
Jan 11, 2024
Merged
Show file tree
Hide file tree
Changes from 19 commits
Commits
Show all changes
21 commits
Select commit Hold shift + click to select a range
c53f913
feat: initial impl
srdtrk Jan 5, 2024
688a9d9
imp: moved event helpers to types and added tests
srdtrk Jan 5, 2024
70e7cad
imp(testing): added mock events to mock module
srdtrk Jan 5, 2024
bdbd9f6
test: added msg_server tests for application events
srdtrk Jan 5, 2024
88f430b
Merge branch 'main' into serdar/issue#5284-error-event-suffix
srdtrk Jan 8, 2024
f4caa14
imp: converted suffix to prefix
srdtrk Jan 8, 2024
da528e4
docs: updated inline comments
srdtrk Jan 8, 2024
b5f6ee0
Merge branch 'main' into serdar/issue#5284-error-event-suffix
srdtrk Jan 8, 2024
6a2bef0
Merge branch 'main' into serdar/issue#5284-error-event-suffix
srdtrk Jan 8, 2024
07fca7e
Merge branch 'main' into serdar/issue#5284-error-event-suffix
srdtrk Jan 8, 2024
78a1c60
Merge branch 'main' into serdar/issue#5284-error-event-suffix
srdtrk Jan 9, 2024
1c7862f
imp: review item
srdtrk Jan 9, 2024
43a03f3
Merge branch 'main' into serdar/issue#5284-error-event-suffix
srdtrk Jan 9, 2024
986fc82
Merge branch 'main' into serdar/issue#5284-error-event-suffix
srdtrk Jan 9, 2024
16a3312
Merge branch 'main' into serdar/issue#5284-error-event-suffix
srdtrk Jan 9, 2024
52b1e0e
Merge branch 'main' into serdar/issue#5284-error-event-suffix
srdtrk Jan 10, 2024
a30078b
Merge branch 'main' into serdar/issue#5284-error-event-suffix
srdtrk Jan 10, 2024
fae32e4
test: review items
srdtrk Jan 10, 2024
6106643
Merge branch 'main' into serdar/issue#5284-error-event-suffix
srdtrk Jan 10, 2024
4b58d7f
Merge branch 'main' into serdar/issue#5284-error-event-suffix
srdtrk Jan 11, 2024
4f9acf3
imp: review items
srdtrk Jan 11, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
106 changes: 106 additions & 0 deletions modules/core/keeper/events_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,106 @@
package keeper_test

import (
"testing"

"github.com/stretchr/testify/require"

sdk "github.com/cosmos/cosmos-sdk/types"

"github.com/cosmos/ibc-go/v8/modules/core/keeper"
"github.com/cosmos/ibc-go/v8/modules/core/types"
)

func TestConvertToErrorEvents(t *testing.T) {
var (
events sdk.Events
expEvents sdk.Events
)

tc := []struct {
name string
malleate func()
}{
{
"success: nil events",
func() {
events = nil
expEvents = nil
},
},
{
"success: empty events",
func() {
events = sdk.Events{}
expEvents = sdk.Events{}
},
},
{
"success: event with no attributes",
func() {
events = sdk.Events{
sdk.NewEvent("testevent"),
}
expEvents = sdk.Events{
sdk.NewEvent("testevent"),
}
},
},
{
"success: event with attributes",
func() {
events = sdk.Events{
sdk.NewEvent("testevent",
sdk.NewAttribute("key1", "value1"),
sdk.NewAttribute("key2", "value2"),
),
}
expEvents = sdk.Events{
sdk.NewEvent("testevent",
sdk.NewAttribute(types.ErrorAttributeKeyPrefix+"key1", "value1"),
sdk.NewAttribute(types.ErrorAttributeKeyPrefix+"key2", "value2"),
),
}
},
},
{
"success: multiple events with attributes",
func() {
events = sdk.Events{
sdk.NewEvent("testevent1",
sdk.NewAttribute("key1", "value1"),
sdk.NewAttribute("key2", "value2"),
),
sdk.NewEvent("testevent2",
sdk.NewAttribute("key3", "value3"),
sdk.NewAttribute("key4", "value4"),
),
}
expEvents = sdk.Events{
sdk.NewEvent("testevent1",
sdk.NewAttribute(types.ErrorAttributeKeyPrefix+"key1", "value1"),
sdk.NewAttribute(types.ErrorAttributeKeyPrefix+"key2", "value2"),
),
sdk.NewEvent("testevent2",
sdk.NewAttribute(types.ErrorAttributeKeyPrefix+"key3", "value3"),
sdk.NewAttribute(types.ErrorAttributeKeyPrefix+"key4", "value4"),
),
}
},
},
}

for _, tc := range tc {
t.Run(tc.name, func(t *testing.T) {
// initial events and expected events are reset so that the test fails if
// the malleate function does not set them
events = nil
expEvents = sdk.Events{}

tc.malleate()

newEvents := keeper.ConvertToErrorEvents(events)
require.Equal(t, expEvents, newEvents)
})
}
}
9 changes: 9 additions & 0 deletions modules/core/keeper/export_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
package keeper

import sdk "github.com/cosmos/cosmos-sdk/types"

// ConvertToErrorEvents is a wrapper around convertToErrorEvents
// to allow the function to be directly called in tests.
func ConvertToErrorEvents(events sdk.Events) sdk.Events {
return convertToErrorEvents(events)
}
25 changes: 25 additions & 0 deletions modules/core/keeper/msg_server.go
Original file line number Diff line number Diff line change
Expand Up @@ -494,6 +494,9 @@ func (k Keeper) RecvPacket(goCtx context.Context, msg *channeltypes.MsgRecvPacke
if ack == nil || ack.Success() {
// write application state changes for asynchronous and successful acknowledgements
writeFn()
} else {
// Modify events in cached context to reflect unsuccessful acknowledgement
ctx.EventManager().EmitEvents(convertToErrorEvents(cacheCtx.EventManager().Events()))
}

// Set packet acknowledgement only if the acknowledgement is not nil.
Expand Down Expand Up @@ -1174,3 +1177,25 @@ func (k Keeper) UpdateChannelParams(goCtx context.Context, msg *channeltypes.Msg

return &channeltypes.MsgUpdateParamsResponse{}, nil
}

// convertToErrorEvents converts all events to error events by appending the
// error attribute prefix to each event's attribute key.
func convertToErrorEvents(events sdk.Events) sdk.Events {
if events == nil {
return nil
}

newEvents := make(sdk.Events, len(events))
for i, event := range events {
newAttributes := make([]sdk.Attribute, len(event.Attributes))
for j, attribute := range event.Attributes {
newAttributes[j] = sdk.NewAttribute(coretypes.ErrorAttributeKeyPrefix+attribute.Key, attribute.Value)
}

// no need to append the error attribute prefix to the event type because
// the event type is not associated to a value that can be misinterpreted
newEvents[i] = sdk.NewEvent(event.Type, newAttributes...)
}

return newEvents
}
Loading
Loading