Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(katana): return contract storage root in RPC proof response #2846

Merged
merged 1 commit into from
Dec 25, 2024

Conversation

kariy
Copy link
Member

@kariy kariy commented Dec 25, 2024

the storage root is required to compute the contract state hash (needed for the proofs verification). the rpc specs doesn't include the storage root in the response object, but considering that the specs version is still on draft for now, we can tolerate deviating from it to simplify the SNOS integration

Summary by CodeRabbit

  • New Features

    • Added a new submodule for Piltover contracts.
    • Introduced new dependencies for enhanced macro capabilities and blockchain application initialization.
    • Enhanced Starknet API with new methods for retrieving storage proofs and managing state roots.
    • Implemented new traits for state proof and root retrieval across various providers.
    • Added support for managing contract and class states in trie structures.
  • Bug Fixes

    • Improved error handling for proof limits and state root retrieval.
  • Documentation

    • Updated documentation to reflect new configuration options and API enhancements.
  • Tests

    • Introduced new test cases for validating storage proofs and ensuring correct error handling.
  • Chores

    • Refactored various modules for improved maintainability and clarity.

@kariy kariy marked this pull request as ready for review December 25, 2024 22:19
@kariy kariy changed the base branch from main to katana/dev December 25, 2024 22:20
Copy link

coderabbitai bot commented Dec 25, 2024

Katana Trie and State Management Enhancement

Walkthrough

Ohayo, sensei! This pull request introduces a comprehensive refactoring of Katana's state management and trie infrastructure. The changes consolidate various state-related traits, introduce new multiproof and root retrieval mechanisms, and enhance the overall flexibility of the blockchain's state handling. Key modifications include unifying trie writers, adding state proof providers, and implementing more robust methods for managing contract, class, and storage tries.

Changes

File Change Summary
.gitmodules Added new submodule for Piltover contracts
Cargo.toml Added procedural macro dependencies: proc-macro2, quote, syn
bin/katana/Cargo.toml Added multiple workspace dependencies for Katana components
crates/katana/trie/src/ Introduced new modules: classes, contracts, id, storages
crates/katana/storage/provider/src/traits/ Refactored state and trie-related traits

Sequence Diagram

sequenceDiagram
    participant StateProvider
    participant TrieWriter
    participant ClassesTrie
    participant ContractsTrie
    participant StoragesTrie

    StateProvider->>TrieWriter: trie_insert_declared_classes
    TrieWriter->>ClassesTrie: insert
    ClassesTrie-->>TrieWriter: commit

    StateProvider->>TrieWriter: trie_insert_contract_updates
    TrieWriter->>ContractsTrie: insert
    ContractsTrie-->>TrieWriter: commit
    TrieWriter->>StoragesTrie: insert
    StoragesTrie-->>TrieWriter: commit
Loading

Possibly Related PRs

Sensei, the changes represent a significant evolution in our state management approach, providing more granular and flexible handling of blockchain state tries! 🚀🔧


🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

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)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai generate docstrings to generate docstrings for this PR. (Beta)
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Caution

Inline review comments failed to post. This is likely due to GitHub's limits when posting large numbers of comments.

Actionable comments posted: 10

🧹 Nitpick comments (50)
crates/katana/rpc/rpc-types-builder/src/state_update.rs (1)

38-38: Ohayo sensei! Carefully Check the Expect Message.

Although the line is blank, note that any preceding .expect("should exist if block exists") message is helpful. Please ensure this message remains relevant for debugging.

crates/katana/storage/provider/tests/block.rs (2)

32-32: Ohayo sensei! Having this test ignored is understandable given the unsupported trie computation.

It might be good to briefly mention or reference in the code when you expect to remove the #[ignore] so future devs know if there's any plan to enable or fix it.


49-49: Ohayo sensei! Same note regarding the ignored test here.

Consider adding comments on progress or a roadmap to remove this ignore, ensuring clarity for new contributors.

