-
Notifications
You must be signed in to change notification settings - Fork 188
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: bump to cairo 2.9.2 #2879
base: main
Are you sure you want to change the base?
Conversation
WalkthroughOhayo, sensei! This pull request represents a comprehensive upgrade across the Dojo ecosystem, primarily focusing on version bumps from Cairo 2.8.4 to 2.9.2. The changes span multiple components including core libraries, language plugins, executors, and example projects. The upgrade involves updating dependency versions, refining type handling, and making minor syntactical improvements across the codebase. Changes
Sequence DiagramsequenceDiagram
participant Dev as Developer
participant CI as CI Workflow
participant Scarb as Scarb Build Tool
participant Cairo as Cairo Compiler
participant Dojo as Dojo Framework
Dev->>CI: Trigger Pull Request
CI->>Scarb: Use Scarb 2.9.2
Scarb->>Cairo: Compile with Cairo 2.9.2
Cairo->>Dojo: Generate Artifacts
Dojo-->>CI: Build Successful
CI-->>Dev: Validation Complete
The sequence diagram illustrates the high-level workflow of how the version upgrades propagate through the development and build process, ensuring compatibility and smooth transitions across the Dojo ecosystem. Possibly related PRs
🪧 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
|
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: 3
🧹 Nitpick comments (9)
crates/dojo/lang/src/inline_macros/spawn_test_world.rs (1)
101-101
: Ohayo! LGTM with a small suggestion, sensei!The addition of
diagnostics_note
field is consistent with the Cairo 2.9.2 upgrade. Consider adding trace logging for diagnostic notes when they're present in the future, similar to how you're logging namespaces and models.trace!(?namespaces, ?models, "Spawning test world from macro."); +// Future enhancement when diagnostics_note is used: +// if let Some(note) = &diagnostics_note { +// trace!(?note, "Diagnostic note present"); +// }crates/dojo/lang/src/attribute_macros/interface.rs (1)
89-89
: Ohayo! Consider future diagnostic note usage, sensei!While the
diagnostics_note
addition is correct, this interface implementation might benefit from actual diagnostic notes in the future, especially for trait-specific validations.Consider utilizing this field in future updates to provide more detailed diagnostic information about trait implementations and interface-specific validations.
bin/sozo/src/commands/test.rs (4)
125-125
: Avoid reassigning theis_included
variableOhayo, sensei! In line 125, the variable
is_included
is reassigned, which may cause confusion and reduce code readability. It's better to use a different variable name or combine the conditions to avoid reusing the same variable name in the same scope.Consider combining the conditions into a single expression or using a new variable name:
-let is_included = opts.include_target_kinds.is_empty() +let include_target_kind = opts.include_target_kinds.is_empty() || opts.include_target_kinds.contains(&cu.main_component().target_kind()); -let is_included = is_included +let is_included = include_target_kind && (opts.include_target_names.is_empty() || cu .main_component() .targets .iter() .any(|t| opts.include_target_names.contains(&t.name)));
Line range hint
414-421
: Updatel2_gas_price
to the correct valuesOhayo, sensei! There are TODO comments in lines 414 and 420 suggesting that the
l2_gas_price
values foreth_gas_prices
andstrk_gas_prices
need to be updated. Accurate gas price information is crucial for proper fee calculation and transaction processing.Would you like assistance in determining and updating the correct
l2_gas_price
values, or should we open a GitHub issue to address this?
Line range hint
568-573
: Address the TODO regarding contract class conversionsOhayo, sensei! In lines 568-573, there's a TODO comment expressing uncertainty about the variant to use in
to_runnable_class
for contract class conversions. This might impact how different contract classes are handled during execution.Would you like me to research and propose a solution for handling the different variants, or open a GitHub issue to track this task?
Line range hint
588-599
: Clarify ABI length retrieval for Sierra classesOhayo, sensei! In lines 592-599, there's a TODO comment about retrieving the ABI length for Sierra classes in the
to_class_info
function. Properly obtaining the ABI length is important for accurate class information.Do you want assistance in determining how to retrieve the ABI length for Sierra classes, or should we open a GitHub issue to address this?
crates/katana/pool/src/validation/stateful.rs (1)
204-212
: Enhanced panic handling implementation!Added proper handling for PanicInValidate with default values for address and class_hash.
Consider adding actual address and class_hash values instead of defaults when available from the context.
crates/katana/rpc/rpc/tests/starknet.rs (1)
Line range hint
929-950
: Ohayo! Improved v3 transaction testing.The error handling has been simplified using
unwrap()
. While this works for tests, consider adding more descriptive error messages for better debugging.Consider adding error context:
- .unwrap(); + .unwrap_or_else(|e| panic!("Failed to execute v3 transaction: {}", e));crates/katana/cairo/Cargo.toml (1)
21-21
: Consider using a tag instead of commit hash, sensei! 🎯Using a specific commit hash (
92da150d
) forstarknet_api
might make builds less reproducible compared to using version tags.Consider using a version tag if available:
-starknet_api = { git = "https://github.com/dojoengine/sequencer", rev = "92da150d" } +starknet_api = { git = "https://github.com/dojoengine/sequencer", tag = "v0.9.0" }
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
⛔ Files ignored due to path filters (11)
Cargo.lock
is excluded by!**/*.lock
crates/benches/contracts/Scarb.lock
is excluded by!**/*.lock
crates/dojo/core-cairo-test/Scarb.lock
is excluded by!**/*.lock
crates/dojo/core/Scarb.lock
is excluded by!**/*.lock
crates/dojo/lang/Scarb.lock
is excluded by!**/*.lock
crates/torii/types-test/Scarb.lock
is excluded by!**/*.lock
examples/game-lib/Scarb.lock
is excluded by!**/*.lock
examples/simple/Scarb.lock
is excluded by!**/*.lock
examples/spawn-and-move/Scarb.lock
is excluded by!**/*.lock
spawn-and-move-db.tar.gz
is excluded by!**/*.gz
types-test-db.tar.gz
is excluded by!**/*.gz
📒 Files selected for processing (100)
.github/workflows/ci.yml
(1 hunks).tool-versions
(1 hunks)Cargo.toml
(4 hunks)bin/sozo/benches/spawn-and-move-build.rs
(1 hunks)bin/sozo/src/commands/build.rs
(1 hunks)bin/sozo/src/commands/test.rs
(6 hunks)crates/benches/contracts/Scarb.toml
(2 hunks)crates/benches/contracts/src/models/character.cairo
(1 hunks)crates/dojo/core-cairo-test/Scarb.toml
(1 hunks)crates/dojo/core-cairo-test/src/lib.cairo
(1 hunks)crates/dojo/core-cairo-test/src/tests/benchmarks.cairo
(12 hunks)crates/dojo/core-cairo-test/src/tests/contract.cairo
(1 hunks)crates/dojo/core-cairo-test/src/tests/event/event.cairo
(1 hunks)crates/dojo/core-cairo-test/src/tests/helpers/event.cairo
(1 hunks)crates/dojo/core-cairo-test/src/tests/helpers/helpers.cairo
(6 hunks)crates/dojo/core-cairo-test/src/tests/helpers/model.cairo
(1 hunks)crates/dojo/core-cairo-test/src/tests/meta/introspect.cairo
(6 hunks)crates/dojo/core-cairo-test/src/tests/model/model.cairo
(2 hunks)crates/dojo/core-cairo-test/src/tests/storage/packing.cairo
(6 hunks)crates/dojo/core-cairo-test/src/tests/utils/hash.cairo
(1 hunks)crates/dojo/core-cairo-test/src/tests/utils/key.cairo
(1 hunks)crates/dojo/core-cairo-test/src/tests/utils/layout.cairo
(4 hunks)crates/dojo/core-cairo-test/src/tests/utils/misc.cairo
(2 hunks)crates/dojo/core-cairo-test/src/tests/world/acl.cairo
(9 hunks)crates/dojo/core-cairo-test/src/tests/world/contract.cairo
(7 hunks)crates/dojo/core-cairo-test/src/tests/world/event.cairo
(16 hunks)crates/dojo/core-cairo-test/src/tests/world/metadata.cairo
(6 hunks)crates/dojo/core-cairo-test/src/tests/world/model.cairo
(17 hunks)crates/dojo/core-cairo-test/src/tests/world/namespace.cairo
(3 hunks)crates/dojo/core-cairo-test/src/tests/world/storage.cairo
(2 hunks)crates/dojo/core-cairo-test/src/tests/world/world.cairo
(10 hunks)crates/dojo/core-cairo-test/src/utils.cairo
(1 hunks)crates/dojo/core-cairo-test/src/world.cairo
(7 hunks)crates/dojo/core/Scarb.toml
(1 hunks)crates/dojo/core/src/contract/components/upgradeable.cairo
(2 hunks)crates/dojo/core/src/contract/components/world_provider.cairo
(2 hunks)crates/dojo/core/src/event/component.cairo
(2 hunks)crates/dojo/core/src/event/event.cairo
(2 hunks)crates/dojo/core/src/lib.cairo
(3 hunks)crates/dojo/core/src/meta/introspect.cairo
(2 hunks)crates/dojo/core/src/meta/layout.cairo
(2 hunks)crates/dojo/core/src/model/component.cairo
(2 hunks)crates/dojo/core/src/model/definition.cairo
(1 hunks)crates/dojo/core/src/model/metadata.cairo
(2 hunks)crates/dojo/core/src/model/model.cairo
(2 hunks)crates/dojo/core/src/model/model_value.cairo
(1 hunks)crates/dojo/core/src/model/storage.cairo
(4 hunks)crates/dojo/core/src/storage/database.cairo
(1 hunks)crates/dojo/core/src/storage/entity_model.cairo
(6 hunks)crates/dojo/core/src/storage/layout.cairo
(19 hunks)crates/dojo/core/src/storage/packing.cairo
(7 hunks)crates/dojo/core/src/storage/storage.cairo
(11 hunks)crates/dojo/core/src/utils/layout.cairo
(2 hunks)crates/dojo/core/src/utils/misc.cairo
(1 hunks)crates/dojo/core/src/utils/serde.cairo
(1 hunks)crates/dojo/core/src/utils/snf_test.cairo
(2 hunks)crates/dojo/core/src/world/errors.cairo
(1 hunks)crates/dojo/core/src/world/iworld.cairo
(8 hunks)crates/dojo/core/src/world/resource.cairo
(1 hunks)crates/dojo/core/src/world/storage.cairo
(24 hunks)crates/dojo/core/src/world/world_contract.cairo
(43 hunks)crates/dojo/lang/Scarb.toml
(1 hunks)crates/dojo/lang/src/attribute_macros/contract.rs
(1 hunks)crates/dojo/lang/src/attribute_macros/event.rs
(1 hunks)crates/dojo/lang/src/attribute_macros/interface.rs
(1 hunks)crates/dojo/lang/src/attribute_macros/model.rs
(1 hunks)crates/dojo/lang/src/derive_macros/mod.rs
(1 hunks)crates/dojo/lang/src/inline_macros/delete.rs
(1 hunks)crates/dojo/lang/src/inline_macros/emit.rs
(1 hunks)crates/dojo/lang/src/inline_macros/get.rs
(1 hunks)crates/dojo/lang/src/inline_macros/get_models_test_class_hashes.rs
(1 hunks)crates/dojo/lang/src/inline_macros/selector_from_tag.rs
(1 hunks)crates/dojo/lang/src/inline_macros/set.rs
(1 hunks)crates/dojo/lang/src/inline_macros/spawn_test_world.rs
(1 hunks)crates/dojo/test-utils/src/compiler.rs
(2 hunks)crates/dojo/world/abigen/src/main.rs
(2 hunks)crates/dojo/world/src/contracts/abigen/model.rs
(7 hunks)crates/katana/cairo/Cargo.toml
(1 hunks)crates/katana/executor/Cargo.toml
(1 hunks)crates/katana/executor/src/implementation/blockifier/error.rs
(1 hunks)crates/katana/executor/src/implementation/blockifier/mod.rs
(4 hunks)crates/katana/executor/src/implementation/blockifier/state.rs
(5 hunks)crates/katana/executor/src/implementation/blockifier/utils.rs
(21 hunks)crates/katana/pool/src/validation/stateful.rs
(3 hunks)crates/katana/primitives/src/conversion/rpc.rs
(2 hunks)crates/katana/rpc/rpc-types/src/class.rs
(2 hunks)crates/katana/rpc/rpc/tests/starknet.rs
(4 hunks)crates/torii/types-test/Scarb.toml
(1 hunks)examples/game-lib/Scarb.toml
(1 hunks)examples/game-lib/armory/Scarb.toml
(1 hunks)examples/game-lib/bestiary/Scarb.toml
(1 hunks)examples/simple/Scarb.toml
(2 hunks)examples/simple/manifest_dev.json
(5 hunks)examples/simple/src/lib.cairo
(4 hunks)examples/spawn-and-move/Scarb.toml
(2 hunks)examples/spawn-and-move/dojo_dev.toml
(1 hunks)examples/spawn-and-move/src/actions.cairo
(7 hunks)examples/spawn-and-move/src/models.cairo
(3 hunks)rust-toolchain.toml
(1 hunks)xtask/generate-test-db/src/main.rs
(1 hunks)
✅ Files skipped from review due to trivial changes (54)
- crates/dojo/core/src/world/resource.cairo
- rust-toolchain.toml
- crates/dojo/core-cairo-test/src/tests/utils/key.cairo
- .tool-versions
- examples/game-lib/Scarb.toml
- crates/dojo/core/src/lib.cairo
- crates/dojo/core-cairo-test/src/tests/event/event.cairo
- crates/dojo/core/src/utils/serde.cairo
- crates/dojo/lang/Scarb.toml
- crates/dojo/core-cairo-test/src/tests/utils/misc.cairo
- crates/dojo/core/src/event/event.cairo
- crates/dojo/core/src/utils/misc.cairo
- crates/dojo/core-cairo-test/src/tests/model/model.cairo
- crates/dojo/core/src/model/definition.cairo
- crates/dojo/core/src/model/metadata.cairo
- xtask/generate-test-db/src/main.rs
- crates/dojo/core/src/storage/database.cairo
- crates/dojo/core-cairo-test/src/tests/world/metadata.cairo
- crates/dojo/core-cairo-test/src/tests/utils/hash.cairo
- crates/dojo/core/src/world/errors.cairo
- crates/dojo/core/src/model/model_value.cairo
- examples/simple/src/lib.cairo
- crates/dojo/core/src/utils/snf_test.cairo
- crates/dojo/core/src/model/model.cairo
- crates/dojo/core-cairo-test/src/tests/world/contract.cairo
- crates/dojo/core-cairo-test/src/tests/storage/packing.cairo
- examples/spawn-and-move/dojo_dev.toml
- crates/dojo/core-cairo-test/src/tests/world/storage.cairo
- crates/dojo/core-cairo-test/src/tests/helpers/model.cairo
- crates/benches/contracts/src/models/character.cairo
- crates/dojo/core-cairo-test/src/lib.cairo
- crates/dojo/core-cairo-test/src/tests/world/world.cairo
- crates/dojo/core-cairo-test/src/tests/world/event.cairo
- examples/spawn-and-move/src/actions.cairo
- crates/dojo/core-cairo-test/src/tests/world/acl.cairo
- crates/dojo/core-cairo-test/src/world.cairo
- crates/dojo/core-cairo-test/src/tests/world/namespace.cairo
- crates/dojo/core/src/contract/components/upgradeable.cairo
- crates/dojo/core-cairo-test/src/tests/benchmarks.cairo
- crates/dojo/core/src/meta/layout.cairo
- crates/dojo/core-cairo-test/src/tests/helpers/helpers.cairo
- crates/dojo/core-cairo-test/src/tests/utils/layout.cairo
- crates/dojo/core/src/model/component.cairo
- crates/dojo/core-cairo-test/src/tests/world/model.cairo
- examples/spawn-and-move/src/models.cairo
- crates/dojo/core/src/storage/storage.cairo
- crates/dojo/core/src/meta/introspect.cairo
- crates/dojo/core/src/storage/packing.cairo
- crates/dojo/core/src/storage/entity_model.cairo
- crates/dojo/core/src/world/storage.cairo
- crates/dojo/core/src/model/storage.cairo
- crates/dojo/core-cairo-test/src/tests/meta/introspect.cairo
- crates/dojo/core/src/world/iworld.cairo
- crates/dojo/core/src/world/world_contract.cairo
⏰ Context from checks skipped due to timeout of 90000ms (3)
- GitHub Check: docs
- GitHub Check: clippy
- GitHub Check: build
🔇 Additional comments (59)
crates/dojo/lang/src/inline_macros/selector_from_tag.rs (1)
70-70
: Ohayo! LGTM, sensei!The addition of
diagnostics_note
field is consistent with the Cairo 2.9.2 upgrade requirements.crates/dojo/lang/src/inline_macros/get.rs (1)
102-102
: Ohayo! LGTM, sensei!The addition of
diagnostics_note
field aligns with the Cairo 2.9.2 upgrade pattern.crates/dojo/lang/src/inline_macros/get_models_test_class_hashes.rs (1)
100-100
: Ohayo! LGTM, sensei!The addition of
diagnostics_note
field maintains consistency with the Cairo 2.9.2 upgrade changes.crates/dojo/lang/src/inline_macros/delete.rs (1)
108-108
: Ohayo! LGTM on the diagnostics_note addition, sensei!The addition of
diagnostics_note
field aligns with Cairo 2.9.2's requirements for plugin-generated files.crates/dojo/lang/src/inline_macros/emit.rs (1)
112-112
: Consistent implementation, looking good sensei!The
diagnostics_note
field addition matches the pattern across other files.crates/dojo/lang/src/inline_macros/set.rs (1)
124-124
: Implementation aligns perfectly with Cairo 2.9.2, sensei!The
diagnostics_note
field is correctly added to support the new diagnostic capabilities.crates/dojo/lang/src/attribute_macros/event.rs (1)
161-161
: Ohayo! LGTM - Consistent with Cairo 2.9.2 upgrade.The addition of
diagnostics_note: None
aligns with the newPluginGeneratedFile
structure in Cairo 2.9.2.crates/dojo/lang/src/derive_macros/mod.rs (1)
58-58
: Ohayo sensei! LGTM - Maintaining consistency.The addition of
diagnostics_note: None
matches the pattern seen in other files, ensuring consistent structure across the codebase.crates/dojo/lang/src/attribute_macros/model.rs (1)
204-204
: Ohayo! LGTM - Aligned with Cairo upgrade.The addition of
diagnostics_note: None
follows the same pattern as other files in this upgrade.crates/dojo/lang/src/attribute_macros/contract.rs (1)
155-155
: Ohayo sensei! LGTM - Consistent implementation.The addition of
diagnostics_note: None
completes the consistent pattern of updates across all plugin-generated files.bin/sozo/src/commands/test.rs (2)
Line range hint
95-104
: Review the fee calculation logicOhayo, sensei! There's a TODO comment in line 95 indicating uncertainty about the correctness of the fee calculation logic. This could affect transaction fee processing and overall system integrity.
Would you like me to help verify and correct the fee calculation logic? I can provide assistance or open a GitHub issue to track this task.
278-279
: Ensure consistent use ofdiscriminator
inCrateLongId::Real
Ohayo, sensei! In lines 278-279, the
discriminator
is set toNone
when interning crates incollect_crates_ids_from_selectors
. However, incollect_all_crate_ids
(lines 287-290), thediscriminator
is derived fromcomponent.id.to_discriminator()
. For consistency and to prevent potential issues with crate identification, please verify if thediscriminator
should be set appropriately here.If the
discriminator
is necessary for distinguishing between crates, consider updating the code:-db.intern_crate(CrateLongId::Real { name: package_name, discriminator: None }) +db.intern_crate(CrateLongId::Real { name: package_name, discriminator: Some(discriminator_value) })Please ensure that
discriminator_value
is correctly obtained for each package.crates/dojo/core/src/event/component.cairo (3)
6-8
: Consistent inclusion ofEvent<E>
improves trait implementationsOhayo, sensei! Including
Event<E>
in the implementation parameters ensures consistent and explicit typing across the trait implementations. This enhances type safety and code clarity.
15-18
: Trait implementations correctly updated withEvent<E>
Ohayo, sensei! The addition of
Event<E>
in the trait implementations forIStoredResource
aligns with the type definitions and improves consistency.
Line range hint
21-23
: Proper extension ofIEventImpl
withEvent<E>
Ohayo, sensei! The implementation of
IEventImpl
now correctly includesEvent<E>
, ensuring that event definitions are accurately represented.crates/dojo/core/src/contract/components/world_provider.cairo (1)
22-23
: Ohayo! Breaking change in type parameters needs verification.The change from
TContractState
toHasComponent<TContractState>
is a breaking change that might affect existing implementations.Let's verify the impact:
Also applies to: 31-32
✅ Verification successful
Ohayo sensei! No breaking change detected - requirement already exists.
The change from
TContractState
toHasComponent<TContractState>
formalizes an existing requirement. All contracts implementing WorldProvider already require HasComponent trait for component functionality.🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Search for existing implementations that might be affected rg -l "impl (World|Internal)Provider<\w+>"Length of output: 44
Script:
#!/bin/bash # Search with broader patterns echo "=== Searching for WorldProvider usage ===" rg "WorldProvider" -A 2 -B 2 echo -e "\n=== Searching for component-related implementations ===" rg "impl.*Component.*for" -A 2 -B 2 echo -e "\n=== Checking files containing Provider in their name ===" fd "provider" --type fLength of output: 126062
Script:
#!/bin/bash # Search for HasComponent usage and requirements echo "=== Searching for HasComponent trait requirements ===" rg "HasComponent" -A 2 -B 2 echo -e "\n=== Searching for TContractState usage patterns ===" rg "TContractState" -A 2 -B 2Length of output: 68764
crates/dojo/core/src/utils/layout.cairo (1)
5-5
: Ohayo sensei! LGTM - Syntax improvements.The addition of trailing commas aligns with Cairo 2.9.2's syntax style and improves consistency.
Also applies to: 40-40
bin/sozo/benches/spawn-and-move-build.rs (1)
26-26
: Ohayo! Good addition of version checking.Explicitly setting
ignore_cairo_version: false
ensures proper version compatibility checks during compilation.Let's verify this option is consistently set across the codebase:
✅ Verification successful
Ohayo! Version checking is properly configured across the codebase
The
ignore_cairo_version: false
setting is consistently used in all production and benchmark code. There's one exception in test utilities where it's set totrue
, but this is acceptable as test utilities often need to work with multiple versions.🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Check for other CompileOpts usage rg "CompileOpts\s*\{" -A 5Length of output: 2400
crates/katana/executor/src/implementation/blockifier/error.rs (1)
34-35
: Ohayo sensei! Improved error handling.The change to use
error_trace
directly provides better error reporting and aligns with Cairo 2.9.2's enhanced error handling capabilities.crates/dojo/core-cairo-test/src/tests/contract.cairo (1)
180-180
: Ohayo! LGTM on the panic message formatting, sensei!The addition of the closing parenthesis properly formats the panic message structure.
crates/dojo/world/abigen/src/main.rs (1)
26-26
: Ohayo! Let's verify the model artifact path changes, sensei!The model artifact path has been updated to use the new naming convention. Let's verify no other paths are affected.
✅ Verification successful
Ohayo! All clear on the artifact path changes, sensei!
The updated path
dojo_m_ResourceMetadata.contract_class.json
is the only instance that needed changing. No other files were using the old path format, and all other contract class files are following their own consistent naming patterns.🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Search for any remaining old-style artifact paths rg -l "dojo_resource_metadata\.contract_class\.json"Length of output: 54
Script:
#!/bin/bash # Search with broader patterns to catch variations echo "=== Searching for contract class JSON files ===" rg -i "contract_class\.json" -A 2 -B 2 echo -e "\n=== Searching for resource metadata related paths ===" rg -i "resource.?metadata" -A 2 -B 2 echo -e "\n=== Listing all .json files in target directories ===" fd -e json . "target/"Length of output: 40894
crates/katana/pool/src/validation/stateful.rs (2)
169-171
: Ohayo! Nice flag configuration, sensei!Clean implementation of execution flags with explicit validation and fee check controls.
172-173
: Transaction type update looks good!Updated from AccountTransaction to Account to align with Cairo 2.9.2's transaction handling.
bin/sozo/src/commands/build.rs (1)
106-106
: Ohayo! Good choice on version checking, sensei!Explicitly setting ignore_cairo_version to false ensures proper version compatibility checks during compilation.
✅ Verification successful
Ohayo! Your version checking wisdom is spot on, sensei!
The cairo-version 2.9.2 is used across multiple core packages and examples in the ecosystem. Setting
ignore_cairo_version
to false is the right choice to maintain version compatibility and prevent potential issues.🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Verify cairo version specifications across the project rg -l "cairo-version.*=.*2\.9\.2" --type tomlLength of output: 211
crates/katana/executor/src/implementation/blockifier/mod.rs (2)
240-266
: Structured gas price access looks clean, sensei!The nested access to gas prices through block context is well-organized and type-safe.
104-110
: Ohayo! Gas price initialization looks good but needs verification.The initialization of gas prices with fallback to
NonzeroGasPrice::MIN
is a safe approach.Let's verify the gas price handling in other parts of the codebase:
✅ Verification successful
Ohayo! Gas price initialization is verified and consistent, sensei! ✨
The fallback to
NonzeroGasPrice::MIN
is consistently implemented across the codebase and properly integrated with the default gas price constants. The implementation provides a robust multi-layer safety net through configuration options, default constants, and MIN value fallbacks.🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Search for other gas price initializations to ensure consistency rg -A 3 "NonzeroGasPrice::new|NonzeroGasPrice::MIN"Length of output: 2516
Script:
#!/bin/bash # Search for gas price related types and constants rg -g "*.rs" "(?i)(struct|enum|type|const).*gas.*price"Length of output: 1228
crates/katana/rpc/rpc-types/src/class.rs (2)
9-11
: Import reorganization for deprecated contract class.Clean separation of concerns by moving entry point types to deprecated namespace.
130-130
: Type update aligns with Cairo 2.9.2 changes.The change from
EntryPoint
toEntryPointV0
reflects the new versioning scheme.Let's verify the consistency of this change:
✅ Verification successful
Ohayo sensei!
EntryPoint to EntryPointV0 migration is properly implemented
The change aligns with Cairo 2.9.2's versioning scheme and is consistently applied across the codebase. No remaining instances of the old type were found.
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Check for any remaining old EntryPoint usages rg "Vec<EntryPoint>" --type rustLength of output: 34
Script:
#!/bin/bash # Search for any remaining EntryPoint usages (excluding EntryPointV0) rg "EntryPoint[^V]" --type rust -A 2 # Search for EntryPointV0 usages to confirm adoption rg "EntryPointV0" --type rust -A 2 # Check imports related to EntryPoint ast-grep --pattern 'use $$$EntryPoint$$$;'Length of output: 30319
crates/katana/primitives/src/conversion/rpc.rs (2)
7-9
: Import alignment with RPC types, nice work sensei!The imports are properly organized to match the changes in class.rs.
38-41
: Function signatures updated consistently.The change to
EntryPointV0
is applied consistently across the conversion functions.crates/dojo/test-utils/src/compiler.rs (2)
323-324
: Consistent version handling in compilation units.The
ignore_cairo_version
parameter is properly propagated to the compilation units generation.
174-174
: Cairo version check disabled for testing.Setting
ignore_cairo_version: true
allows for more flexible testing scenarios.Let's check if this is consistently applied:
✅ Verification successful
Ohayo sensei! Here's what I found:
✓ Version check bypass is correctly isolated to test utilities
The
ignore_cairo_version: true
flag is exclusively used in test utilities, while all production code paths explicitly set it tofalse
. This is the correct approach for maintaining version safety in production while allowing flexible testing scenarios.🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Check for other ignore_cairo_version usages rg "ignore_cairo_version.*=.*true" --type rustLength of output: 48
Script:
#!/bin/bash # Search for any mention of ignore_cairo_version rg "ignore_cairo_version" --type rust -A 2 -B 2 # Look for struct definitions containing cairo_version ast-grep --pattern 'struct $_ { $$$ cairo_version $$$ }' # Search for version-related configurations rg "cairo.*version" --type rust -A 2 -B 2Length of output: 9403
crates/dojo/core/src/storage/layout.cairo (1)
Line range hint
1-475
: Ohayo, sensei! The layout changes look good.The changes in this file are purely syntactical, adding trailing commas to function signatures. This aligns with modern Cairo syntax conventions and improves code consistency.
crates/katana/executor/src/implementation/blockifier/state.rs (2)
351-367
: Test adaptations look good, sensei!The tests have been properly updated to use
to_runnable_class
, maintaining test coverage while adapting to the new type system.
49-60
: Ohayo! Important architectural change in compiled class handling.The transition from
ContractClass
toRunnableCompiledClass
represents a significant architectural improvement:
- More specific type for compiled classes
- Better alignment with Cairo 2.9.2's class handling mechanisms
Let's verify the usage of this new type across the codebase:
✅ Verification successful
Ohayo! No architectural concerns with the ContractClass to RunnableCompiledClass transition.
The change is safely contained within the blockifier executor implementation:
- RunnableCompiledClass is just an intermediate execution-time representation
- Main ContractClass type remains unchanged across the codebase
- Conversion is handled cleanly via utils::to_runnable_class
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Search for any remaining uses of the old ContractClass type rg "ContractClass" --type rust # Search for RunnableCompiledClass usage to ensure consistent adoption rg "RunnableCompiledClass" --type rustLength of output: 42627
crates/dojo/world/src/contracts/abigen/model.rs (2)
224-224
: Ohayo! Enhanced metadata structure with hash field.The addition of
metadata_hash
to both ResourceMetadata and ResourceMetadataValue structs improves the metadata handling capabilities.Also applies to: 261-261
597-606
: New ensure_unique functionality added.The
ensure_unique
method has been added to both ModelContract and ModelContractReader, providing consistent uniqueness validation.Also applies to: 714-723
crates/katana/rpc/rpc/tests/starknet.rs (1)
1148-1175
: Nice test coverage expansion, sensei!The new
call_contract
test improves coverage by testing both legacy and standard contracts. The use ofabigen!
for AccountContract demonstrates proper contract interaction patterns.examples/game-lib/armory/Scarb.toml (1)
5-8
: Ohayo! LGTM - Workspace configuration looks good, sensei!The workspace configuration changes align with the standardization efforts across the project.
examples/game-lib/bestiary/Scarb.toml (1)
5-8
: LGTM - Consistent workspace setup!The workspace configuration mirrors the changes in armory/Scarb.toml, maintaining consistency.
crates/torii/types-test/Scarb.toml (1)
2-2
: LGTM - Cairo version bump to 2.9.2!Version update aligns with the target upgrade version.
crates/benches/contracts/Scarb.toml (1)
2-2
: Verify version consistency, sensei!The Cairo and Starknet versions are set to 2.9.1, while other files in the PR use 2.9.2. This inconsistency should be addressed.
Consider updating both versions to 2.9.2 to maintain consistency:
-cairo-version = "=2.9.1" +cairo-version = "=2.9.2" -starknet = "=2.9.1" +starknet = "=2.9.2"Also applies to: 11-11
crates/dojo/core-cairo-test/Scarb.toml (1)
2-2
: LGTM - Consistent version updates across dependencies!All versions (Cairo, Starknet, and cairo_test) are properly aligned at 2.9.2, and the package version has been bumped to 1.0.5.
Also applies to: 6-6, 9-9, 13-13
crates/dojo/core/Scarb.toml (1)
2-2
: Ohayo sensei! Version updates look consistent! 🎉All dependencies are properly aligned to version 2.9.2:
- cairo-version: 2.9.2
- starknet: 2.9.2
- cairo_test: 2.9.2
Also applies to: 9-9, 14-14
examples/simple/Scarb.toml (1)
2-2
: Versions in sync with core, sensei! ✨Example project dependencies properly aligned to 2.9.2.
Also applies to: 14-14
examples/spawn-and-move/Scarb.toml (1)
2-2
: Another perfect version alignment, sensei! 🌟All dependencies properly updated to 2.9.2.
Also applies to: 19-19
crates/katana/cairo/Cargo.toml (1)
Line range hint
12-17
: Ohayo! Consider updating cairo dependencies, sensei! 🤔The cairo-lang dependencies are still at version 2.7.0 while the rest of the project is moving to 2.9.2. This might cause compatibility issues.
Could you verify if these dependencies need to be updated as well?
crates/dojo/core-cairo-test/src/utils.cairo (1)
52-52
: Clean formatting update, sensei! ✨Removing the trailing comma in the assert macro aligns with Cairo 2.9.2 style guidelines.
Cargo.toml (1)
148-169
: Ohayo sensei! Let's verify the Cairo 2.9.2 upgrade compatibility.The upgrade from Cairo 2.8.4 to 2.9.2 looks good. However, we should verify:
- Breaking changes in Cairo 2.9.2
- Compatibility between scarb revision and Cairo version
- Impact of switching starknet_api to git dependency
Also applies to: 213-214, 223-224
✅ Verification successful
Ohayo sensei! The Cairo 2.9.2 upgrade looks safe to proceed!
Our thorough investigation shows no version-specific code patterns or compatibility issues. The coordinated update of all cairo-lang-* packages to 2.9.2 maintains consistency across the ecosystem. However, since this is a minor version bump, please ensure to:
- Run the test suite after the upgrade
- Verify any Cairo VM-specific functionality
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Description: Check for breaking changes in Cairo 2.9.2 # Check the changelog for breaking changes curl -s https://raw.githubusercontent.com/starkware-libs/cairo/v2.9.2/CHANGELOG.md | grep -A 10 "## \[2.9" # Verify scarb compatibility curl -s "https://api.github.com/repos/dojoengine/scarb/commits/72b5db6b009fda6a83e2740d2a10b529b02d792c" | jq -r '.files[].filename' | grep -i "cairo" # Check starknet_api changes curl -s "https://api.github.com/repos/dojoengine/sequencer/commits/92da150d" | jq -r '.files[].filename' | grep -i "starknet_api"Length of output: 385
Script:
#!/bin/bash # Search for Cairo version references and potential compatibility issues echo "=== Searching for Cairo version references ===" rg -i "cairo.*2\.(8|9)" --type rust -C 2 echo -e "\n=== Checking for compatibility configurations ===" fd "\.toml$" --exec cat {} \; | rg -i "cairo.*compatibility" echo -e "\n=== Looking for version-specific imports or features ===" rg -i "cairo.*feature" --type rust -C 2 echo -e "\n=== Checking for any migration guides or documentation ===" fd "README|CHANGELOG|UPGRADE" --exec cat {} \; | rg -i -A 5 "migration|upgrade|breaking.?change"Length of output: 1907
Script:
#!/bin/bash # Check for version-specific code patterns and test configurations echo "=== Checking for Cairo version-specific test configurations ===" fd "test" -e rs -e toml --exec cat {} \; | rg -i "cairo.*2\.(8|9)" -C 3 echo -e "\n=== Looking for Cairo compiler version requirements ===" rg -i "requires.*cairo" -C 3 echo -e "\n=== Searching for Cairo version-specific APIs or features ===" ast-grep --pattern 'cairo_lang_$_' -l rust echo -e "\n=== Checking for any version pins in dependency files ===" fd Cargo.lock -x cat {} \; | rg -i "cairo-lang.*2\.(8|9)"Length of output: 747
examples/simple/manifest_dev.json (1)
3-4
: LGTM! Contract hashes updated for Cairo 2.9.2.The updates to contract addresses and class hashes are expected due to the Cairo version upgrade. All references have been consistently updated across the manifest.
Also applies to: 1255-1256, 1513-1514, 1689-1690, 1950-1950, 1956-1956, 1964-1964, 1970-1970
crates/katana/executor/src/implementation/blockifier/utils.rs (6)
524-533
: Verify ifto_api_resource_bounds
implementation is up-to-date with Cairo 2.9.2.The function
to_api_resource_bounds
has a comment indicating it's for pre-0.13.3 versions:// Pre 0.13.3. Only L1 gas. L2 bounds are signed but never used. fn to_api_resource_bounds( resource_bounds: katana_primitives::fee::ResourceBoundsMapping, ) -> ValidResourceBounds { ValidResourceBounds::L1Gas(ResourceBounds { max_amount: resource_bounds.l1_gas.max_amount.into(), max_price_per_unit: resource_bounds.l1_gas.max_price_per_unit.into(), }) }Since the project is upgrading to Cairo 2.9.2, please check if this implementation needs to be updated to handle L2 gas or other changes in resource bounds in the newer version.
95-105
:⚠️ Potential issueOhayo, sensei! Please clarify the gas price selection logic and resolve the TODO.
The current implementation selects the L2 gas price based on the
fee_type
, but there is a TODO comment indicating uncertainty about its correctness:// TODO: i dont know if this is correct let (unit, gas_price) = match fee_type { FeeType::Eth => ( PriceUnit::Wei, block_context.block_info().gas_prices.eth_gas_prices.l2_gas_price.get().0, ), FeeType::Strk => ( PriceUnit::Fri, block_context.block_info().gas_prices.strk_gas_prices.l2_gas_price.get().0, ), };Please verify that the gas price and unit are correctly determined for both
FeeType::Eth
andFeeType::Strk
, ensuring they align with the expected fee calculation logic after the upgrade to Cairo 2.9.2. Once confirmed, remove the TODO comment.
720-729
: Ensure correct mapping inFrom<ExecutionFlags>
implementation.The
From
implementation convertsExecutionFlags
intoBlockifierExecutionFlags
:impl From<ExecutionFlags> for BlockifierExecutionFlags { fn from(value: ExecutionFlags) -> Self { Self { only_query: false, charge_fee: value.fee(), nonce_check: value.nonce_check(), validate: value.account_validation(), } } }Please verify that all fields in
ExecutionFlags
are correctly and completely mapped to the corresponding fields inBlockifierExecutionFlags
, ensuring no functionality is lost in the conversion.✅ Verification successful
Ohayo sensei! The
From<ExecutionFlags>
implementation is correct and complete.The mapping preserves all functionality with proper field correspondence:
fee()
→charge_fee
nonce_check()
→nonce_check
account_validation()
→validate
The hardcoded
only_query: false
is appropriate as it's not part of the original flags.🏁 Scripts executed
The following scripts were executed for the analysis:
Error: No shell scripts found
Script:
#!/bin/bash # Find struct definitions and their fields ast-grep --pattern 'struct ExecutionFlags { $$$ }' ast-grep --pattern 'struct BlockifierExecutionFlags { $$$ }' # Search for the implementation of methods used in conversion rg "fn fee|fn nonce_check|fn account_validation" -A 2Length of output: 1597
Script:
#!/bin/bash # View the files containing the structs cat crates/katana/executor/src/abstraction/mod.rs cat crates/katana/executor/src/implementation/blockifier/utils.rs # Backup search for struct definitions rg "struct (ExecutionFlags|BlockifierExecutionFlags)" --type rustLength of output: 46025
565-599
:⚠️ Potential issueAddress the TODO comments regarding contract class conversions.
The functions
to_runnable_class
andto_class_info
contain TODO comments expressing uncertainty about the variant to use and whether the return type should change to handle error cases in contract class conversions:// TODO: @kariy not sure of the variant that must be used in this case. Should we change the // return type to include this case of error for contract class conversions? pub fn to_runnable_class( class: class::CompiledClass, ) -> Result<RunnableCompiledClass, ProgramError> { match class { class::CompiledClass::Legacy(class) => { Ok(RunnableCompiledClass::V0(CompiledClassV0::try_from(class)?)) } class::CompiledClass::Class(casm) => { Ok(RunnableCompiledClass::V1(CompiledClassV1::try_from(casm)?)) } } } pub fn to_class_info(class: class::CompiledClass) -> Result<ClassInfo, ProgramError> { // TODO: @kariy not sure of the variant that must be used in this case. Should we change the // return type to include this case of error for contract class conversions? match class { class::CompiledClass::Legacy(class) => { // ... } class::CompiledClass::Class(class) => { // ... } } }Please consult with the team (e.g., @kariy) to resolve these uncertainties and update the code accordingly.
628-633
: Confirm the assignment ofl1_gas
andl1_data_gas
.In both
data_availability
andtotal_gas_consumed
, the fieldsl1_gas
andl1_data_gas
are assigned the same value:data_availability: L1Gas { l1_gas: exec_info.receipt.da_gas.l1_data_gas.0 as u128, l1_data_gas: exec_info.receipt.da_gas.l1_data_gas.0 as u128, }, total_gas_consumed: L1Gas { l1_gas: exec_info.receipt.gas.l1_data_gas.0 as u128, l1_data_gas: exec_info.receipt.gas.l1_data_gas.0 as u128, },Please verify that this is intentional and consistent with the gas calculation methodology in Cairo 2.9.2.
87-90
: Verify fee calculation logic after upgrading to Cairo 2.9.2.The fee is recalculated when
info.receipt.fee == Fee(0)
:let fee = if info.receipt.fee == Fee(0) { get_fee_by_gas_vector(block_context.block_info(), info.receipt.gas, &fee_type) } else { info.receipt.fee };With the upgrade to Cairo 2.9.2, please ensure that this condition is appropriate and that the fee calculation accurately reflects the new transaction fee mechanics. Adjust the logic if necessary to align with the latest standards.
✅ Verification successful
Ohayo sensei!
Fee calculation logic is correct and compatible with Cairo 2.9.2
The current fee calculation implementation follows Starknet's standard fee model and remains valid after the Cairo 2.9.2 upgrade. The zero-fee check is a proper fallback mechanism that correctly utilizes block context gas prices for both ETH and STRK fee types.
🏁 Scripts executed
The following scripts were executed for the analysis:
Error: No shell scripts found
Script:
#!/bin/bash # Find implementation of get_fee_by_gas_vector ast-grep --pattern 'fn get_fee_by_gas_vector' # Search for fee-related test files fd test.*rs --exec rg -l "fee.*calculation|get_fee_by_gas" # Search for Cairo version or upgrade related changes rg -i "cairo.*2\.9\.2|upgrade.*cairo" -g "*.{rs,toml}" # Look for fee-related structs and implementations ast-grep --pattern 'struct Fee'Length of output: 3174
Script:
#!/bin/bash # Search for fee-related code in blockifier directory rg -l "Fee" --type rust crates/katana/executor/src/implementation/blockifier/ # Look for fee calculation implementation ast-grep --pattern 'fn get_fee_by_gas_vector' # Search for transaction fee related constants or configurations rg "fee.*type|gas.*price" crates/katana/executor/src/ # Find any fee-related imports or uses rg "use.*fee|use.*gas" crates/katana/executor/src/implementation/blockifier/Length of output: 7934
crates/katana/executor/Cargo.toml (2)
19-20
: Dependencies look good.The optional dependencies
parking_lot
andstarknet
are correctly re-added:parking_lot = { workspace = true, optional = true } starknet = { workspace = true, optional = true }
10-10
: Confirm the optionalkatana-cairo
dependency.The
katana-cairo
dependency is added as optional:katana-cairo = { workspace = true, optional = true }Please verify that all necessary features are included when this dependency is not enabled, and that optionality does not introduce issues in dependent code.
crates/dojo/core-cairo-test/src/tests/helpers/event.cairo (1)
68-78
: Improved readability with updated formatting.The addition of a trailing comma and adjustment of the
.span()
method improves the readability of thenamespace_def
definition:let namespace_def = NamespaceDef { namespace: "dojo", resources: [ TestResource::Event(old_foo_event_bad_layout_type::TEST_CLASS_HASH.try_into().unwrap()), TestResource::Event(e_FooEventMemberRemoved::TEST_CLASS_HASH.try_into().unwrap()), TestResource::Event( e_FooEventMemberAddedButRemoved::TEST_CLASS_HASH.try_into().unwrap(), ), TestResource::Event(e_FooEventMemberAddedButMoved::TEST_CLASS_HASH.try_into().unwrap()), TestResource::Event(e_FooEventMemberAdded::TEST_CLASS_HASH.try_into().unwrap()), ] .span(), };These changes are syntactically correct and align with standard formatting practices in Rust.
eth_gas_prices: GasPriceVector { | ||
l1_gas_price: eth_l1_gas_price, | ||
l1_data_gas_price: eth_l1_data_gas_price, | ||
// TODO: update to use the correct value | ||
l2_gas_price: eth_l1_gas_price, | ||
}, | ||
strk_gas_prices: GasPriceVector { | ||
l1_gas_price: strk_l1_gas_price, | ||
l1_data_gas_price: strk_l1_data_gas_price, | ||
// TODO: update to use the correct value | ||
l2_gas_price: strk_l1_gas_price, | ||
}, |
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.
💡 Codebase verification
Ohayo sensei!
The L2 gas price TODO needs proper tracking and documentation
This temporary implementation using L1 gas price for L2 appears in multiple files within the blockifier implementation. Consider:
- Adding a tracking issue to document the rationale and future plans
- Updating the TODO comments with a reference to the tracking issue
🔗 Analysis chain
Consider documenting the L2 gas price TODO.
The L2 gas price is temporarily using L1 gas price. This needs to be updated in the future.
Let's check if there are any related TODOs:
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Search for related TODOs about L2 gas prices
rg -l "TODO.*[Ll]2.*gas.*price"
Length of output: 33
Script:
#!/bin/bash
# Try different patterns to find L2 gas price related TODOs
echo "=== Searching with broader patterns ==="
rg -l "L2 gas"
echo -e "\n=== Searching in the specific file with context ==="
rg -C 2 "TODO" crates/katana/executor/src/implementation/blockifier/mod.rs
echo -e "\n=== Searching for exact comment text ==="
rg "TODO: update to use the correct value"
Length of output: 1959
.github/workflows/ci.yml
Outdated
@@ -114,7 +114,7 @@ jobs: | |||
- uses: actions/checkout@v3 | |||
- uses: software-mansion/setup-scarb@v1 | |||
with: | |||
scarb-version: "2.8.4" | |||
scarb-version: "2.9.1" |
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.
🛠️ Refactor suggestion
Heads up sensei! Version mismatch detected.
The Scarb version (2.9.1) in the CI workflow is behind the Cairo version (2.9.2) used in dependencies. Consider updating to 2.9.2 for consistency.
Apply this diff to align versions:
- scarb-version: "2.9.1"
+ scarb-version: "2.9.2"
📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.
scarb-version: "2.9.1" | |
scarb-version: "2.9.2" |
crates/katana/executor/Cargo.toml
Outdated
thiserror.workspace = true | ||
tracing.workspace = true | ||
|
||
blockifier = { git = "https://github.com/dojoengine/sequencer", tag = "v0.8.0-rc3.2", features = [ "testing" ], optional = true } | ||
katana-cairo = { workspace = true, optional = true } | ||
blockifier = { git = "https://github.com/dojoengine/sequencer", rev = "92da150d", features = [ "testing" ], optional = true } |
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.
💡 Codebase verification
Ohayo sensei! The blockifier dependency needs attention!
The specified git revision 92da150d
does not exist in the dojoengine/sequencer repository. This will cause build failures and needs to be updated to a valid commit hash.
- Update the blockifier dependency in
crates/katana/executor/Cargo.toml
to use a valid and verified commit hash from the sequencer repository
🔗 Analysis chain
Verify the blockifier
dependency revision and features.
The blockifier
dependency is specified with a git revision and features:
blockifier = { git = "https://github.com/dojoengine/sequencer", rev = "92da150d", features = [ "testing" ], optional = true }
Ensure that this commit hash corresponds to the intended version compatible with Cairo 2.9.2, and that the correct features are enabled for your use case.
🏁 Scripts executed
The following scripts were executed for the analysis:
Error: No shell scripts found
Script:
#!/bin/bash
# Check repository root Cargo.toml for Cairo version
echo "=== Checking root Cargo.toml for Cairo version ==="
rg -A 5 "cairo" Cargo.toml || true
# Search for Cairo version specifications across the codebase
echo -e "\n=== Searching for Cairo version specifications ==="
rg -i "cairo.*[0-9]+\.[0-9]+\.[0-9]+" || true
# Look for blockifier features
echo -e "\n=== Checking blockifier features ==="
rg -A 5 "\[features\]" crates/katana/executor/Cargo.toml || true
# Examine the commit message and content
echo -e "\n=== Checking commit information ==="
git show --no-patch 92da150d || true
Length of output: 8264
Script:
#!/bin/bash
# Check if the repository exists and examine the commit
echo "=== Checking remote repository ==="
git ls-remote https://github.com/dojoengine/sequencer 92da150d || true
# Try to find blockifier dependency declarations
echo -e "\n=== Searching for blockifier dependency declarations ==="
rg -l "blockifier.*=.*" || true
# Look for testing feature usage
echo -e "\n=== Searching for testing feature usage ==="
rg -A 5 "testing.*feature" || true
Length of output: 599
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: 1
🧹 Nitpick comments (3)
bin/sozo/src/commands/test.rs (3)
71-71
: Consider adding validation for the packages filter, sensei!While making
packages
required is a good change, we should validate that at least one package matches the filter before proceeding with compilation.pub fn run(self, config: &Config) -> anyhow::Result<()> { let ws = ops::read_workspace(config.manifest_path(), config).unwrap_or_else(|err| { eprintln!("error: {err}"); std::process::exit(1); }); + // Validate packages filter early + let packages = self.packages.match_many(&ws)?; + if packages.is_empty() { + anyhow::bail!("No packages match the specified filter"); + }Also applies to: 82-83
101-111
: Verify the impact of ignore_cairo_version flag, sensei!Setting
ignore_cairo_version: false
is correct for ensuring version compatibility, but we should document this behavior.Add a comment explaining the version check behavior:
scarb::ops::compile( packages.iter().map(|p| p.id).collect(), CompileOpts { include_target_kinds: vec![TargetKind::TEST], exclude_target_kinds: vec![], include_target_names: vec![], features: self.features.try_into()?, + // Ensure Cairo version compatibility between dependencies ignore_cairo_version: false, }, &ws, )?;
181-195
: Excellent gas configuration handling, sensei!The
is_gas_enabled
function has good default behavior, defaulting to true if not specified. However, we could improve error handling for malformed compiler config.fn is_gas_enabled(metadata: &Metadata, package_id: &PackageId, target: &TargetMetadata) -> bool { metadata .compilation_units .iter() .find(|cu| { cu.package == *package_id && cu.target.kind == "test" && cu.target.name == target.name }) .map(|cu| cu.compiler_config.clone()) .and_then(|c| { - c.as_object() - .and_then(|c| c.get("enable_gas").and_then(|x| x.as_bool())) + c.as_object().and_then(|c| { + c.get("enable_gas").and_then(|x| { + if !x.is_boolean() { + tracing::warn!("Invalid enable_gas value in compiler config, defaulting to true"); + } + x.as_bool() + }) + }) }) // Defaults to true, meaning gas enabled - relies on cli config then. .unwrap_or(true) }
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
⛔ Files ignored due to path filters (3)
Cargo.lock
is excluded by!**/*.lock
spawn-and-move-db.tar.gz
is excluded by!**/*.gz
types-test-db.tar.gz
is excluded by!**/*.gz
📒 Files selected for processing (5)
Cargo.toml
(4 hunks)bin/sozo/Cargo.toml
(1 hunks)bin/sozo/src/commands/test.rs
(3 hunks)examples/simple/Scarb.toml
(2 hunks)examples/spawn-and-move/Scarb.toml
(2 hunks)
🚧 Files skipped from review as they are similar to previous changes (3)
- examples/simple/Scarb.toml
- examples/spawn-and-move/Scarb.toml
- Cargo.toml
🔇 Additional comments (1)
bin/sozo/src/commands/test.rs (1)
1-8
: Ohayo! Nice documentation update, sensei!The updated imports and documentation clearly reflect the shift to Scarb-based test compilation. The addition of
cairo-lang-sierra
and test-related imports shows good organization.
cairo-lang-filesystem.workspace = true | ||
cairo-lang-project.workspace = true | ||
cairo-lang-starknet.workspace = true | ||
cairo-lang-sierra.workspace = true |
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.
💡 Codebase verification
Ohayo! We found some dependency issues, sensei!
The removal of cairo-lang dependencies will break the codebase as they're still actively used:
cairo_lang_starknet_classes
is used in multiple files forCasmContractClass
andContractClass
cairo_lang_filesystem
is used ininline_macros/utils.rs
cairo_lang_starknet
is re-exported inkatana/cairo/lib.rs
While adding cairo-lang-sierra
is good, we should keep the other necessary Cairo dependencies to maintain functionality.
🔗 Analysis chain
Ohayo! Let's verify these dependency changes, sensei!
The shift from direct Cairo language dependencies to Scarb-based ones aligns well with the Cairo 2.9.2 upgrade. However, we should verify that all necessary functionality is covered by the new dependencies.
Let's confirm there are no missing dependencies by checking the usage:
Also applies to: 29-29
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Search for any remaining usage of removed dependencies
rg -l "cairo_lang_(compiler|filesystem|project|starknet)" --type rust
# Check if all new dependencies are actually used
rg -l "cairo_lang_sierra|scarb_metadata" --type rust
Length of output: 473
Script:
#!/bin/bash
# Check actual usage context in non-test files
rg "cairo_lang_(compiler|filesystem|project|starknet)" --type rust -g '!*test*' -A 2 -B 2
# Also check if there are any direct imports of these packages
ast-grep --pattern 'use cairo_lang_$_::$$$'
Length of output: 2792
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: 2
🧹 Nitpick comments (1)
crates/katana/rpc/rpc/tests/starknet.rs (1)
Line range hint
951-972
: Consider adding more assertions in v3_transactions test.While the test verifies basic transaction execution, it could be enhanced with additional assertions to verify:
- Gas price token (STRK) usage
- Resource bounds
- Transaction receipt details
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
⛔ Files ignored due to path filters (8)
Cargo.lock
is excluded by!**/*.lock
crates/dojo/core-cairo-test/Scarb.lock
is excluded by!**/*.lock
crates/dojo/core/Scarb.lock
is excluded by!**/*.lock
crates/torii/types-test/Scarb.lock
is excluded by!**/*.lock
examples/simple/Scarb.lock
is excluded by!**/*.lock
examples/spawn-and-move/Scarb.lock
is excluded by!**/*.lock
spawn-and-move-db.tar.gz
is excluded by!**/*.gz
types-test-db.tar.gz
is excluded by!**/*.gz
📒 Files selected for processing (9)
.github/workflows/ci.yml
(1 hunks)Cargo.toml
(4 hunks)crates/dojo/core/Scarb.toml
(1 hunks)crates/katana/cairo/Cargo.toml
(1 hunks)crates/katana/executor/Cargo.toml
(1 hunks)crates/katana/executor/src/implementation/blockifier/utils.rs
(21 hunks)crates/katana/rpc/rpc/tests/starknet.rs
(4 hunks)crates/torii/types-test/Scarb.toml
(1 hunks)examples/spawn-and-move/Scarb.toml
(2 hunks)
🚧 Files skipped from review as they are similar to previous changes (5)
- crates/torii/types-test/Scarb.toml
- crates/katana/cairo/Cargo.toml
- examples/spawn-and-move/Scarb.toml
- crates/dojo/core/Scarb.toml
- .github/workflows/ci.yml
⏰ Context from checks skipped due to timeout of 90000ms (1)
- GitHub Check: fmt
🔇 Additional comments (4)
Cargo.toml (1)
150-171
: LGTM! Cairo dependencies consistently updated to 2.9.2.The update of all Cairo-related dependencies to version 2.9.2 is consistent and complete.
crates/katana/executor/src/implementation/blockifier/utils.rs (2)
567-580
: LGTM! New to_runnable_class function properly handles both legacy and new class formats.The function correctly converts both legacy and new class formats to RunnableCompiledClass.
722-731
: LGTM! Clean implementation of ExecutionFlags conversion.The From trait implementation for ExecutionFlags provides a clear mapping to BlockifierExecutionFlags.
crates/katana/rpc/rpc/tests/starknet.rs (1)
1170-1197
: LGTM! Comprehensive contract call test coverage.The new test effectively covers both legacy and standard contract calls, providing good test coverage for the contract interaction functionality.
thiserror.workspace = true | ||
tracing.workspace = true | ||
|
||
blockifier = { git = "https://github.com/dojoengine/sequencer", tag = "v0.8.0-rc3.2", features = [ "testing" ], optional = true } | ||
katana-cairo = { workspace = true, optional = true } | ||
blockifier = { git = "https://github.com/dojoengine/sequencer", rev = "802c5dc", features = [ "testing" ], optional = true } |
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.
💡 Codebase verification
Ohayo sensei! The blockifier dependency revision appears to be invalid.
The commit 802c5dc
does not exist in the dojoengine/sequencer
repository. Please verify the correct commit hash with your team and update it accordingly.
🔗 Analysis chain
Ohayo sensei! Verify the blockifier dependency revision.
The blockifier dependency is using a specific git revision. Let's verify it exists and is the intended version.
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Check if the repository exists and examine the commit
echo "=== Checking remote repository ==="
git ls-remote https://github.com/dojoengine/sequencer 802c5dc || true
# Look for blockifier features usage
echo -e "\n=== Searching for blockifier feature usage ==="
rg -A 5 "blockifier.*feature" || true
Length of output: 1201
#starknet_api = "0.11.0" | ||
starknet_api = { git = "https://github.com/dojoengine/sequencer", rev = "802c5dc" } |
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.
💡 Codebase verification
Invalid git commit reference for starknet_api dependency
The git commit 802c5dc
does not exist in the dojoengine/sequencer
repository. Given the extensive usage of starknet_api throughout the codebase, this will cause build failures.
- Consider reverting to the stable version
0.11.0
- If git dependency is required, ensure to use a valid commit hash from the repository
🔗 Analysis chain
Verify the starknet_api dependency change.
The starknet_api dependency has been changed from a version string to a git dependency. Let's verify the revision exists and is compatible.
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Check if the repository exists and examine the commit
echo "=== Checking remote repository ==="
git ls-remote https://github.com/dojoengine/sequencer 802c5dc || true
# Look for starknet_api usage
echo -e "\n=== Searching for starknet_api usage ==="
rg -A 5 "starknet_api::" || true
Length of output: 17179
Summary by CodeRabbit
Summary by CodeRabbit
Release Notes
Dependency Updates
cairo_test
dependency with version 2.9.2Code Improvements
sozo
Performance and Compatibility
Testing and Validation
New Features