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

Cap maximum gas price #4308

Merged
merged 10 commits into from
May 24, 2021
Merged

Cap maximum gas price #4308

merged 10 commits into from
May 24, 2021

Conversation

Longarithm
Copy link
Member

@Longarithm Longarithm commented May 20, 2021

Cap maximum gas price: #4302

Test plan

  • test_cap_max_gas_price checks that max_gas_price <= 10 * min_gas_price for the new protocol version.
  • process_blocks.rs:cap_max_gas_price_tests check that gas_price may exceed 10 * min_gas_price for the old protocol version but may not for the new one.

@Longarithm Longarithm self-assigned this May 20, 2021
@Longarithm Longarithm linked an issue May 20, 2021 that may be closed by this pull request
@Longarithm Longarithm marked this pull request as ready for review May 20, 2021 16:53
Copy link
Collaborator

@bowenwang1996 bowenwang1996 left a comment

Choose a reason for hiding this comment

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

Please add a test that asserts the gas price does not exceed maximum gas price even when there is congestion.

@Longarithm
Copy link
Member Author

Added new tests and moved creation of congestion to a separate function

Copy link
Collaborator

@bowenwang1996 bowenwang1996 left a comment

Choose a reason for hiding this comment

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

Well done!

@@ -77,6 +77,79 @@ pub fn create_nightshade_runtimes(genesis: &Genesis, n: usize) -> Vec<Arc<dyn Ru
.collect()
}

/// Create environment and set of transactions which cause congestion on the chain.
fn create_env_with_congestion(
Copy link
Collaborator

Choose a reason for hiding this comment

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

Nice

Comment on lines 2774 to 2783
env.produce_block(0, i);
let block = env.clients[0].chain.get_block_by_height(i).unwrap().clone();
let protocol_version = env.clients[0]
.runtime_adapter
.get_epoch_protocol_version(block.header().epoch_id())
.unwrap();
let min_gas_price =
env.clients[0].chain.block_economics_config.min_gas_price(protocol_version);
if block.header().gas_price() > 10 * min_gas_price {
return true;
Copy link
Collaborator

Choose a reason for hiding this comment

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

Please also assert that congestion actually happens. You can do this by asserting that gas usage is at least as large as gas limit.

@near-bulldozer near-bulldozer bot merged commit 6588460 into master May 24, 2021
@near-bulldozer near-bulldozer bot deleted the cap-gas branch May 24, 2021 23:31
near-bulldozer bot pushed a commit that referenced this pull request Jun 7, 2021
- Actually update nightly protocol version to catch CapMaxGasPrice feature which I forgot to do here: #4308
- Fix tests for `RestoreReceiptsAfterFix` feature started failing after it. Reason: protocol feature have to be set in produced blocks explicitly like in `storage_usage_fix_tests`
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.

Cap maximum gas price
3 participants