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

Abstract factory creational methods doctests fail #418

Closed
grimley517 opened this issue May 13, 2024 · 2 comments
Closed

Abstract factory creational methods doctests fail #418

grimley517 opened this issue May 13, 2024 · 2 comments

Comments

@grimley517
Copy link
Contributor

Context

Arrising from PR #417 and issue #415

The doctests for the creation abstract factory are not working. code reference

The issue here appears to be that the random seed isn't making the random selection of pet store determinative.

Reproduction Steps

Run the tests using the lint and test script. (lint.sh in PR #417), or via the github pipeline

Expected Result

Tests pass

Actual result

Doctests fail, with animals assigned randomly

Solutions

The code appears to be good, this is the tests failing. The aim of the code is to demonstrate the pattern. The solution should be to strengthen the tests.

Remove the random pet shop

Since the code's aim is to demonstrate the abstract creation pattern, the random petshop may not be the most testable way to do this. My preference is to remove the random animal petshop from this set of tests. There are some options on what to replace it with in order to demonstrate the pattern.

  • Replace with a dog shop
    • Demonstrates that the animal is determined at run time
    • Does this add anything to the existing cat shop tests?
  • Replace with an alternating animal shop
    • first animal is a cat, second is a dog and so on
    • maintains the demonstration that the type of animal is determined at runtime
  • Do not replace with anything
    • The existing cat shop tests demonstrate the principle. The random shop is cool, but does it add value?

Refactor the tests

Doctests are not sufficiently flexible to handle the non-determinative nature of the random pet shop. The answer could be to remove them as doctests and replace them with traditional unit tests, which demonstrate that the type of animal depends on the kind of pet sold.

Conclusion

I prefer to remove the random pet shop altogether or replace it with an alternating pet shop. The question that should differentiate between these two approaches is whether the test adds anything to the explanation.

@faif
Copy link
Owner

faif commented May 14, 2024

I thought that a contributor added a fixed seed to avoid the randomness issue, so not sure when that broke. I agree with you, the random part is not necessary so we can remove it

grimley517 added a commit to grimley517/python-patterns that referenced this issue May 16, 2024
@grimley517
Copy link
Contributor Author

This issue is resolved with #415

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

No branches or pull requests

2 participants