crates/katana/storage/db/src/trie/snapshot.rs (5)

15-23: Ohayo sensei! Consider including a doc comment for this struct.
Providing a short high-level description will help others quickly understand the purpose of SnapshotTrieDb.


25-33: Ohayo sensei! Include the snapshot ID in debug output.
Right now, we only format tx. Adding snapshot_id might help pinpoint which snapshot is being debugged.

 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
     f.debug_struct("SnapshotTrieDb")
-        .field("tx", &self.tx)
+        .field("tx", &self.tx)
+        .field("snapshot_id", &self.snapshot_id)
         .finish()
 }

67-67: Ohayo sensei! Add a doc comment for create_batch.
Even if it's empty, a comment clarifying why we return an empty batch will aid understanding.


92-97: Ohayo sensei! “todo!” comment is fine, but be mindful of usage.
A specialized error or a more descriptive placeholder may better communicate the feature’s status.


116-118: Ohayo sensei! “todo!” approach for contains.
Consider clarifying timeline or relevant references to complete this method, for better context.

crates/katana/trie/src/classes.rs (2)

37-51: Ohayo sensei! Validate input sets
When generating a multiproof for potentially large class_hashes, consider validating or logging the size to avoid performance issues or out-of-memory scenarios.


53-65: Ohayo sensei! Graceful error handling might help
insert and commit unwrap potential errors, which can panic. A gentle Result approach with descriptive error messages could make debugging easier.

- self.trie.insert(Self::BONSAI_IDENTIFIER, hash, value)
+ if let Err(err) = self.trie.insert(Self::BONSAI_IDENTIFIER, hash, value) {
+     // handle or propagate error here
+ }
crates/katana/storage/provider/src/traits/state.rs (1)

24-31: Ohayo sensei! Great addition of dedicated trie root fetch methods
classes_root, contracts_root, and storage_root clarify the retrieval of each domain's root. Keep an eye on potential performance overhead if these calls are frequently repeated.

crates/katana/storage/provider/src/providers/db/trie.rs (2)

26-41: Ohayo sensei! Partitioning class insertion logic is cleaner
trie_insert_declared_classes nicely separates class-hash updates from contract updates. Ensure that any partial insertion failures roll back or handle errors gracefully.


49-108: Ohayo sensei! Consider concurrency aspects
storages and contracts tries are updated in a loop. If parallel updates or multi-threading is introduced, a synchronization approach might be needed. Currently, single-thread usage is fine.

crates/katana/trie/src/lib.rs (1)

Line range hint 96-108: Ohayo sensei! anyhow::Result for compute_merkle_root
Using anyhow::Result is flexible for error chaining but rest assured the overhead is acceptable. If performance is critical, a specialized error type might be more efficient.

crates/katana/executor/src/abstraction/mod.rs (1)

227-243: Ohayo sensei! StateRootProvider integration
By implementing classes_root, contracts_root, storage_root, and state_root, StateProviderDb unifies all root retrieval logic. Beware that repeated root calls might be expensive if they perform complex I/O.

crates/katana/storage/db/src/abstraction/transaction.rs (2)

94-129: Ohayo sensei, consider unifying trait definitions
We see that DbTxMutRef duplicates the type Cursor<T> and type DupCursor<T>. This duplication is a recognized TODO. Consolidating them in a single location or using generic constraints might reduce boilerplate.


151-180: Ohayo sensei, add a specialized unit test
Though the code works for references, adding targeted tests to verify the behavior of each method in both read-only and read-write contexts ensures coverage and prevents regressions. Would you like me to draft some test stubs?

crates/katana/rpc/rpc-types/src/trie.rs (2)

66-106: Ohayo sensei, strongly typed proofs
Defining GetStorageProofResponse and the associated proof structures is a good approach. This ensures clarity in RPC responses. Consider adding a short doc block explaining usage of classes_proof vs. contracts_proof.


