-
Notifications
You must be signed in to change notification settings - Fork 39
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
Issues with astropy-helpers #170
Comments
Additionally:
My experience has been that all the hacks and customizations in the helpers seem well-motivated by problems in Astropy, but our WebbPSF and POPPY projects don't have {as large a build matrix, C and Cython extensions, a desire to customize setup.py to the same extent}. So, the benefits of the package template and the helpers are negated by the additional complexity. I think another problem is the lag time: when we run into an issue, it typically takes a day to identify the template or helpers as the underlying cause, then we open an issue, then another day or so passes until we get a resolution. This is a very good level of service for a volunteer project, but a very bad time constant when I'm blocked and can't make progress on something! There's a nonzero probability that POPPY and WebbPSF will gradually accrete customizations of their own over time that end up being similarly opaque to contributors, but at least @mperrin or I will be able to explain what went into them 😄 |
Something we inherited from the package template: this ConfigParser issue. |
@mperrin @josePhoenix - I understand your concern that it can be frustrating to chase down these issues on a code base you didn't write. Trust me, I know that pain very very well! And if it's really true that you are not now nor ever going to be gaining anything by using the template, then there's no reason you should use it. That said, consider the possibility that this may be a confirmation bias problem. There are likely a number of things you've gotten "for free" because it just worked and you never saw that anything was wrong, and no one ever noticed. And on this bit:
The problem lies in putting these paragraphs together. I totally believe that you don't need all of what's in the helpers. But if you do accrete a need for some of it in the future, and build your own version, I bet it will be incompatible. And more importantly, the wider community will not be able to work with you on it. So yes, you two will understand it better, but the 50 other people who could have contributed are now cut out, or have to make the choice of "do I learn the POPPY/WebbPSF way of handling packages, or the affiliated package template", which is a lose-lose for everyone. Especially given that the largest fraction of the time implementing this sort of stuff is always in working around the other bugs and documenting all the fiddly little details.
What I would hope for is that you help us make the helpers and package template better. Then you wouldn't be blocked: you could fix it right away and at the same time help the problem for others. Even if you think that means the best thing to do is throw it away and start over, then maybe that would be good for everyone! But someone has to do it. Happy to chat more about in person on this topic if that makes more sense, given we're all in the same institution... P.S.
I'm pretty sure that's actually due to changes in the Python interpreter (arguably a bug in that it was a subtle change that they probably thought wouldn't affect anything public but actually did). So that goes along with the point above that it's a fix "for free", it's just you happen to catch it in an intermediate state. |
Well, yes, the change that broke that import is from Python. However, had we used the PyPA recommended template for a Another issue is that the way we learned there were changes to pull from upstream was by having our build break and then going and looking around the affiliated package template for likely culprits, then looking around the repo for a fix to copy in manually. We could have pulled in the changes via git, but that makes a really gnarly git history that mixes the package template development commits with our own development, making for vexing |
But the Astropy affiliated package template already imposes this choice! "Do I learn the Python way of packaging, or the Astropy way of packaging?" For example: in an Astropy project, you don't
I do contribute upstream when I can, but I don't feel like I can make effective contributions to the helpers/template. A lot of customizations are motivated by specific limitations in outside tools that someone on the Astropy project has a specific need to work around, but what those limitations are is hard to figure out (except by working backwards from the behavior observed, which I'm not usually doing until the behavior is abnormal...).
Sure! We can set up a time. Marshall and I are somewhat occupied this week, and I believe he is going on vacation soon... so I thought I'd capture my thoughts in this issue. |
Another issue with the pytest customizations in Astropy: |
Astropy helpers and the package template strike again! When building WebbPSF on ReadTheDocs, our latest version of POPPY (including the latest v2.0.1 astropy_helpers submodule) was unable to install: Excerpt from https://readthedocs.org/projects/webbpsf/builds/5821195/:
I saw something on the package template or helpers issue tracker that made me think Upon investigating the post-create hook in the Cookiecutter template, I see it's now in the helpers and only copied out on project creation. So, I updated it in POPPY and ran the RTD build against POPPY |
@josePhoenix - so just to clarify: it worked after you did that, right? (FWIW, the cookiecutter approach to the template is hopefully the first step to making the helpers more "a la carte") |
@mperrin can let you know. My favorite kind of bugs are the ones that only show up in production :) |
In any case, the problems with astropy-helpers have never been insurmountable. They've merely required a totally disproportionate amount of time and expertise in packaging internals to surmount. |
Not to beat a dead horse... but my point is that this depends on what you think it should be proportionate to. Certainly there are "quick fixes" that would be faster (although probably not easier, so I think the packaging expertise is always necessary), but those come with other costs down the road... for example, if someone else has to pick up the maintenance (you know... hypothetically 😉), it'll be easier if it's on shared infrastructure. |
There is a set of shared infrastructure for Python packages. Building an astronomy-specific overlay to attempt to save maintainers from having to understand this shared infrastructure means you carry the maintenance burden of all your dependencies AND of this astronomy-specific overlay. If you're volunteering (or being deputized) to maintain WebbPSF, I wish you the best of luck. I think it's clear that this does not decrease the maintenance burden for casual contributors at this point, so perhaps it should be taken over by a non-casual contributor. |
Yeah. I think we can all agree that the overhead is more proportionate when that cost gets spread across multiple packages by the same maintainer -- which in fact @eteq and I were just discussing by email. :-) This does raise the question of - for something like In any case as of 3 minutes ago, this is now my and @eteq's problem, and no longer @josePhoenix's. :-) Thanks again for all your many contributions over the last 3 years. |
Fair enough, @mperrin. The intent of this machinery is to have fewer problems than you'd have to deal with if you didn't use it. But I think a missing piece of this story is that we don't know about the problems you would have had if the helpers hadn't silently fixed things behind the scenes (e.g. there are constant CI versioning problems that are mostly transparently fixed by the machinery). But I honestly don't know what the balance is there for WebbPSF. It may be that there's a fundamental tension in using the same machinery for more "advanced" cases (for which WebbPSF apparently is one), and the "basic" user who, without the template/helpers, wouldn't ever have managed to package or use tests or anything like that. The helpers currently serve this dual purpose (i.e., they are not just for things that are supposed to go into core astropy), and this may be a result of just that tension. The curious thing is that I would have thought WebbPSF is a fairly straightforward case. So it's a bit confusing why it seems to have a lot more problems than many of the affiliated packages or other template users...? I should say, though: one good bit of feedback I've gotten from the conversations with @josePhoenix is that it would be useful if this machinery was more "a la carte". That is, you can not have pieces you don't need, which should lower the apparent burden on the maintainer (as they only get "what they ask for"). That's now a goal for the helpers, it just requires developer resources which of course are always stretched thin, especially for infrastructure.
👍 🎆 |
Good question, and one I have wondered myself. One possibility is the WebbPSF codebase is something like 2 or 3 years older than Astropy itself, and thus long predates the helpers and package template. It wasn't originally created from the |
I didn't read everything here but am a bit shocked that your Travis CI matrix against |
splitting off this topic from #160 (comment)
Hi @eteq, @josePhoenix can give more of the details, but I think it's a bit of both.
For literally years, every so often I've encountered some random and hard-to-debug failures which eventually traced back to "the astropy helpers are doing something unexpected behind the scenes":
Each of the above has led to time-consuming debugging to track down what's going on, which has been a time sink and distraction from the main tasks we're actually trying to get done. I readily admit that software is hard, and we can't expect a bug-free existence or anything close to it. But overall given the limited functionality we're actually gaining from the astropy helpers (mostly some setup.py tweaks and the sphinx extensions), it seems like the overall return on time invested is negative.
The text was updated successfully, but these errors were encountered: