theStack
commented at 1:06 am on June 26, 2023:
contributor
There are several instances in the tests where random non-zero field elements are generated by calling random_fe_test in a do/while-loop with is-zero condition. This PR deduplicates all these by introducing a random_fe_non_zero_test helper. Note that some instances checked the is-zero condition via secp256k1_fe_normalizes_to_zero_var, which is unnecessary, as the result of random_field_element_test is already normalized (so strictly speaking, this is not a pure refactor, and there could be tiny run-time improvements, though I doubt that’s measurable).
Additionally, the first commit removes the function random_field_element_test as it is logically a duplicate of random_fe_test.
theStack
commented at 1:21 am on June 26, 2023:
contributor
I guess an alternative would be to not care about the zero-case at all (in the sense of not looping, but only asserting/verify-checking) due to the incredibly low probability of that ever happening? (I just remembered the discussion at https://github.com/bitcoin/bitcoin/pull/27479#discussion_r1171972333, though that was about invalid private keys; the probability to create a zero field-element seems to be even many orders of magnitudes lower with 1/p)
real-or-random
commented at 8:43 am on June 26, 2023:
contributor
Concept ACK
Additionally, the first commit removes the function random_fe_test as it is logically a duplicate of random_field_element_test.
I think it’s better to use the name random_fe_test because we have other random_fe_* functions in the tests.
theStack force-pushed
on Jun 26, 2023
theStack renamed this:
tests: introduce helper for non-zero `random_field_element_test()` results
tests: introduce helper for non-zero `random_fe_test()` results
on Jun 26, 2023
theStack
commented at 1:56 pm on June 26, 2023:
contributor
Concept ACK
Additionally, the first commit removes the function random_fe_test as it is logically a duplicate of random_field_element_test.
I think it’s better to use the name random_fe_test because we have other random_fe_* functions in the tests.
Thanks, done. I had to move up the random_fe_test function in the code a little (before random_group_element_test) to avoid a forward declaration, let me know if using that instead would be preferred.
real-or-random approved
real-or-random
commented at 1:58 pm on June 26, 2023:
contributor
utACK5f9b7596cd31fac5f93ad3c5f0ba3dd1f613120f
real-or-random added the label
assurance
on Jun 26, 2023
real-or-random added the label
refactor
on Jun 26, 2023
sipa
commented at 6:12 pm on June 26, 2023:
contributor
utACK5f9b7596cd31fac5f93ad3c5f0ba3dd1f613120f
real-or-random
commented at 7:38 am on June 27, 2023:
contributor
needs rebase :/
tests: refactor: remove duplicate function `random_field_element_test`
There is a function `random_fe_test` which does exactly the
same, so use that instead. Note that it's also moved up before the
`random_group_element_test` function, in order to avoid needing a forward
declaration.
304421d57b
tests: introduce helper for non-zero `random_fe_test` results
There are several instances in the tests where random non-zero field
elements are generated by calling `random_fe_test` in a do/while-loop.
This commit deduplicates all these by introducing a
`random_fe_non_zero_test` helper. Note that some instances checked the
is-zero condition via `secp256k1_fe_normalizes_to_zero_var`, which is
unnecessary, as the result of `random_fe_test` is already normalized (so
strictly speaking, this is not a pure refactor).
5a95a268b9
theStack force-pushed
on Jun 27, 2023
theStack
commented at 8:42 am on June 27, 2023:
contributor
needs rebase :/
Done.
real-or-random approved
real-or-random
commented at 10:16 am on June 27, 2023:
contributor
This is a metadata mirror of the GitHub repository
bitcoin-core/secp256k1.
This site is not affiliated with GitHub.
Content is generated from a GitHub metadata backup.
generated: 2025-01-15 09:15 UTC
This site is hosted by @0xB10C More mirrored repositories can be found on mirror.b10c.me