108-129: Ohayo sensei, simpler wrappers
NodeWithHash and Nodes are well-defined. The custom Deref and DerefMut improve ergonomics. Keep an eye on memory overhead for large proofs.

crates/katana/core/src/backend/mod.rs (1)

255-263: Ohayo sensei, consider better error handling
Using .expect("failed to update...") might panic in production. A more robust approach is to propagate the error or provide tailored logging.

-    .expect("failed to update class trie");
+    .map_err(|e| anyhow!("Class trie update failed: {e:?}"))?;
bin/katana/src/cli/init/mod.rs (2)

88-120: Ohayo sensei, structuring InitArgs::execute
The execute method properly constructs a runtime and organizes the flow. Consider logging progress steps to inform users about configuration steps.


202-281: Ohayo sensei, multi-step settlement contract deployment
init_core_contract is well-structured. Using a spinner is a nice UX detail. You might want more robust error messages if a step fails (e.g., class declare vs. contract deploy).

crates/katana/storage/provider/src/providers/db/state.rs (2)

165-193: Ohayo sensei! Validate empty input in multiproof methods.
The multiproof logic is correct overall. However, consider returning an empty proof or an explicit error if the input vectors for classes/contracts/storage are empty, to avoid potential edge cases in downstream code.


387-423: Ohayo sensei! The historical state root retrieval is aligned with project requirements.
As with the multiproof coverage, substituting expect("should exist") with a more robust fallback approach might improve resilience for partial states or incomplete blocks.

crates/katana/storage/db/src/trie/mod.rs (6)

29-33: Ohayo sensei! TrieDbFactory struct is a useful abstraction.
Consider verifying if &'a PhantomData<()> is fully needed or if a simpler lifetime management suffices.


34-47: Ohayo sensei! The TrieDbFactory impl is clear.
Adding stronger error handling around historical(block) might help avoid Some(...) proxies if the data doesn’t exist.


49-80: Ohayo sensei! GlobalTrie is well-structured for latest tries.
It might help to unify repeated katana_trie::XxxTrie::new(TrieDb::new(...)) calls via a small helper function to reduce code duplication.


82-121: Ohayo sensei! HistoricalGlobalTrie cleanly extends functionality.
Guarding expect("should exist") with a more informative error for uninitialized or partial historical data would bolster reliability.


209-239: Ohayo sensei! TrieDbMut introduces write caching.
Storing writes in write_cache is good for snapshot logic but be mindful of potential memory usage if many entries accumulate.


Line range hint 243-327: Ohayo sensei! Write operations are well-limited.
remove_by_prefix usage is robust. Consider bounding the iteration in large databases or using indexes if performance becomes an issue.

crates/katana/storage/provider/src/providers/fork/state.rs (4)

105-124: Ohayo sensei! Stubbed multiproof is acceptable.
However, returning a default MultiProof may prematurely signal success in external callers. Consider returning an explicit unsupported or placeholder status to reduce confusion.


181-200: Ohayo sensei! Same stubbing approach in LatestStateProvider.
Alternatively, implement partial proof logic or warn that these are placeholders so consumers don’t rely on them incorrectly.


288-307: Ohayo sensei! Similar multiproof stubbing in ForkedSnapshot.
Everything is consistent with the approach in ForkedStateDb. Just ensure you unify them if or when real proofs become available.
[minimum_revision_needed: none | final decision is up to you]


309-321: Ohayo sensei! The stubbed StateRootProvider for ForkedSnapshot.
Again, returning Felt::ZERO can be ambiguous, especially for real usage. Consider a distinct sentinel or clarifying doc comment.

crates/katana/storage/db/src/tables.rs (1)

250-269: Ohayo sensei! The new trie tables store high-level data consistently.
Might be worth adding doc comments explaining how these tries differ from one another for new developers.

crates/katana/trie/src/storages.rs (1)

16-28: Ohayo sensei! Consider adding a test helper for multiproof.

