-
Notifications
You must be signed in to change notification settings - Fork 60
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
add abacusutils to downstream #1845
Conversation
3b2207f
to
9762d28
Compare
@lgarrison if you have a chance to take a look at this PR that would be great! Let me know if there are different tests that might be useful (and hopefully straightforward) to run as part of asdf's downstream testing. Our downstream tests run weekly, prior to release and on PRs that we expect might cause downstream warnings and failures. So far I only see 1 warning (mentioned in the description above) due to the deprecation of |
pip install --no-build-isolation classy corrfunc | ||
pip install -e abacusutils[test] | ||
pip install -r {env_tmp_dir}/requirements.txt | ||
bash -c "echo '' > pytest.ini" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I had to make a blank "pytest.ini" here to prevent pytest from searching the parent directory and finding the asdf pytest configuration (in pyproject.toml in the asdf checkout). I think this should still work if abacusutils adds a pytest configuration (since that should be found before the blank pytest.ini created here).
Cool, thanks for putting this together! abacusutils does a lot of things, many of which don't use asdf, so I think it might make sense to use a restricted set of tests so it runs faster (and maybe more reliably) in CI. I would suggest:
I think that doesn't need any of the source-only dependencies. All that should be needed is:
Can you try that? I don't think any of these paths/dependencies are likely to change in the near future. |
Thanks! I gave this a try and it ran into a few issues that I think are related to numpy 2. I'm going to try switching back to installing from source (which I think was working) and then running just the tests you mentioned to see what that does. Also I tried to run this locally on a mac (while working on the change) and got a number of errors since os.sched_getaffinity is only available on unix. Let me know if it's helpful to open an abacusutils issue for that (it shouldn't cause an issue here since the CI runs in linux). |
e6cbb77
to
1683cb4
Compare
Oh that's interesting, a recent PR I made seems to have had the side effect of fixing NumPy 2 installs. I don't even think I noticed that NumPy 2 was broken because we were testing against NumPy 1 for Classy! I think a source install from GitHub (e.g. We haven't been packaging the tests in the wheels partly because they rely on data files that inflate the wheel size. I'm happy to revisit that in the future, especially if you prefer to test against released versions. Last time I checked, the tests on Mac were failing in a non-trivial way (abacusorg/abacusutils#59). I don't have a Mac, so I didn't get very far in debugging it, unfortunately. |
1683cb4
to
7db6470
Compare
For the future, I think this:
could be simplified to:
Since the tests are working, it's fine to leave it as-is, but Corrfunc and classy can take a while to build/can be fragile, so I just wanted to note this possible simplification. |
This PR adds https://github.com/abacusorg/abacusutils to our downstream tests.
The tox environment was largely modeled on the test setup in the downstream repo:
https://github.com/abacusorg/abacusutils/blob/6e18f79fc31aea7973abbb144b78d049a2452eeb/.github/workflows/tests.yml#L84
as there are a few "difficult to install" dependencies.
The tests are currently passing but do show some warnings related to asdf:
which are expected following the deprecation of
copy_arrays
#1797Checklist:
pre-commit checks ran successfully
tests ran successfully
for a public change, added a towncrier news fragment
changes/<PR#>.<changetype>.rst
changes/<PR#>.feature.rst
: new featurechanges/<PR#>.bugfix.rst
: bug fixchanges/<PR#>.doc.rst
: documentation changechanges/<PR#>.removal.rst
: deprecation or removal of public APIchanges/<PR#>.general.rst
: infrastructure or miscellaneous changefor a public change, updated documentation
for any new features, unit tests were added