-
Notifications
You must be signed in to change notification settings - Fork 407
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
Tuple shrinking should go to 11 (and beyond) #738
Comments
I added pull request #744 which implements this. |
I was going to suggest adding to the existing code-generation, so that seems like the right approach in #744 rather than copy-paste. |
I have one concern about "fixing" this: Was the limit to tuples of 9 an historical artifact of either Scala or ScalaCheck or was it intentional? One reason it might be intentional is because raising the shrinking to greater tuple sizes means that shrinking complexity is increased and failures might be extremely slow. Unfortunately, issues around test failures like this aren't likely to be caught in our test suite. I believe the complexity would be something on the order of n^m where n is the bit-length of the value and m is the number of tuples. I'll need to run some experiments to verify that suspicion. |
I guess we could re-implement a small part of the shrinking process, a la
Empiricism ftw :-) I think for tuples of ints, I can half-way persuade myself that shrinking However, that's assuming 0 is the shrink target. If you use a sized generator (generating e.g. Anyways, on the assumption that this is a problem, we could perhaps make the shrinkers available but only make the first 9 implicit; then users can uh implicitize whatever they want to use. Maybe if it's only marginally a problem, big tuple shrinking could be enabled by default if the old behavior can be restored?
I'm not sure how I could know for sure, but here's a probably-relevant observation: the most recent change which touches the tuple shrinking lines in |
The largest tuple size for which ScalaCheck provides built-in shrinking is 9. I think ScalaCheck should provide built-in shrinking for all tuple sizes (i.e. 2 to 22).
At work we would like to shrink both 11- and 22-tuples, and they might change size as the underlying case classes acquire new fields. I'll happily do the copy-paste grunt work of writing the patch if you think this is a feature you want.
The text was updated successfully, but these errors were encountered: