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

chore(blockifier): separate create and validate logic on gas prices #2243

Merged
merged 1 commit into from
Nov 28, 2024

Conversation

ArniStarkware
Copy link
Contributor

No description provided.

@reviewable-StarkWare
Copy link

This change is Reviewable

@ArniStarkware ArniStarkware force-pushed the arni/gas_prices/separate_new_from_validate branch from e945fbe to ec2b2fe Compare November 24, 2024 12:21
@ArniStarkware ArniStarkware changed the title chore(blockifier): separate create and validate logic on gas prices struct chore(blockifier): separate create and validate logic on gas prices Nov 24, 2024
Copy link

codecov bot commented Nov 24, 2024

Codecov Report

Attention: Patch coverage is 88.00000% with 3 lines in your changes missing coverage. Please review.

Project coverage is 52.85%. Comparing base (e3165c4) to head (d60ce60).
Report is 615 commits behind head on main.

Files with missing lines Patch % Lines
crates/blockifier/src/blockifier/block.rs 90.47% 2 Missing ⚠️
crates/starknet_batcher/src/block_builder.rs 0.00% 1 Missing ⚠️
Additional details and impacted files
@@             Coverage Diff             @@
##             main    #2243       +/-   ##
===========================================
+ Coverage   40.10%   52.85%   +12.74%     
===========================================
  Files          26      228      +202     
  Lines        1895    25790    +23895     
  Branches     1895    25790    +23895     
===========================================
+ Hits          760    13631    +12871     
- Misses       1100    11178    +10078     
- Partials       35      981      +946     

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

Copy link
Collaborator

@alonh5 alonh5 left a comment

Choose a reason for hiding this comment

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

Reviewable status: 0 of 7 files reviewed, 1 unresolved discussion (waiting on @aner-starkware, @ArniStarkware, and @dorimedini-starkware)


a discussion (no related file):
Why do we need this change? Specifically if new() is now a private method, what's the difference between safe_new() and the previous new()?

@ArniStarkware ArniStarkware requested a review from alonh5 November 24, 2024 13:20
Copy link
Contributor Author

@ArniStarkware ArniStarkware left a comment

Choose a reason for hiding this comment

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

Reviewable status: 0 of 7 files reviewed, 1 unresolved discussion (waiting on @alonh5, @aner-starkware, and @dorimedini-starkware)


a discussion (no related file):

Previously, alonh5 (Alon Haramati) wrote…

Why do we need this change? Specifically if new() is now a private method, what's the difference between safe_new() and the previous new()?

The goal is to move new() into starknet API.
You do have a point - it will be public at that point. Should I change the visibility of new in this PR?

Copy link
Collaborator

@alonh5 alonh5 left a comment

Choose a reason for hiding this comment

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

Reviewed 7 of 7 files at r1, all commit messages.
Reviewable status: all files reviewed, 2 unresolved discussions (waiting on @aner-starkware, @ArniStarkware, and @dorimedini-starkware)


a discussion (no related file):

Previously, ArniStarkware (Arnon Hod) wrote…

The goal is to move new() into starknet API.
You do have a point - it will be public at that point. Should I change the visibility of new in this PR?

I think the reason there is a new() function is for that validation. So in that case I would remove the new() function and the getters completely and make the fields public. WDYT?


crates/blockifier/src/blockifier/block.rs line 88 at r2 (raw file):

    }

    pub fn safe_new(

Suggestion:

validated_new

Copy link
Contributor Author

@ArniStarkware ArniStarkware left a comment

Choose a reason for hiding this comment

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

Reviewable status: 0 of 7 files reviewed, 2 unresolved discussions (waiting on @alonh5, @aner-starkware, and @dorimedini-starkware)


a discussion (no related file):

Previously, alonh5 (Alon Haramati) wrote…

I think the reason there is a new() function is for that validation. So in that case I would remove the new() function and the getters completely and make the fields public. WDYT?

Done.


crates/blockifier/src/blockifier/block.rs line 88 at r2 (raw file):

    }

    pub fn safe_new(

Done.

Copy link
Collaborator

@alonh5 alonh5 left a comment

Choose a reason for hiding this comment

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

Reviewed 7 of 7 files at r3, all commit messages.
Reviewable status: :shipit: complete! all files reviewed, all discussions resolved (waiting on @aner-starkware and @dorimedini-starkware)

Copy link
Collaborator

@alonh5 alonh5 left a comment

Choose a reason for hiding this comment

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

Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @aner-starkware, @ArniStarkware, and @dorimedini-starkware)


crates/blockifier/src/blockifier/block.rs line 108 at r3 (raw file):

            FeeType::Eth => &self.eth_gas_prices,
        }
    }