While root and multiproof are straightforward, having a dedicated test function that exercises multiproof with various edge cases would strengthen reliability. This is especially beneficial for surface-level bugs in hashing or key conversions.

crates/katana/trie/src/contracts.rs (1)

17-34: Ohayo sensei! Good introduction of BONSAI_IDENTIFIER.

Embedding an identifier for the contract mapping inside the trie logic is a fine architectural choice, providing clear scoping of keys. Consider adding in-code references for any extended usage or potential expansions.

crates/saya/core/src/blockchain/mod.rs (1)

9-9: Ohayo sensei! Nice consolidation of state traits.
Introducing StateFactoryProvider aligns with the refactor that moves away from StateRootProvider. This approach appears cleaner, but verify that all dependent modules can still derive the state root without disruptions.

crates/katana/executor/src/implementation/noop.rs (1)

173-197: Ohayo sensei! The new StateProofProvider implementation is looking good.

These multiproof stubs returning an empty default proof are a straightforward start. Consider adding tests or logs if you expand them so that future senseis can better troubleshoot real proofs.

crates/katana/storage/provider/src/providers/fork/mod.rs (2)

602-603: Ohayo sensei! Implementing trie_insert_declared_classes is a step toward consolidating class updates. For now, it returns a dummy Felt::ZERO, but you might want to confirm how it should reflect real trie manipulations in future iterations.


613-613: Ohayo sensei! Implementing trie_insert_contract_updates similarly returns Felt::ZERO. In a future iteration, consider mixing in the logic for actual updates to the fork's trie data.

crates/katana/executor/src/implementation/blockifier/state.rs (2)

250-256: Ohayo sensei!
Unimplemented contract_multiproof

Similar to class_multiproof, this method remains unimplemented. If the system eventually needs to return multiproof data, schedule a follow-up to provide the actual logic.


258-266: Ohayo sensei!
Unimplemented storage_multiproof

Again, the same pattern arises: unimplemented method. If this is intentional, consider returning a more descriptive error for clarity.

crates/katana/storage/provider/src/providers/fork/backend.rs (3)

679-687: Ohayo sensei!
Unimplemented storage_multiproof

Identical pattern: no actual logic for storage proofs. Provide a short docstring or error message to clarify this limitation if you see fit.


695-697: Ohayo sensei!
Unimplemented contracts_root

Same approach; if you opt to keep placeholders, add notes to reduce confusion for future maintainers.


699-701: Ohayo sensei!
Unimplemented storage_root

No functionality indicated. Same comment applies: consider a descriptive error or a TODO.

bin/katana/Cargo.toml (1)

22-24: Consider using workspace versions for consistency, sensei!

The dirs and inquire dependencies use fixed versions while most other dependencies use workspace versions. Consider moving these to workspace-level version management for better maintainability.

-dirs = "5.0.1"
+dirs.workspace = true
-inquire = "0.7.5"
+inquire.workspace = true
crates/katana/rpc/rpc/Cargo.toml (1)

Line range hint 20-34: Ohayo! The RPC dependency additions look comprehensive, sensei!

The new dependencies enhance the RPC capabilities with proper metrics (dojo-metrics, metrics), error handling (thiserror), and HTTP server infrastructure (tower, tower-http). This provides a solid foundation for the new storage proof functionality.

Consider adding metrics for:

  • Storage proof generation time
  • Proof size statistics
  • Cache hit/miss rates for frequently accessed storage slots
crates/katana/storage/db/src/models/trie.rs (1)

8-11: Ohayo! Consider adding documentation for the new struct, sensei.

The struct looks well-designed, but adding documentation would help explain its purpose and usage patterns.

Add documentation like this:

+/// Represents a historical entry in the trie database
+/// containing the key and its associated value at a point in time.
 #[derive(Debug, Clone, Serialize, Deserialize, PartialEq, Eq)]
 pub struct TrieHistoryEntry {
     pub key: TrieDatabaseKey,
     pub value: TrieDatabaseValue,
 }
