-
Notifications
You must be signed in to change notification settings - Fork 3.7k
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
feat(server/v2): refactor the server/v2 events #21785
Conversation
WalkthroughWalkthroughThe changes in this pull request involve updates to multiple Go modules, focusing primarily on modifying the Changes
Sequence Diagram(s)sequenceDiagram
participant Client
participant Server
participant Schema
participant Event
Client->>Server: Request for event attributes
Server->>Schema: Retrieve attributes
Schema-->>Server: Return attributes
Server->>Event: Process attributes
Event-->>Server: Return processed event
Server-->>Client: Send response
Assessment against linked issues
Possibly related issues
Possibly related PRs
Suggested labels
Suggested reviewers
Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media? TipsChatThere are 3 ways to chat with CodeRabbit:
Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
Other keywords and placeholders
Documentation and Community
|
@julienrbrt we need to create the appropriate version of |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 7
Outside diff range and nitpick comments (1)
simapp/v2/go.mod (1)
249-249
: Approve the addition of the replacement directive for thecosmossdk.io/schema
module, with a reminder.The replacement directive for the
cosmossdk.io/schema
module, pointing to a local path../../schema
, indicates that the module is now utilizing a local version of theschema
package. This can be beneficial for development or testing purposes, as it allows for quick iterations and debugging.However, please ensure that:
- The local version is kept in sync with the main development branch to avoid introducing any breaking changes.
- The reason for using a local version is documented, along with instructions on how to set it up, to ensure a smooth development experience for other team members.
Review details
Configuration used: .coderabbit.yml
Review profile: CHILL
Files ignored due to path filters (6)
collections/go.sum
is excluded by!**/*.sum
runtime/v2/go.sum
is excluded by!**/*.sum
server/v2/cometbft/go.sum
is excluded by!**/*.sum
server/v2/go.sum
is excluded by!**/*.sum
server/v2/stf/go.sum
is excluded by!**/*.sum
simapp/v2/go.sum
is excluded by!**/*.sum
Files selected for processing (12)
- collections/collections.go (1 hunks)
- collections/go.mod (1 hunks)
- collections/indexing.go (2 hunks)
- runtime/v2/go.mod (3 hunks)
- server/v2/cometbft/go.mod (2 hunks)
- server/v2/cometbft/utils.go (2 hunks)
- server/v2/go.mod (3 hunks)
- server/v2/stf/core_event_service.go (1 hunks)
- server/v2/stf/go.mod (2 hunks)
- server/v2/stf/stf.go (4 hunks)
- server/v2/streaming/utils.go (1 hunks)
- simapp/v2/go.mod (2 hunks)
Additional context used
Path-based instructions (6)
server/v2/streaming/utils.go (1)
Pattern
**/*.go
: Review the Golang code for conformity with the Uber Golang style guide, highlighting any deviations.server/v2/stf/core_event_service.go (1)
Pattern
**/*.go
: Review the Golang code for conformity with the Uber Golang style guide, highlighting any deviations.collections/indexing.go (1)
Pattern
**/*.go
: Review the Golang code for conformity with the Uber Golang style guide, highlighting any deviations.collections/collections.go (1)
Pattern
**/*.go
: Review the Golang code for conformity with the Uber Golang style guide, highlighting any deviations.server/v2/cometbft/utils.go (1)
Pattern
**/*.go
: Review the Golang code for conformity with the Uber Golang style guide, highlighting any deviations.server/v2/stf/stf.go (1)
Pattern
**/*.go
: Review the Golang code for conformity with the Uber Golang style guide, highlighting any deviations.
GitHub Check: tests (03)
collections/indexing.go
[failure] 70-70:
undefined: schema.StateObjectUpdate
[failure] 90-90:
undefined: schema.StateObjectUpdate
[failure] 97-97:
undefined: schema.StateObjectUpdate
[failure] 103-103:
undefined: schema.StateObjectUpdate
[failure] 110-110:
undefined: schema.StateObjectUpdate
[failure] 115-115:
undefined: schema.StateObjectUpdatecollections/collections.go
[failure] 107-107:
undefined: schema.StateObjectType
GitHub Check: tests (02)
collections/indexing.go
[failure] 70-70:
undefined: schema.StateObjectUpdate
[failure] 90-90:
undefined: schema.StateObjectUpdate
[failure] 97-97:
undefined: schema.StateObjectUpdate
[failure] 103-103:
undefined: schema.StateObjectUpdate
[failure] 110-110:
undefined: schema.StateObjectUpdate
[failure] 115-115:
undefined: schema.StateObjectUpdatecollections/collections.go
[failure] 107-107:
undefined: schema.StateObjectType
GitHub Check: tests (01)
collections/indexing.go
[failure] 70-70:
undefined: schema.StateObjectUpdate
[failure] 90-90:
undefined: schema.StateObjectUpdate
[failure] 97-97:
undefined: schema.StateObjectUpdate
[failure] 103-103:
undefined: schema.StateObjectUpdate
[failure] 110-110:
undefined: schema.StateObjectUpdate
[failure] 115-115:
undefined: schema.StateObjectUpdatecollections/collections.go
[failure] 107-107:
undefined: schema.StateObjectType
GitHub Check: tests (00)
collections/indexing.go
[failure] 70-70:
undefined: schema.StateObjectUpdate
[failure] 90-90:
undefined: schema.StateObjectUpdate
[failure] 97-97:
undefined: schema.StateObjectUpdate
[failure] 103-103:
undefined: schema.StateObjectUpdate
[failure] 110-110:
undefined: schema.StateObjectUpdate
[failure] 115-115:
undefined: schema.StateObjectUpdatecollections/collections.go
[failure] 107-107:
undefined: schema.StateObjectType
GitHub Check: dependency-review
collections/indexing.go
[failure] 70-70:
undefined: schema.StateObjectUpdate
[failure] 90-90:
undefined: schema.StateObjectUpdate
[failure] 97-97:
undefined: schema.StateObjectUpdate
[failure] 103-103:
undefined: schema.StateObjectUpdate
[failure] 110-110:
undefined: schema.StateObjectUpdate
[failure] 115-115:
undefined: schema.StateObjectUpdatecollections/collections.go
[failure] 107-107:
undefined: schema.StateObjectType
GitHub Check: golangci-lint
collections/indexing.go
[failure] 70-70:
undefined: schema.StateObjectUpdate
[failure] 90-90:
undefined: schema.StateObjectUpdate
[failure] 97-97:
undefined: schema.StateObjectUpdate
[failure] 103-103:
undefined: schema.StateObjectUpdate
[failure] 110-110:
undefined: schema.StateObjectUpdate
[failure] 115-115:
undefined: schema.StateObjectUpdate) (typecheck)collections/collections.go
[failure] 107-107:
undefined: schema.StateObjectType
Additional comments not posted (20)
server/v2/stf/go.mod (3)
6-6
: Verify the compatibility of the updatedcosmossdk.io/core
version.The version of
cosmossdk.io/core
has been updated to a more specific pseudo-versionv1.0.0-alpha.2.0.20240917105208-c9f0e2e4d892
. Please ensure that this version is compatible with the rest of the codebase and does not introduce any breaking changes.
7-7
: Verify the usage of the newcosmossdk.io/schema
dependency.A new dependency on
cosmossdk.io/schema
at versionv0.2.0
has been introduced. Please ensure that this dependency is being used correctly and does not introduce any issues or conflicts with existing functionality.
17-17
: Verify the compatibility of the local schema package.A replace directive has been added for
cosmossdk.io/schema
, pointing to a local path../../../schema
. Please ensure that the local version of the schema package is up-to-date and compatible with the rest of the codebase to avoid any inconsistencies or compatibility issues.collections/go.mod (1)
21-22
: LGTM! The new replacement enhances local development and testing.The addition of the replacement directive for
cosmossdk.io/schema
allows using a local version of theschema
package, enabling more flexible development and testing workflows. This change is consistent with the existing replacement forcosmossdk.io/core/testing
, suggesting a pattern of leveraging local packages for development and testing purposes.Keep in mind that this modification may impact the build process and requires the presence of the
schema
package in the specified local directory (../schema
).server/v2/streaming/utils.go (1)
Line range hint
1-29
: The code conforms to the Uber Golang style guide.The code follows the basic Golang style guidelines and there are no deviations from the Uber Golang style guide. The function and variable names follow the camelCase convention and are descriptive.
runtime/v2/go.mod (2)
17-17
: Ensure the stability of the chosen commit forcosmossdk.io/core
.Using a pseudo-version that points to a specific commit helps ensure reproducible builds and avoids potential breaking changes. However, please ensure that the chosen commit
c9f0e2e4d892
is stable and has been thoroughly tested.
34-34
: Keep the local version of theschema
package in sync with the remote version.The addition of the
cosmossdk.io/schema
dependency and the usage of a local version of theschema
package allows for faster development. However, please ensure to regularly sync the local version with the remote version to avoid divergence and potential compatibility issues.Also applies to: 90-90
collections/indexing.go (2)
70-70
: Fix the compilation error due to undefined typeschema.StateObjectUpdate
.The static analysis hints indicate that the type
schema.StateObjectUpdate
is undefined, causing a compilation error. Please ensure that theschema
package is updated to define this type.Also, verify that the downstream code is updated to handle the change in return type from
[]schema.ObjectUpdate
to[]schema.StateObjectUpdate
.Tools
GitHub Check: tests (03)
[failure] 70-70:
undefined: schema.StateObjectUpdateGitHub Check: tests (02)
[failure] 70-70:
undefined: schema.StateObjectUpdateGitHub Check: tests (01)
[failure] 70-70:
undefined: schema.StateObjectUpdateGitHub Check: tests (00)
[failure] 70-70:
undefined: schema.StateObjectUpdateGitHub Check: dependency-review
[failure] 70-70:
undefined: schema.StateObjectUpdateGitHub Check: golangci-lint
[failure] 70-70:
undefined: schema.StateObjectUpdate
90-90
: Fix the compilation error due to undefined typeschema.StateObjectUpdate
.The static analysis hints indicate that the type
schema.StateObjectUpdate
is undefined, causing a compilation error. Please ensure that theschema
package is updated to define this type.Also, verify that the downstream code is updated to handle the change in return type from
[]schema.ObjectUpdate
to[]schema.StateObjectUpdate
.Tools
GitHub Check: tests (03)
[failure] 90-90:
undefined: schema.StateObjectUpdateGitHub Check: tests (02)
[failure] 90-90:
undefined: schema.StateObjectUpdateGitHub Check: tests (01)
[failure] 90-90:
undefined: schema.StateObjectUpdateGitHub Check: tests (00)
[failure] 90-90:
undefined: schema.StateObjectUpdateGitHub Check: dependency-review
[failure] 90-90:
undefined: schema.StateObjectUpdateGitHub Check: golangci-lint
[failure] 90-90:
undefined: schema.StateObjectUpdateserver/v2/go.mod (3)
17-17
: LGTM!The update to a more specific pseudo-version for
cosmossdk.io/core
dependency is a good practice. It ensures that the project is pinned to a specific commit, providing better reproducibility and control over the exact version being used.
47-47
: Looks good!The addition of
cosmossdk.io/schema
as an indirect dependency is a necessary update to ensure all required dependencies are properly tracked. Indirect dependencies are an important part of the Go module system and help maintain a complete dependency graph.
116-116
: Consider the implications of using a local replace directive.The replace directive for
cosmossdk.io/schema
points to a local path../../schema
, indicating the use of a local version of this module. While this is a common practice during development, it can make the project harder to build for other developers or in CI/CD pipelines.Could you provide more context on the reason for using a local replacement? If the changes made to the local version are necessary, consider publishing the modified module to a remote repository. If the changes are temporary or not required, it might be better to revert to using the upstream version to improve the project's portability and ease of use.
server/v2/cometbft/go.mod (2)
8-8
: Ensure compatibility of the localschema
package.The new replace directive points the
cosmossdk.io/schema
module to a local version in the../../../schema
directory. While this may be necessary for development or testing, it's crucial to verify that the local version is compatible with the rest of the codebase and doesn't introduce any breaking changes.Consider running the following script to check for any inconsistencies or issues related to the
schema
package usage:This script searches for all
.go
files that import thecosmossdk.io/schema
package, and then performs static analysis or runs specific tests to check for any usage of deprecated or changed APIs from the local schema version. Adjust the checks based on the changes made in the local version.If any issues are found, the script will print a summary and exit with a non-zero status, indicating that further investigation and fixes are needed before proceeding with the local schema version.
Verification successful
Local
schema
package appears compatible, but exercise cautionThe compatibility check for the local
schema
package has completed successfully, and no issues were detected across the 63 files that importcosmossdk.io/schema
. This suggests that the local version is likely compatible with the existing codebase.However, please note that this check was limited to detecting usage of deprecated APIs. To ensure full compatibility:
- Run the full test suite to catch any runtime issues.
- Perform a manual review of any significant changes in the local
schema
package.- Consider gradual rollout or additional testing in a staging environment.
Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Check for `cosmossdk.io/schema` usage and verify compatibility # 1. Find all `.go` files that import the `cosmossdk.io/schema` package importers=$(fd -e go -x rg -l 'cosmossdk.io/schema') # 2. For each file, check if the usage is compatible with the local version for file in $importers; do echo "Checking $file" # Perform static analysis or run tests specific to the schema usage # For example, check for deprecated or changed APIs rg -q 'schema\.Deprecated' "$file" && echo " WARNING: Usage of deprecated schema API" # Add more checks as needed done # 3. If any issues are found, print a summary and exit with a non-zero status if [ -n "$(echo $issues)" ]; then echo "Compatibility issues found:" echo "$issues" exit 1 else echo "No compatibility issues found" fiLength of output: 13600
23-23
: Review the changes in the specificcore
module commit.The
cosmossdk.io/core
module version has been updated to a specific commit hashc9f0e2e4d892
from2024-09-17
. This change could include bug fixes, new features, or other improvements that might affect the behavior or compatibility of the codebase.To ensure a smooth integration, follow these steps:
Review the changes included in the specific commit by visiting the commit URL or running:
Assess the impact of these changes on the dependent code in your project. Look for any breaking changes, deprecated APIs, or new features that might require updates in your codebase.
If necessary, update your code to accommodate the changes introduced by the new
core
module version. This may involve updating function calls, adapting to new APIs, or handling any deprecated functionality.Run your project's test suite and perform thorough testing to verify that everything works as expected with the updated
core
module.By carefully reviewing and adapting to the changes in the specific
core
module commit, you can ensure a smooth integration and maintain the stability of your codebase.server/v2/cometbft/utils.go (2)
130-133
: LGTM!The change improves error handling by explicitly checking for an error when retrieving event attributes and panicking if an error occurs. This aligns with the Uber Go Style Guide's recommendations for error handling.
155-158
: LGTM!Similar to the previous comment, this change improves error handling by explicitly checking for an error when retrieving event attributes and panicking if an error occurs. This aligns with the Uber Go Style Guide's recommendations for error handling.
simapp/v2/go.mod (1)
8-8
: Approve the version update for thecosmossdk.io/core
dependency.The version update to
v1.0.0-alpha.2.0.20240917105208-c9f0e2e4d892
reflects a more precise versioning scheme, which can help in ensuring compatibility and stability within the module's dependencies. This change aligns with the best practices of dependency management.server/v2/stf/stf.go (3)
18-18
: LGTM!The import statement is syntactically correct and follows the recommended naming convention for Cosmos SDK modules. The usage of the imported
appdata
package is evident in the changes made to thepreBlock
,beginBlock
, andendBlock
functions.
342-343
: Excellent refactor!The usage of
appdata.PreBlockStage
,appdata.BeginBlockStage
, andappdata.EndBlockStage
constants to assign theBlockStage
field of each event provides a more structured and standardized approach compared to the previous hardcoded values. This change simplifies the event attribute management and enhances the clarity and maintainability of the code. It aligns well with the overall objective of refactoring the events in theserver/v2
module.Also applies to: 358-359, 381-382
Line range hint
1-583
: Code conforms to the Uber Go Style Guide.Based on the review, the code in this file follows the conventions and recommendations outlined in the Uber Go Style Guide. The formatting, naming, error handling, and commenting practices align with the style guide's guidelines. No obvious deviations were found in the provided code.
server/v2/streaming/utils.go
Outdated
attrs, err := event.Attributes() | ||
if err != nil { | ||
panic(err) | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Avoid panicking on errors. Return an error instead to allow graceful error handling.
Panicking on an error is not an ideal error handling strategy as it can lead to unexpected program crashes. Instead of panicking, the function should return an error to allow the caller to handle the error gracefully.
Consider applying this diff to improve the error handling:
- attrs, err := event.Attributes()
- if err != nil {
- panic(err)
- }
+ attrs, err := event.Attributes()
+ if err != nil {
+ return nil, err
+ }
Also, update the function signature to return an error:
-func IntoStreamingEvents(events []event.Event) []*Event {
+func IntoStreamingEvents(events []event.Event) ([]*Event, error) {
Committable suggestion was skipped due to low confidence.
@@ -81,6 +81,6 @@ func TypedEventToEvent(tev transaction.Msg) (event.Event, error) { | |||
|
|||
return event.Event{ | |||
Type: evtType, | |||
Attributes: attrs, | |||
Attributes: func() ([]event.Attribute, error) { return attrs, nil }, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Consider enhancing the attributes closure for more robust error handling and validation.
The introduction of a closure to encapsulate the attributes allows for deferred execution and the addition of logic without altering the function signature. This is a good approach to make the handling of attributes more flexible.
However, the current implementation doesn't fully leverage the potential benefits of the closure. Consider adding error handling or validation logic within the closure to ensure the attributes are valid and to handle any potential errors gracefully.
For example:
Attributes: func() ([]event.Attribute, error) {
if err := validateAttributes(attrs); err != nil {
return nil, err
}
return attrs, nil
},
This way, the closure can serve as a centralized point to handle attribute-related errors and validations, making the code more robust and maintainable.
return []schema.StateObjectUpdate{ | ||
{TypeName: c.coll.GetName()}, | ||
}, err |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fix the compilation error due to undefined type schema.StateObjectUpdate
.
The static analysis hints indicate that the type schema.StateObjectUpdate
is undefined, causing a compilation error. Please ensure that the schema
package is updated to define this type.
Tools
GitHub Check: tests (03)
[failure] 97-97:
undefined: schema.StateObjectUpdate
GitHub Check: tests (02)
[failure] 97-97:
undefined: schema.StateObjectUpdate
GitHub Check: tests (01)
[failure] 97-97:
undefined: schema.StateObjectUpdate
GitHub Check: tests (00)
[failure] 97-97:
undefined: schema.StateObjectUpdate
GitHub Check: dependency-review
[failure] 97-97:
undefined: schema.StateObjectUpdate
GitHub Check: golangci-lint
[failure] 97-97:
undefined: schema.StateObjectUpdate
return []schema.StateObjectUpdate{ | ||
{TypeName: c.coll.GetName(), Key: k, Delete: true}, | ||
}, nil |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fix the compilation error due to undefined type schema.StateObjectUpdate
.
The static analysis hints indicate that the type schema.StateObjectUpdate
is undefined, causing a compilation error. Please ensure that the schema
package is updated to define this type.
Tools
GitHub Check: tests (03)
[failure] 103-103:
undefined: schema.StateObjectUpdate
GitHub Check: tests (02)
[failure] 103-103:
undefined: schema.StateObjectUpdate
GitHub Check: tests (01)
[failure] 103-103:
undefined: schema.StateObjectUpdate
GitHub Check: tests (00)
[failure] 103-103:
undefined: schema.StateObjectUpdate
GitHub Check: dependency-review
[failure] 103-103:
undefined: schema.StateObjectUpdate
GitHub Check: golangci-lint
[failure] 103-103:
undefined: schema.StateObjectUpdate
return []schema.StateObjectUpdate{ | ||
{TypeName: c.coll.GetName(), Key: k}, | ||
}, err |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fix the compilation error due to undefined type schema.StateObjectUpdate
.
The static analysis hints indicate that the type schema.StateObjectUpdate
is undefined, causing a compilation error. Please ensure that the schema
package is updated to define this type.
Tools
GitHub Check: tests (03)
[failure] 110-110:
undefined: schema.StateObjectUpdate
GitHub Check: tests (02)
[failure] 110-110:
undefined: schema.StateObjectUpdate
GitHub Check: tests (01)
[failure] 110-110:
undefined: schema.StateObjectUpdate
GitHub Check: tests (00)
[failure] 110-110:
undefined: schema.StateObjectUpdate
GitHub Check: dependency-review
[failure] 110-110:
undefined: schema.StateObjectUpdate
GitHub Check: golangci-lint
[failure] 110-110:
undefined: schema.StateObjectUpdate
return []schema.StateObjectUpdate{ | ||
{TypeName: c.coll.GetName(), Key: k, Value: v}, | ||
}, nil |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fix the compilation error due to undefined type schema.StateObjectUpdate
.
The static analysis hints indicate that the type schema.StateObjectUpdate
is undefined, causing a compilation error. Please ensure that the schema
package is updated to define this type.
Tools
GitHub Check: tests (03)
[failure] 115-115:
undefined: schema.StateObjectUpdate
GitHub Check: tests (02)
[failure] 115-115:
undefined: schema.StateObjectUpdate
GitHub Check: tests (01)
[failure] 115-115:
undefined: schema.StateObjectUpdate
GitHub Check: tests (00)
[failure] 115-115:
undefined: schema.StateObjectUpdate
GitHub Check: dependency-review
[failure] 115-115:
undefined: schema.StateObjectUpdate
GitHub Check: golangci-lint
[failure] 115-115:
undefined: schema.StateObjectUpdate) (typecheck)
@@ -104,7 +104,7 @@ | |||
// decoders and encoders to and from schema values and raw kv-store bytes. | |||
type collectionSchemaCodec struct { | |||
coll Collection | |||
objectType schema.ObjectType | |||
objectType schema.StateObjectType |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fix the undefined type schema.StateObjectType
.
The static analysis tools indicate that schema.StateObjectType
is undefined. This change would cause compilation errors.
Please ensure that schema.StateObjectType
is properly defined and imported before using it as the type for the objectType
field.
Tools
GitHub Check: tests (03)
[failure] 107-107:
undefined: schema.StateObjectType
GitHub Check: tests (02)
[failure] 107-107:
undefined: schema.StateObjectType
GitHub Check: tests (01)
[failure] 107-107:
undefined: schema.StateObjectType
GitHub Check: tests (00)
[failure] 107-107:
undefined: schema.StateObjectType
GitHub Check: dependency-review
[failure] 107-107:
undefined: schema.StateObjectType
GitHub Check: golangci-lint
[failure] 107-107:
undefined: schema.StateObjectType
collections/go.mod
Outdated
@@ -18,3 +18,5 @@ require ( | |||
) | |||
|
|||
replace cosmossdk.io/core/testing => ../core/testing | |||
|
|||
replace cosmossdk.io/schema => ../schema |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we do this in a separate PR? I'm pretty sure this replace has a global effect on all go.mod's in the SDK. Instead if needed we can tag schema
and then update collections.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yes, we need a new tag of schema
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
BlockStage
is not included in the schema v2.0
, after new tag of schema
, and also need to tag the core
module, maybe alpah3
??? cc: @julienrbrt
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sure let's have alpha.3.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done, you can now remove all the replaces and use https://github.com/cosmos/cosmos-sdk/releases/tag/schema%2Fv0.3.0 and https://github.com/cosmos/cosmos-sdk/releases/tag/core%2Fv1.0.0-alpha.3
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for tagging schema @julienrbrt !
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
utACK
Adding the backport label for the server/v2/CometBFT changes |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
Outside diff range and nitpick comments (4)
x/slashing/go.mod (1)
Line range hint
186-193
: Address the TODO comment and removereplace
directives when appropriate.The
replace
directives in thego.mod
file are used to temporarily substitute certain dependencies with local file paths. This is likely done for development purposes, to use modified or custom versions of those dependencies.As indicated by the TODO comment, these
replace
directives should be removed once all the modules are "spun out" (i.e., moved to their own repositories or made independent). Keeping thereplace
directives long-term can make the module harder to reuse and maintain.Please ensure to address this TODO comment and remove the
replace
directives when the modules are ready to be spun out.client/v2/go.mod (1)
Line range hint
215-222
: Address the TODO comment about removingreplace
statements.The TODO comment indicates that
replace
statements should be removed after spinning out all modules. This is a good practice for maintaining clean and efficient dependency management.Please let me know if you need any assistance in spinning out the modules and removing the
replace
statements. I'd be happy to help!x/feegrant/go.mod (1)
Line range hint
208-215
: Consider removing thereplace
directive.It's generally recommended to avoid using
replace
directives in production as they can cause issues with dependency management and reproducibility.Instead, consider creating the appropriate versions of the
core
andschema
modules to avoid the need for local replacements.x/accounts/go.mod (1)
Line range hint
184-184
: Address the TODO comment.The
go.mod
file contains a TODO comment indicating that certain replace directives should be removed after spinning out all modules. It's important to create a plan or timeline for addressing this TODO to avoid accumulating technical debt and potential confusion for other developers.Do you need any assistance in creating a plan to remove the unnecessary replace directives? I'd be happy to help you outline the steps and create GitHub issues to track the progress.
Review details
Configuration used: .coderabbit.yml
Review profile: CHILL
Files ignored due to path filters (31)
client/v2/go.sum
is excluded by!**/*.sum
collections/go.sum
is excluded by!**/*.sum
go.sum
is excluded by!**/*.sum
runtime/v2/go.sum
is excluded by!**/*.sum
server/v2/cometbft/go.sum
is excluded by!**/*.sum
server/v2/go.sum
is excluded by!**/*.sum
server/v2/stf/go.sum
is excluded by!**/*.sum
simapp/go.sum
is excluded by!**/*.sum
simapp/v2/go.sum
is excluded by!**/*.sum
tests/go.sum
is excluded by!**/*.sum
x/accounts/defaults/base/go.sum
is excluded by!**/*.sum
x/accounts/defaults/lockup/go.sum
is excluded by!**/*.sum
x/accounts/defaults/multisig/go.sum
is excluded by!**/*.sum
x/accounts/go.sum
is excluded by!**/*.sum
x/authz/go.sum
is excluded by!**/*.sum
x/bank/go.sum
is excluded by!**/*.sum
x/circuit/go.sum
is excluded by!**/*.sum
x/consensus/go.sum
is excluded by!**/*.sum
x/distribution/go.sum
is excluded by!**/*.sum
x/epochs/go.sum
is excluded by!**/*.sum
x/evidence/go.sum
is excluded by!**/*.sum
x/feegrant/go.sum
is excluded by!**/*.sum
x/gov/go.sum
is excluded by!**/*.sum
x/group/go.sum
is excluded by!**/*.sum
x/mint/go.sum
is excluded by!**/*.sum
x/nft/go.sum
is excluded by!**/*.sum
x/params/go.sum
is excluded by!**/*.sum
x/protocolpool/go.sum
is excluded by!**/*.sum
x/slashing/go.sum
is excluded by!**/*.sum
x/staking/go.sum
is excluded by!**/*.sum
x/upgrade/go.sum
is excluded by!**/*.sum
Files selected for processing (36)
- client/v2/go.mod (2 hunks)
- collections/go.mod (1 hunks)
- go.mod (1 hunks)
- runtime/v2/go.mod (2 hunks)
- server/v2/cometbft/abci.go (1 hunks)
- server/v2/cometbft/go.mod (2 hunks)
- server/v2/cometbft/streaming.go (1 hunks)
- server/v2/cometbft/utils.go (4 hunks)
- server/v2/go.mod (2 hunks)
- server/v2/stf/go.mod (1 hunks)
- server/v2/streaming/utils.go (2 hunks)
- simapp/go.mod (2 hunks)
- simapp/v2/go.mod (2 hunks)
- tests/go.mod (2 hunks)
- x/accounts/defaults/base/go.mod (2 hunks)
- x/accounts/defaults/lockup/go.mod (2 hunks)
- x/accounts/defaults/multisig/go.mod (2 hunks)
- x/accounts/go.mod (2 hunks)
- x/authz/go.mod (2 hunks)
- x/bank/go.mod (2 hunks)
- x/bank/keeper/keeper_test.go (2 hunks)
- x/circuit/go.mod (2 hunks)
- x/consensus/go.mod (2 hunks)
- x/distribution/go.mod (2 hunks)
- x/epochs/go.mod (2 hunks)
- x/evidence/go.mod (2 hunks)
- x/feegrant/go.mod (2 hunks)
- x/gov/go.mod (2 hunks)
- x/group/go.mod (2 hunks)
- x/mint/go.mod (2 hunks)
- x/nft/go.mod (2 hunks)
- x/params/go.mod (2 hunks)
- x/protocolpool/go.mod (2 hunks)
- x/slashing/go.mod (2 hunks)
- x/staking/go.mod (2 hunks)
- x/upgrade/go.mod (2 hunks)
Files skipped from review as they are similar to previous changes (6)
- collections/go.mod
- runtime/v2/go.mod
- server/v2/cometbft/go.mod
- server/v2/go.mod
- server/v2/stf/go.mod
- simapp/v2/go.mod
Additional context used
Path-based instructions (6)
server/v2/streaming/utils.go (1)
Pattern
**/*.go
: Review the Golang code for conformity with the Uber Golang style guide, highlighting any deviations.server/v2/cometbft/streaming.go (1)
Pattern
**/*.go
: Review the Golang code for conformity with the Uber Golang style guide, highlighting any deviations.server/v2/cometbft/utils.go (1)
Pattern
**/*.go
: Review the Golang code for conformity with the Uber Golang style guide, highlighting any deviations.tests/go.mod (1)
Pattern
tests/**/*
: "Assess the integration and e2e test code assessing sufficient code coverage for the changes associated in the pull request"server/v2/cometbft/abci.go (1)
Pattern
**/*.go
: Review the Golang code for conformity with the Uber Golang style guide, highlighting any deviations.x/bank/keeper/keeper_test.go (2)
Pattern
**/*.go
: Review the Golang code for conformity with the Uber Golang style guide, highlighting any deviations.
Pattern
**/*_test.go
: "Assess the unit test code assessing sufficient code coverage for the changes associated in the pull request"
Additional comments not posted (55)
server/v2/streaming/utils.go (1)
Line range hint
5-25
: LGTM!The function now correctly handles the error returned by
event.Attributes()
and returns it to the caller. The function signature has also been updated to return an error, which is a good practice.The past review comment suggesting a similar change is no longer applicable as the suggested change has already been implemented.
server/v2/cometbft/streaming.go (3)
24-27
: LGTM!The error handling for event conversion is implemented correctly. Returning early if an error occurs prevents further processing with potentially invalid data, improving the robustness of the function.
32-32
: LGTM!The assignment of the converted streaming events to the
Events
field is correct.
37-45
: LGTM!The error handling for event conversion is implemented correctly. Returning early if an error occurs prevents further processing with potentially invalid data, improving the robustness of the function. The converted events are correctly passed to the
ListenDeliverBlock
function of each streaming listener.x/accounts/defaults/lockup/go.mod (2)
7-7
: Verify compatibility with the updatedcosmossdk.io/core
dependency.The version of
cosmossdk.io/core
has been updated fromv1.0.0-alpha.2
tov1.0.0-alpha.3
. This change may introduce breaking changes or new features that could impact the module's functionality or compatibility with other components.Ensure that the module has been thoroughly tested with the updated version to confirm that it remains compatible and functions as expected.
25-25
: Confirm compatibility with the updatedcosmossdk.io/schema
dependency.The version of
cosmossdk.io/schema
has been updated fromv0.2.0
tov0.3.0
. This change may introduce updates or modifications in the schema handling that could affect the module's interaction with the schema.Verify that the module remains compatible with the updated schema handling and that any necessary adjustments have been made to ensure proper functionality.
x/params/go.mod (1)
7-7
: Approve version updates, but verify compatibility and impact.The updates to the
cosmossdk.io/core
andcosmossdk.io/schema
dependencies seem reasonable given the minor version increments. However, it's important to ensure that these updates are compatible with the rest of the codebase and do not introduce any breaking changes.To verify the compatibility and impact of the version updates, consider the following:
- Review the release notes or changelog of the updated dependencies to understand the changes and any potential breaking changes.
- Run the unit tests and integration tests of the application to ensure that the updates do not introduce any regressions or failures.
- Perform manual testing of the critical functionalities of the application to validate that the behavior remains as expected.
- If possible, deploy the application to a staging or test environment to monitor its performance and stability with the updated dependencies.
By thoroughly verifying the compatibility and impact of the version updates, you can minimize the risk of introducing issues or breaking changes in the production environment.
Also applies to: 32-32
x/staking/go.mod (2)
8-8
: Verify the impact of updatingcosmossdk.io/core
tov1.0.0-alpha.3
.Updating to a new alpha version may introduce breaking changes or new features that could affect the functionality of the
x/staking
module. Ensure that thorough testing has been performed to confirm compatibility with the updated version.
167-167
: Verify the impact of updatingcosmossdk.io/schema
tov0.3.0
.Updating to a new minor version may introduce new features, bug fixes, or minor breaking changes that could affect the schema definitions or serialization logic within the
x/staking
module. Ensure that proper testing has been performed to confirm compatibility with the updated version.x/consensus/go.mod (2)
8-8
: LGTM!The version update of
cosmossdk.io/core
fromv1.0.0-alpha.2
tov1.0.0-alpha.3
is approved.
30-30
: LGTM!The version update of
cosmossdk.io/schema
fromv0.2.0
tov0.3.0
is approved.x/bank/go.mod (2)
8-8
: LGTM!The update to
cosmossdk.io/core
fromv1.0.0-alpha.2
tov1.0.0-alpha.3
is approved. This progression in the alpha release likely introduces new features, bug fixes, or improvements to the core module.
167-167
: Verify compatibility with the updatedcosmossdk.io/schema
version.The update to
cosmossdk.io/schema
fromv0.2.0
tov0.3.0
is approved. This update likely introduces enhancements or modifications to the schema handling capabilities.To ensure compatibility with the updated schema version, run the following script:
x/evidence/go.mod (2)
8-8
: Approve version update forcosmossdk.io/core
.The minor version update to
v1.0.0-alpha.3
should introduce enhancements or bug fixes while maintaining backward compatibility. However, please verify that this updated version is compatible with other dependencies and the codebase to avoid any potential issues.
31-31
: Approve version update forcosmossdk.io/schema
.The minor version update to
v0.3.0
should introduce enhancements or bug fixes while maintaining backward compatibility. However, please verify that this updated version is compatible with other dependencies and the codebase to avoid any potential issues.x/epochs/go.mod (2)
8-8
: Verify compatibility with the updatedcosmossdk.io/core
version.The
cosmossdk.io/core
module has been updated fromv1.0.0-alpha.2
tov1.0.0-alpha.3
. Please review the changelog for any breaking changes or new features introduced in this version update. Ensure that the codebase is updated accordingly to maintain compatibility.
23-23
: Verify compatibility with the updatedcosmossdk.io/schema
version.The
cosmossdk.io/schema
module has been updated fromv0.2.0
tov0.3.0
. Please review the changelog for any breaking changes or new features introduced in this version update. Ensure that the codebase is updated accordingly to maintain compatibility.x/protocolpool/go.mod (2)
8-8
: LGTM!The version update for
cosmossdk.io/core
is a standard part of the development process and does not raise any immediate concerns.
30-30
: LGTM!The version update for
cosmossdk.io/schema
is a standard part of the development process and does not raise any immediate concerns.x/authz/go.mod (2)
7-7
: Verify the impact of updatingcosmossdk.io/core
tov1.0.0-alpha.3
.Ensure that the module's functionality is not adversely affected by the changes in the core SDK. Perform thorough testing to confirm compatibility with the updated version.
33-33
: Verify the impact of updatingcosmossdk.io/schema
tov0.3.0
.Ensure that the module's schema handling is not adversely affected by the changes in the
cosmossdk.io/schema
package. Perform thorough testing to confirm compatibility with the updated version, especially if the update introduces new features or breaking changes.x/nft/go.mod (2)
7-7
: Verify compatibility with the updatedcosmossdk.io/core
version.The version of
cosmossdk.io/core
has been incremented fromv1.0.0-alpha.2
tov1.0.0-alpha.3
. Please ensure that thex/nft
module is compatible with this updated version and thoroughly test the module to identify any potential issues or breaking changes introduced by the version update.
29-29
: Verify compatibility with the updatedcosmossdk.io/schema
version.The version of
cosmossdk.io/schema
has been updated fromv0.2.0
tov0.3.0
. Please ensure that thex/nft
module is compatible with this updated version and thoroughly test the module to identify any potential issues or breaking changes introduced by the version update.x/slashing/go.mod (1)
8-8
: Review the impact of updatingcosmossdk.io/core
andcosmossdk.io/schema
versions.The
go.mod
file has been updated to use newer versions ofcosmossdk.io/core
(v1.0.0-alpha.3) andcosmossdk.io/schema
(v0.3.0). It's important to review the release notes or changelog of these dependencies to understand any breaking changes, new features, or bug fixes introduced by the updated versions.Ensure that the
x/slashing
module code is compatible with the changes in these dependencies and make necessary adaptations if required.Also applies to: 33-33
x/circuit/go.mod (2)
8-8
: Verify compatibility with the updatedcosmossdk.io/core
dependency.The version update to
v1.0.0-alpha.3
is approved. However, please ensure that thex/circuit
module is fully compatible with any changes introduced in this version of the core module. Thorough testing is recommended to identify and address any potential issues arising from this update.
27-27
: Verify compatibility of schema definitions with the updatedcosmossdk.io/schema
dependency.The version update to
v0.3.0
is approved. However, please review the module's schema definitions to ensure they are fully compatible with any changes introduced in this version of the schema module. Make any necessary adjustments to maintain compatibility and prevent potential issues.x/distribution/go.mod (2)
8-8
: Verify the impact of updatingcosmossdk.io/core
tov1.0.0-alpha.3
.Incrementing the version of
cosmossdk.io/core
fromv1.0.0-alpha.2
tov1.0.0-alpha.3
may introduce updates, bug fixes, or new features. As this is an alpha version, there is a risk of breaking changes.Ensure thorough testing is performed to validate compatibility with this new version and check for any breaking changes that may impact the functionality of the module.
33-33
: Verify the impact of updatingcosmossdk.io/schema
tov0.3.0
.Updating the version of
cosmossdk.io/schema
fromv0.2.0
tov0.3.0
suggests enhancements or modifications in the schema handling. While a minor version update should maintain backwards compatibility, it's important to validate this assumption.Ensure thorough testing is performed to confirm compatibility with this new version and check for any unexpected behavior or breaking changes that may impact the functionality of the module.
x/mint/go.mod (2)
8-8
: Verify compatibility with the updatedcosmossdk.io/core
version.The
cosmossdk.io/core
dependency has been updated to versionv1.0.0-alpha.3
. Please ensure that thex/mint
module is compatible with this version and thoroughly test the module to identify any potential issues arising from the update.
32-32
: Review usage of schema definitions from the updatedcosmossdk.io/schema
version.The
cosmossdk.io/schema
dependency has been updated to versionv0.3.0
. Please review any usages of schema definitions from this module in thex/mint
module and ensure they are still valid and compatible with the updated version.x/gov/go.mod (2)
8-8
: Approve version update forcosmossdk.io/core
.Updating to
v1.0.0-alpha.3
is reasonable, as it likely includes enhancements or bug fixes. However, since this is still an alpha version, ensure thorough testing is performed to validate compatibility and stability with the rest of the codebase.
40-40
: Approve version update forcosmossdk.io/schema
.The update to
v0.3.0
is a reasonable choice, as it likely introduces new backward-compatible functionality. However, it's still prudent to perform testing to validate that there are no unexpected breaking changes that could affect the codebase.client/v2/go.mod (1)
7-7
: Verify the impact of the dependency updates on the application.The versions of
cosmossdk.io/core
andcosmossdk.io/schema
have been updated, which may introduce changes in the core SDK functionality and schema handling.Please ensure that the application has been thoroughly tested with these new versions to confirm that there are no breaking changes or unexpected behaviors.
Also applies to: 29-29
x/feegrant/go.mod (2)
8-8
: LGTM!The version update for
cosmossdk.io/core
fromv1.0.0-alpha.2
tov1.0.0-alpha.3
looks good.
40-40
: LGTM!The version update for
cosmossdk.io/schema
fromv0.2.0
tov0.3.0
looks good.x/accounts/defaults/multisig/go.mod (1)
7-7
: Verify compatibility with updated dependency versions.The updates to the
cosmossdk.io/core
andcosmossdk.io/schema
dependency versions look good. However, it's important to ensure that thex/accounts/defaults/multisig
module remains compatible with these updated versions.To verify compatibility, consider running the following checks:
If any issues are identified during these checks, please address them to maintain compatibility with the updated dependencies.
Also applies to: 26-26
x/accounts/defaults/base/go.mod (2)
8-8
: Review thecosmossdk.io/core
version update carefully.The
cosmossdk.io/core
dependency has been updated fromv1.0.0-alpha.2
tov1.0.0-alpha.3
. While this update might bring enhancements or bug fixes, please be cautious as alpha versions may contain breaking changes or instability risks.Thoroughly test the codebase to ensure compatibility with the updated
core
module and verify overall stability before proceeding.
26-26
: Review thecosmossdk.io/schema
version update.The
cosmossdk.io/schema
dependency has been updated fromv0.2.0
tov0.3.0
. This minor version update suggests there might be new backwards-compatible functionality in theschema
module.Please review the changelog to understand the changes and new features introduced in
v0.3.0
. Ensure thorough testing to verify compatibility with the updatedschema
module.go.mod (2)
8-8
: Thoroughly test the update tocosmossdk.io/core
v1.0.0-alpha.3
.Updating to a new alpha version of the
core
module may introduce breaking changes that could impact the project's functionality. Ensure comprehensive testing is performed to verify compatibility and stability. Adapt the project's code as necessary to accommodate any breaking changes introduced by the newcore
version.
14-14
: Review the changelog forcosmossdk.io/schema
v0.3.0
and ensure compatibility.Updating to a new minor version of the
schema
module may introduce changes that affect how data is structured or processed. Review the changelog to understand the new features or enhancements introduced inv0.3.0
. Ensure the project's code is compatible with any changes introduced by the newschema
version.x/accounts/go.mod (1)
8-8
: Verify compatibility with updated dependencies.The versions of
cosmossdk.io/core
andcosmossdk.io/schema
have been updated tov1.0.0-alpha.3
andv0.3.0
, respectively. While updating dependencies is generally beneficial, it's important to thoroughly test the module to ensure that these updates do not introduce any breaking changes or unexpected behavior.Please confirm that comprehensive testing has been performed to validate the compatibility and stability of the module with the updated dependencies.
Also applies to: 35-35
x/group/go.mod (2)
41-41
: Approve version update forcosmossdk.io/schema
.Upgrading to
v0.3.0
is beneficial to leverage potential enhancements and bug fixes in the schema handling package.Considering the sensitivity of schema changes, ensure comprehensive testing is conducted to validate compatibility and stability. Pay close attention to any schema definitions, migrations, or serialization/deserialization logic. Consider running the following script to identify and analyze all usages of the
cosmossdk.io/schema
package:
7-7
: Approve version update forcosmossdk.io/core
.Upgrading to
v1.0.0-alpha.3
is a good move to incorporate the latest enhancements and bug fixes in the core SDK.Ensure thorough testing is performed to validate compatibility and stability with this alpha version update. Consider running the following script to identify and analyze all usages of the
cosmossdk.io/core
package:x/upgrade/go.mod (1)
7-7
: Verify the compatibility and impact of the updated versions.The versions of
cosmossdk.io/core
andcosmossdk.io/schema
have been updated tov1.0.0-alpha.3
andv0.3.0
, respectively. These updates could introduce enhancements, bug fixes, or changes in functionality.To ensure a smooth integration, please verify that:
- The updated versions are compatible with the rest of the codebase.
- There are no breaking changes introduced by these updates that could negatively impact the application.
Consider running the following script to analyze the usage of these packages across the codebase:
Review the results to identify any potential incompatibilities or areas that may require updates to align with the new versions.
Also applies to: 45-45
server/v2/cometbft/utils.go (3)
76-85
: Improved error handling infinalizeBlockResponse
.The changes enhance the error handling and data retrieval process within the
finalizeBlockResponse
function. By capturing the results ofintoABCIEvents
andintoABCITxResults
in separate variables and returning immediately if either function encounters an error, the code ensures that any issues encountered while processing events or transaction results are properly communicated to the caller. This improvement increases the robustness and reliability of the code by handling errors gracefully and maintaining data integrity throughout the processing flow.
Line range hint
110-136
: Enhanced error handling inintoABCITxResults
.The modifications to the
intoABCITxResults
function improve error propagation by returning an error alongside the results. The retrieval of event attributes now includes error handling, which prevents the code from accessing potentially invalid data. If an error is encountered while processing events, the function returns immediately with the error, ensuring that any issues encountered while processing transaction results are properly communicated to the caller. These enhancements contribute to the overall robustness and reliability of the code.
Line range hint
139-161
: Improved error handling inintoABCIEvents
.The
intoABCIEvents
function has been enhanced to return an error alongside the results, allowing for better error propagation. The retrieval of event attributes now includes error handling, which prevents the code from accessing potentially invalid data. If an error is encountered while retrieving event attributes, the function returns immediately with the error, ensuring that any issues encountered while processing events are properly communicated to the caller. These modifications contribute to the overall robustness and reliability of the code by gracefully handling errors and maintaining data integrity.tests/go.mod (2)
69-69
: Review the changelog and assess the impact of updatingcosmossdk.io/schema
tov0.3.0
.The minor version update suggests potential improvements or changes in functionality. Please review the changelog for
cosmossdk.io/schema
and assess how these changes might impact our codebase. Ensure that any necessary adjustments or migrations are made to maintain compatibility.
8-8
: Verify the impact of updatingcosmossdk.io/core
tov1.0.0-alpha.3
.The version increment suggests potential enhancements or bug fixes. However, as it's still an alpha version, please ensure that this update doesn't introduce any breaking changes or compatibility issues in the codebase.
Run the following script to verify the usage of
cosmossdk.io/core
across the codebase:Verification successful
To properly assess the impact of updating
cosmossdk.io/core
from v1.0.0-alpha.2 to v1.0.0-alpha.3, we need to gather more information about the changes introduced in this version. Let's search for any changelog entries, release notes, or comments in the code that might give us insight into the update.
Based on our search results, we couldn't find any specific information about the changes in
cosmossdk.io/core v1.0.0-alpha.3
within the local repository. This lack of information doesn't necessarily mean there are no significant changes, but it suggests that any changes made might not have required extensive modifications or attention in the current codebase.However, as this is an alpha version update, we should still proceed with caution. Here's what we can conclude:
Proceed with the update, but exercise caution and conduct thorough testing.
While we didn't find any explicit warnings or breaking changes mentioned in the codebase, alpha versions can still introduce subtle changes or new features that might affect the system. Here are some recommendations:
- Before applying the update in production, thoroughly test the entire application with the new version in a staging environment.
- Pay special attention to modules and components that heavily rely on
cosmossdk.io/core
.- Review the official documentation or GitHub repository of
cosmossdk.io/core
for any changelog or release notes that might not be included in this repository.- After updating, monitor the application closely for any unexpected behaviors or performance issues.
If any issues arise during testing or after deployment, be prepared to roll back to the previous version (v1.0.0-alpha.2) if necessary.
Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Description: Verify the usage of `cosmossdk.io/core` and check for potential breaking changes. # Test: Search for the import statements of `cosmossdk.io/core`. # Expect: Review the usage to ensure compatibility with the updated version. rg --type go -A 5 $'cosmossdk.io/core'Length of output: 267499
Script:
#!/bin/bash # Search for changelog or release notes for cosmossdk.io/core v1.0.0-alpha.3 grep -r "cosmossdk.io/core v1.0.0-alpha.3" . --include="CHANGELOG.md" --include="RELEASE_NOTES.md" # Look for any TODO comments or update notes related to this core package update grep -r "TODO.*cosmossdk.io/core" . # Check for any deprecation notices related to cosmossdk.io/core grep -r "deprecated.*cosmossdk.io/core" . # Search for any breaking changes mentioned in comments grep -r "breaking change.*cosmossdk.io/core" .Length of output: 227
simapp/go.mod (2)
65-65
: Verify compatibility of thecosmossdk.io/schema
version update.The version of
cosmossdk.io/schema
has been updated fromv0.2.0
tov0.3.0
. Ensure that this version update is compatible with the rest of the codebase and doesn't introduce any breaking changes.Run the following script to search for usages of
cosmossdk.io/schema
and verify compatibility:
9-9
: Verify compatibility of thecosmossdk.io/core
version update.The version of
cosmossdk.io/core
has been incremented fromv1.0.0-alpha.2
tov1.0.0-alpha.3
. Ensure that this version update is compatible with the rest of the codebase and doesn't introduce any breaking changes.Run the following script to search for usages of
cosmossdk.io/core
and verify compatibility:Verification successful
The update to
cosmossdk.io/core v1.0.0-alpha.3
appears to be compatible.The changelog for this version indicates a single change:
- The
core/event
package is now a type alias ofschema/appdata
.This modification is unlikely to cause compatibility issues as it seems to be an internal restructuring. The functionality of
core/event
should remain the same, just accessed through a different package structure.However, as this is an alpha release, it's always recommended to thoroughly test your application with the new version to ensure everything works as expected.
Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Description: Search for usages of `cosmossdk.io/core` and verify compatibility. # Test: Search for import statements and function calls related to `cosmossdk.io/core`. rg --type go -A 5 $'cosmossdk\.io/core'Length of output: 267502
Script:
#!/bin/bash # Search for changelog or release notes for cosmossdk.io/core v1.0.0-alpha.3 echo "Searching for changelog or release notes..." grep -r -i "changelog" --include="*.md" || true grep -r -i "release notes" --include="*.md" || true echo "Searching for v1.0.0-alpha.3 specific information..." grep -r -i "v1.0.0-alpha.3" --include="*.md" || trueLength of output: 20659
Script:
#!/bin/bash # Extract the changelog entry for v1.0.0-alpha.3 from core/CHANGELOG.md echo "Changelog for core v1.0.0-alpha.3:" sed -n '/## \[v1.0.0-alpha.3\]/,/## \[v1.0.0-alpha.2\]/p' core/CHANGELOG.md | sed '$d'Length of output: 391
server/v2/cometbft/abci.go (2)
129-132
: Excellent refactoring to improve code readability and error handling!Extracting the event processing logic into a separate variable
events
and handling the error makes the code more readable and maintainable. If an error occurs during event conversion, it is properly propagated and handled.
138-138
: Proper usage of theevents
variable.The
events
variable, which holds the converted ABCI events, is correctly assigned to theEvents
field in theCheckTxResponse
. This ensures that the processed events are included in the response.x/bank/keeper/keeper_test.go (2)
1380-1400
: LGTM!The refactoring of event attribute construction using a closure enhances code readability and maintainability. The test logic is correct, and the implementation is accurate.
1461-1496
: LGTM!The refactoring of event attribute construction using closures for each event enhances code readability and maintainability. The test logic is correct, and the implementation is accurate.
@@ -81,6 +81,6 @@ func TypedEventToEvent(tev transaction.Msg) (event.Event, error) { | |||
|
|||
return event.Event{ | |||
Type: evtType, | |||
Attributes: attrs, | |||
Attributes: func() ([]event.Attribute, error) { return attrs, nil }, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We can actually wrap all the logic in TypedEventToEvent
in this closure so that JSON marshaling is done lazily. Let's do that in a follow up PR though, and merge this.
(cherry picked from commit 01212de) # Conflicts: # client/v2/go.mod # client/v2/go.sum # collections/collections.go # collections/go.mod # collections/go.sum # collections/indexing.go # go.mod # go.sum # runtime/v2/go.mod # runtime/v2/go.sum # server/v2/cometbft/go.mod # server/v2/cometbft/go.sum # server/v2/go.mod # server/v2/go.sum # server/v2/stf/core_event_service.go # server/v2/stf/go.mod # server/v2/stf/go.sum # server/v2/stf/stf.go # server/v2/streaming/utils.go # simapp/go.mod # simapp/go.sum # simapp/v2/go.mod # simapp/v2/go.sum # tests/go.mod # tests/go.sum # x/accounts/defaults/base/go.mod # x/accounts/defaults/base/go.sum # x/accounts/defaults/lockup/go.mod # x/accounts/defaults/lockup/go.sum # x/accounts/defaults/multisig/go.mod # x/accounts/defaults/multisig/go.sum # x/accounts/go.mod # x/accounts/go.sum # x/authz/go.mod # x/authz/go.sum # x/bank/go.mod # x/bank/go.sum # x/circuit/go.mod # x/circuit/go.sum # x/consensus/go.mod # x/consensus/go.sum # x/distribution/go.mod # x/distribution/go.sum # x/epochs/go.mod # x/epochs/go.sum # x/evidence/go.mod # x/evidence/go.sum # x/feegrant/go.mod # x/feegrant/go.sum # x/gov/go.mod # x/gov/go.sum # x/group/go.mod # x/group/go.sum # x/mint/go.mod # x/mint/go.sum # x/nft/go.mod # x/nft/go.sum # x/params/go.mod # x/params/go.sum # x/protocolpool/go.mod # x/protocolpool/go.sum # x/slashing/go.mod # x/slashing/go.sum # x/staking/go.mod # x/staking/go.sum # x/upgrade/go.mod # x/upgrade/go.sum
) Co-authored-by: cool-developer <[email protected]> Co-authored-by: Julien Robert <[email protected]>
Description
Closes: #21527
Author Checklist
All items are required. Please add a note to the item if the item is not applicable and
please add links to any relevant follow up issues.
I have...
!
in the type prefix if API or client breaking changeCHANGELOG.md
Reviewers Checklist
All items are required. Please add a note if the item is not applicable and please add
your handle next to the items reviewed if you only reviewed selected items.
Please see Pull Request Reviewer section in the contributing guide for more information on how to review a pull request.
I have...
Summary by CodeRabbit