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

Non-exhaustive testing #1599

Merged
merged 68 commits into from
Oct 31, 2022
Merged

Non-exhaustive testing #1599

merged 68 commits into from
Oct 31, 2022

Conversation

stephencelis
Copy link
Member

This PR introduces the ability to configure a test store's level of exhaustivity. We have always promoted TCA's exhaustive testing as a great feature, and it's helped us and others catch many bugs quickly over the years.

This thoroughness isn't without its pitfalls, though, especially when testing the integration of several reducers. We've seen this firsthand in larger applications, like isowords, and other TCA users have battled with it, as well.

This led @krzysztofzablocki to propose a "non-exhaustive" test store, which would allow you to dial in your assertions to focus on just what you care about. After working together, we're bringing this functionality into the Composable Architecture in a configurable way.

@acosmicflamingo
Copy link
Contributor

Nice! Is there going to be a PointFree episode dedicated to this or will I have to actually read documentation? :)

.github/workflows/ci.yml Outdated Show resolved Hide resolved
@mbrandonw
Copy link
Member

Nice! Is there going to be a PointFree episode dedicated to this or will I have to actually read documentation? :)

No episode is planned for this change, but we may discuss it in future episodes. 😁

@mbrandonw mbrandonw merged commit 5d687b6 into main Oct 31, 2022
@mbrandonw mbrandonw deleted the extendable-test-store branch October 31, 2022 18:23
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.

3 participants