-
Notifications
You must be signed in to change notification settings - Fork 43
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
Simplify tests, shorten buildir name on windows #137
base: main
Are you sure you want to change the base?
Conversation
I am not sure why CI is failing. When I run the tests locally they pass. |
Force the tests to re-run (unsure how), and see if they still fail? If they do, force a re-run on the base (unsure how) and see if they still pass? If all that is true, then dig deeper. |
The failure we get is genuine. I think you can get it too by running both |
When I run the tests locally the |
Maybe the CI runs pytest-xdist anyway? Or some other pytest version, or other plugins, etc.? Something that would make the order of execution different, e.g. |
I am stumped. No pytest-xdist plugin is used:
and the tests are run in the correct order:
When I can I will add debug cruft to |
Another strange thing I noticed in the codebase: there is both testing/cffi0/test_verify.py and testing/cffi1/test_verify1.py. These files echo each other: they have many of the same tests with slight variations. Some of these repeated tests are quite "expensive" on PyPy's nightly testing on windows. For instance:
|
Still stumped. I used |
f40b90e
to
4e7ebbd
Compare
CI was passing so I removed the debug cruft and enabled windows tests. Let's see how long it takes. I am not sure why when using a module name I had to create a unique module name but 🤷. I guess #135 avoided this problem by making all the module names unique. |
25 minutes for windows tests, I guess that is acceptable? It could be less if the repetitive tests are removed from cffi0/test_verify and cffi1/test_verify1.py |
cffi0 checks the verify() call that was in cffi 0.x.y, while cffi1 checks the new compile() call. This is very different pieces of code, even if they both implement a large common part. |
Ahh, makes sense, thanks for clarifying. CI is passing, including enabling windows tests. |
Taken from #135, without the pytest-xdist module name randomization
This should be smaller and easier to review: