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

Add optional deps if not using hatch #59

Open
wants to merge 4 commits into
base: main
Choose a base branch
from

Conversation

sneakers-the-rat
Copy link
Contributor

Currently if you say "no" to using hatch envs but "yes" to all the bells and whistles, you end up with a package that doesn't have the optional dependencies needed to use them :(

so this completes another leg of the combinatoric labyrinth we are constructing here ;)

for a project my_package with hatch off...

and nothing special is added:

[project.optional-dependencies]
dev = [
    "hatch",
    "pre-commit",
    "my_package[audit]",
]
audit = [
    "pip-audit",
]

and everything special is added

[project.optional-dependencies]
dev = [
    "hatch",
    "pre-commit",
    "my_package[docs,tests,style,types,audit]",
]
docs = [
    "pydata_sphinx_theme ~=0.16",
    "myst-parser ~=4.0",
    "Sphinx ~=8.0",
    "sphinx-autobuild ==2024.10.3"
]
tests = [
    "pytest",
    "pytest-cov",
    "pytest-raises",
    "pytest-randomly",
    "pytest-xdist",
]
style = [
    "pydoclint",
    "ruff",
]
types = [
    "mypy",
]
audit = [
    "pip-audit",
]

and the permutations in between.

I think this officially puts as at the time in every template's life where we need to start abstracting the values, because keeping deps synchronized will be tough.

@Midnighter
Copy link
Contributor

I'm not super happy with the optional dependencies listed in dev to be honest. I think, hatch is much better installed via pipx and likely pre-commit, too.

How about we wait until dependency-groups are fully supported by hatch and then give this a go?

@sneakers-the-rat
Copy link
Contributor Author

part of that might be differences in how we use that group/term? Between these two pyproject.tomls (the template one and the top-level one) I think i see you using them as like 'minimal' dev requirements: just enough to get you started in the environment, and then the packaging tool takes over (i didn't realize hatch had a full tox-like env system until today, i have been using pdm bc simple but now i am like :eyes-emoji: ), where i have typically used that as "everything used during development, which is usually close to everything everything." I'm a little old fashioned and haven't made pipx part of my routine yet.

So maybe we take all the other optional deps out of dev and make an all group instead?

I think it's worth doing in the short term for a few reasons:

  • first is that if someone is exploring, past first steps, and wants to see how "non-hatch" works. at the moment they would just get nothing: instead of a comparison of "how does this look like in hatch vs not hatch" it would just be "having the deps vs not having them"
  • relatedly, a package generated without hatch but yes on the other options would end up with a decent bit of dead/unusable code in the repo without clear path to resolve that
  • i'll open a separate issue on this rn so i can know if i should stop thinking this, but i also eventually imagine it would be nice to have a choice of frontend/backend managers down the line. It would take a bit of doing, and i think we would have to give up on feature parity between all of them (e.g. hatch might have a deeper config tree that lets you do fancy hatch things), but there are some things like deps and dep groups that would need to have some representation in all frontend/backend combos. So starting to keep that division in mind early and not getting too far off in hatch-only land might make it easier later on when we want to think about other package managers.

@blink1073
Copy link
Contributor

I agree with this approach, it is similar to what we've used in Jupyter libraries. Having everything self-contained has been super helpful for contributors.

Copy link
Contributor

@blink1073 blink1073 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM!

@sneakers-the-rat
Copy link
Contributor Author

sneakers-the-rat commented Nov 1, 2024

want to check with @Midnighter before merging since he expressed some reservations. is this ok or no good? :)

edit: I didn't make the switch to an all dependency group to leave dev just as hatch, but can totally do that if it's preferable.

@Midnighter
Copy link
Contributor

Go ahead, we can revisit this when new features are available.

@lwasser
Copy link
Member

lwasser commented Nov 7, 2024

@all-contributors please add @sneakers-the-rat for code, review

Copy link
Contributor

@lwasser

I've put up a pull request to add @sneakers-the-rat! 🎉

@lwasser
Copy link
Member

lwasser commented Jan 8, 2025

There are a lot of deps here that i suspect we could drop to make this truly beginner friendly.

can anyone tell me what the following deps are used for:

"pytest-raises",
"pytest-randomly",
"pytest-xdist",

we use pytest-raises as a command in stravalib for testing but I've never used that dep.

The other two i'm completely unfamiliar with. i'd like us to exploring cleaning this up with the goal of making our template much simpler and more user friendly.

let's keep in mind our target user - something just getting started with testing. for me that is

pytest, pytest-cov for coverage ... there may be another one or two that we want, but I suspect we can drop the others. what do you all think?

we can always include lessons on adding more bells and whistles, but starting simpler is best here (and our goal).

@sneakers-the-rat
Copy link
Contributor Author

  • pytest-xdist runs tests concurrently
  • pytest-raises lets you do with pytest.raises as a mark decorator rather than a context manager
  • pytest-randomly shuffles test order.

I agree that we should keep dependencies minimal, for both newbies as well as more experienced devs that might use the template. It buts up against the purpose of the template - is this a "best practices" template or one that implements the packaging guide? Is this a one-and-done template or a modular template where people can choose their own adventure? If we were going for "best practices" we should keep randomly but it's not in the packaging guide, and so on.

Anyway this PR is dependency neutral, it's just about making it so you get the same deps whether you use hatch or not (in a way that touches as little as possible, I actually think we should move all those to yaml data files and not define them inline, but didnt want to change too much in one PR), so maybe we move trimming deps to a different issue?

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.

4 participants