crates/katana/rpc/rpc/tests/test_data/test_sierra_contract.json (1)

Line range hint 1-892: Consider adding debug information for better test observability.

The contract is well-structured but lacks debug information in the sierra_program_debug_info section, which could be helpful for testing and debugging.

Consider adding type names, libfunc names, and user func names in the debug info section to improve test observability.

🛑 Comments failed to post (10)
crates/katana/trie/src/lib.rs (1)

56-70: 🛠️ Refactor suggestion

Ohayo sensei! Panics on root or get_multi_proof
Returning expect(...) can cause abrupt panics if the database is unavailable. Consider returning ProviderResult to capture these errors gracefully.

crates/katana/storage/provider/src/providers/db/state.rs (1)

348-385: 🛠️ Refactor suggestion

Ohayo sensei! Storing and retrieving historical multiproofs could benefit from checks.
This implementation for HistoricalStateProvider is fine, but consider logging or returning a clear error if historical(self.block_number) fails or is absent rather than calling expect("should exist").

crates/katana/storage/db/src/trie/mod.rs (1)

328-370: 🛠️ Refactor suggestion

Ohayo sensei! Snapshotting changes is crucial.
Check if any concurrency concerns arise when multiple threads call snapshot simultaneously (e.g., mismatch in write_cache).

crates/katana/storage/provider/src/providers/fork/state.rs (2)

126-138: 🛠️ Refactor suggestion

Ohayo sensei! The root provider functions returning zero are placeholders.
If zero indicates "no data," a separate error or optional type might be clearer for external integrators.


202-214: 🛠️ Refactor suggestion

Ohayo sensei! Returning zero for classes_root, contracts_root, and storage_root.
Be careful: if an aggregator merges root data but sees 0, it might misinterpret the entire state as empty.

crates/katana/rpc/rpc/src/starknet/mod.rs (1)

1132-1219: 🛠️ Refactor suggestion

Ohayo sensei! get_proofs is a fantastic addition, but handle edge cases more explicitly.

  1. Consider returning partial proofs if some classes/contracts aren’t found.
  2. The line that calls expect("...") in block or header retrieval might be replaced with a custom error to avoid panics.
  3. Confirm the sum of keys used matches expected concurrency patterns to avoid performance hits.
crates/katana/contracts/Makefile (2)

16-17: ⚠️ Potential issue

Ohayo! Variable redefinition needs attention, sensei!

The ORIGINAL_CLASS_NAME variable is being redefined which could lead to conflicts with the default account section. Consider using unique variable names for different targets.

-ORIGINAL_CLASS_NAME := piltover_appchain$(CONTRACT_CLASS_SUFFIX)
+PILTOVER_CLASS_NAME := piltover_appchain$(CONTRACT_CLASS_SUFFIX)
📝 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.

PILTOVER_CLASS_NAME := piltover_appchain$(CONTRACT_CLASS_SUFFIX)
CLASS_NAME := appchain_core_contract.json

19-21: 🛠️ Refactor suggestion

Build directory dependency might need refinement.

The $(BUILD_DIR) target is defined multiple times with different prerequisites, which could lead to unexpected behavior. Consider using separate target names.

