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

Add assertions in the FeeRate constructor #694

Merged
merged 1 commit into from
Aug 2, 2022

Conversation

afilini
Copy link
Member

@afilini afilini commented Jul 30, 2022

Description

Disallow negative, NaN, infinite or subnormal fee rate values.

Notes to the reviewers

This commit is technically an API break because it makes the FeeRate::from_sat_per_vb function non-const. I think it's worth it compared to the risk of having completely nonsensical fee rates (that can break the coin selection in interesting ways).

EDIT: it's also a breaking change because our code can now panic in scenarios where it didn't before. Again, I think it's worth it.

Checklists

All Submissions:

  • I've signed all my commits
  • I followed the contribution guidelines
  • I ran cargo fmt and cargo clippy before committing

Bugfixes:

  • This pull request breaks the existing API
  • I've added tests to reproduce the issue which are now passing
  • I'm linking the issue being fixed by this PR

Sorry, something went wrong.

@afilini afilini added the new feature New feature or request label Jul 30, 2022
@afilini afilini added this to the Release 0.21.0 Feature Freeze milestone Jul 30, 2022
@afilini afilini force-pushed the fix/feerate-assertions branch 2 times, most recently from 36f7427 to 00e5c1d Compare July 30, 2022 16:10
Copy link
Member

@danielabrozzoni danielabrozzoni left a comment

Choose a reason for hiding this comment

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

utACK 00e5c1d

Disallow negative, NaN, infinite or subnormal fee rate values.
@afilini afilini force-pushed the fix/feerate-assertions branch from 4dbd2bd to 235011f Compare August 2, 2022 09:02
@danielabrozzoni
Copy link
Member

re-ACK 235011f

@afilini afilini merged commit 8e0d00a into bitcoindevkit:master Aug 2, 2022
@afilini afilini deleted the fix/feerate-assertions branch August 2, 2022 09:27
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
new feature New feature or request
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

3 participants