You can also remove these now.

Code quote:

    pub fn get_l1_gas_price_by_fee_type(&self, fee_type: &FeeType) -> NonzeroGasPrice {
        self.get_gas_prices_by_fee_type(fee_type).l1_gas_price
    }

    pub fn get_l1_data_gas_price_by_fee_type(&self, fee_type: &FeeType) -> NonzeroGasPrice {
        self.get_gas_prices_by_fee_type(fee_type).l1_data_gas_price
    }

    pub fn get_l2_gas_price_by_fee_type(&self, fee_type: &FeeType) -> NonzeroGasPrice {
        self.get_gas_prices_by_fee_type(fee_type).l2_gas_price
    }

    pub fn get_gas_prices_by_fee_type(&self, fee_type: &FeeType) -> &GasPriceVector {
        match fee_type {
            FeeType::Strk => &self.strk_gas_prices,
            FeeType::Eth => &self.eth_gas_prices,
        }
    }

@ArniStarkware ArniStarkware requested a review from alonh5 November 24, 2024 16:01
Copy link
Contributor Author

@ArniStarkware ArniStarkware left a comment

Choose a reason for hiding this comment

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

Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @alonh5, @aner-starkware, and @dorimedini-starkware)


crates/blockifier/src/blockifier/block.rs line 108 at r3 (raw file):

Previously, alonh5 (Alon Haramati) wrote…

You can also remove these now.

No - I can not. I looked into it.
It is used in many locations, non-trivially.

Copy link
Collaborator

@alonh5 alonh5 left a comment

Choose a reason for hiding this comment

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

Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @aner-starkware, @ArniStarkware, and @dorimedini-starkware)


crates/blockifier/src/blockifier/block.rs line 108 at r3 (raw file):

Previously, ArniStarkware (Arnon Hod) wrote…

No - I can not. I looked into it.
It is used in many locations, non-trivially.

Oh I see. Let's leave them then.
Can you remove the get_ prefix and the _by_fee_type suffix?
The Rust style guide says you shouldn't use get_ and the _by_fee_type is also redundant because the fee type argument signifies that.

Copy link
Contributor Author

@ArniStarkware ArniStarkware left a comment

Choose a reason for hiding this comment

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

Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @alonh5, @aner-starkware, and @dorimedini-starkware)


crates/blockifier/src/blockifier/block.rs line 108 at r3 (raw file):

Previously, alonh5 (Alon Haramati) wrote…

Oh I see. Let's leave them then.
Can you remove the get_ prefix and the _by_fee_type suffix?
The Rust style guide says you shouldn't use get_ and the _by_fee_type is also redundant because the fee type argument signifies that.

Done. Now on the next PR on this stack: #2269.

@ArniStarkware ArniStarkware force-pushed the arni/gas_prices/separate_new_from_validate branch from 8ed2ee0 to 0056b67 Compare November 25, 2024 11:49
Copy link
Collaborator

@alonh5 alonh5 left a comment

Choose a reason for hiding this comment

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

:lgtm:

Reviewable status: :shipit: complete! all files reviewed, all discussions resolved (waiting on @aner-starkware and @dorimedini-starkware)

@ArniStarkware ArniStarkware force-pushed the arni/gas_prices/separate_new_from_validate branch 2 times, most recently from b761166 to 7d6ad29 Compare November 25, 2024 14:56
Copy link
Collaborator

@alonh5 alonh5 left a comment

Choose a reason for hiding this comment

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

Reviewed 1 of 1 files at r4, all commit messages.
Reviewable status: :shipit: complete! all files reviewed, all discussions resolved (waiting on @aner-starkware and @dorimedini-starkware)

@ArniStarkware ArniStarkware force-pushed the arni/gas_prices/separate_new_from_validate branch 3 times, most recently from e677ebf to dd596b9 Compare November 27, 2024 09:31
@ArniStarkware ArniStarkware force-pushed the arni/gas_prices/separate_new_from_validate branch from dd596b9 to d60ce60 Compare November 28, 2024 07:06
Copy link
Collaborator

@alonh5 alonh5 left a comment

Choose a reason for hiding this comment

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

Reviewed 3 of 3 files at r5, all commit messages.
Reviewable status: :shipit: complete! all files reviewed, all discussions resolved (waiting on @aner-starkware and @dorimedini-starkware)

@ArniStarkware ArniStarkware merged commit 23231e4 into main Nov 28, 2024
20 checks passed
Copy link
Contributor Author

Merge activity

  • Nov 28, 4:15 AM EST: A user merged this pull request with Graphite.

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

Successfully merging this pull request may close these issues.

3 participants