-$(BUILD_DIR): ./piltover/src/*
+build-piltover: ./piltover/src/*
+	mkdir -p $(BUILD_DIR)
 	cd piltover && scarb build
 	mv target/dev/$(ORIGINAL_CLASS_NAME) $(BUILD_DIR)/$(CLASS_NAME)
📝 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.

build-piltover: ./piltover/src/*
	mkdir -p $(BUILD_DIR)
	cd piltover && scarb build
	mv target/dev/$(ORIGINAL_CLASS_NAME) $(BUILD_DIR)/$(CLASS_NAME)
crates/katana/storage/db/src/models/trie.rs (2)

24-35: ⚠️ Potential issue

Add proper buffer length validation in Decompress implementation.

The current implementation could panic if the buffer is too short after key decoding.

Apply this diff to add proper validation:

 impl Decompress for TrieHistoryEntry {
     fn decompress<B: AsRef<[u8]>>(bytes: B) -> Result<Self, CodecError> {
         let bytes = bytes.as_ref();
 
         let key = TrieDatabaseKey::decode(bytes)?;
         // first byte is the key type, second byte is the actual key length
         let key_bytes_length = 1 + 1 + key.key.len();
+        if bytes.len() <= key_bytes_length {
+            return Err(CodecError::InvalidData("Buffer too short for value".into()));
+        }
         let value = TrieDatabaseValue::decompress(&bytes[key_bytes_length..])?;
 
         Ok(Self { key, value })
     }
 }
📝 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.

impl Decompress for TrieHistoryEntry {
    fn decompress<B: AsRef<[u8]>>(bytes: B) -> Result<Self, CodecError> {
        let bytes = bytes.as_ref();

        let key = TrieDatabaseKey::decode(bytes)?;
        // first byte is the key type, second byte is the actual key length
        let key_bytes_length = 1 + 1 + key.key.len();
        if bytes.len() <= key_bytes_length {
            return Err(CodecError::InvalidData("Buffer too short for value".into()));
        }
        let value = TrieDatabaseValue::decompress(&bytes[key_bytes_length..])?;

        Ok(Self { key, value })
    }
}

86-97: ⚠️ Potential issue

Replace panics with proper error handling in decode method.

The current implementation uses panic which is not ideal for a decode operation.

Apply this diff to use proper error handling:

-        if bytes.len() < 2 {
-            // Need at least type and length bytes
-            panic!("empty buffer")
-        }
+        if bytes.len() < 2 {
+            return Err(CodecError::InvalidData("Buffer too short for type and length".into()));
+        }

-        let r#type =
-            TrieDatabaseKeyType::try_from(bytes[0]).expect("Invalid trie database key type");
+        let r#type = TrieDatabaseKeyType::try_from(bytes[0])
+            .map_err(|e| CodecError::InvalidData(format!("Invalid key type: {}", e.0)))?;
         let key_len = bytes[1] as usize;

-        if bytes.len() < 2 + key_len {
-            panic!("Buffer too short for key length");
-        }
+        if bytes.len() < 2 + key_len {
+            return Err(CodecError::InvalidData("Buffer too short for key data".into()));
+        }

Committable suggestion skipped: line range outside the PR's diff.

Copy link

codecov bot commented Dec 25, 2024

Codecov Report

Attention: Patch coverage is 31.34328% with 46 lines in your changes missing coverage. Please review.

Please upload report for BASE (katana/dev@a7e119b). Learn more about missing BASE report.

Files with missing lines Patch % Lines
.../katana/storage/provider/src/providers/db/state.rs 11.11% 16 Missing ⚠️
...atana/storage/provider/src/providers/fork/state.rs 0.00% 9 Missing ⚠️
crates/katana/storage/db/src/trie/mod.rs 0.00% 7 Missing ⚠️
crates/katana/executor/src/abstraction/mod.rs 0.00% 3 Missing ⚠️
crates/katana/executor/src/implementation/noop.rs 0.00% 3 Missing ⚠️
...na/executor/src/implementation/blockifier/state.rs 0.00% 2 Missing ⚠️
crates/katana/rpc/rpc/src/starknet/mod.rs 0.00% 2 Missing ⚠️
...ana/storage/provider/src/providers/fork/backend.rs 0.00% 2 Missing ⚠️
crates/katana/trie/src/storages.rs 75.00% 2 Missing ⚠️
Additional details and impacted files
@@              Coverage Diff              @@
##             katana/dev    #2846   +/-   ##
=============================================
  Coverage              ?   55.73%           
=============================================
  Files                 ?      446           
  Lines                 ?    57572           
  Branches              ?        0           
=============================================
  Hits                  ?    32087           
  Misses                ?    25485           
  Partials              ?        0           

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant