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

Replace requirements.txt with pyproject.toml for dependency management? #2757

Closed
amandakys opened this issue Jul 3, 2023 · 10 comments
Closed

Comments

@amandakys
Copy link

Introduction

Tracking ticket for discussion about

"Moreover, we should move away from using setup.py and make all Kedro starters use only pyproject.toml and setup.cfg, since this is how the Python ecosystem is evolving."

and

"The setup.cfg, src/setup.py and src/requirements.txt should be replaced with pyproject.toml. pip/setuptools support pyproject.toml out of the box. Would love to have this by default in new projects."

These are comments that came up in #2149 and should be discussed separately to the planned work to strip the project template #2756

@amandakys amandakys added the Stage: Technical Design 🎨 Ticket needs to undergo technical design before implementation label Jul 3, 2023
@amandakys amandakys mentioned this issue Jul 3, 2023
4 tasks
@merelcht merelcht moved this to To Do in Kedro Framework Sep 26, 2023
@merelcht merelcht changed the title Using pyproject.toml for dependency management Replace requirements.txt with pyproject.toml for dependency management Oct 2, 2023
@astrojuanlu
Copy link
Member

This is blocked on #2519.

@merelcht
Copy link
Member

Does it make sense to do this after #4116 ? @astrojuanlu

@merelcht merelcht removed the Stage: Technical Design 🎨 Ticket needs to undergo technical design before implementation label Oct 22, 2024
@astrojuanlu
Copy link
Member

Oh, in a sense I wouldn't know what's left for this issue after we address #4116.

Maybe before getting completely rid of requirements.txt I'd wait until the acceptance of PEP 751 (still wip) or the complete takeover of uv.lock...

@merelcht
Copy link
Member

We just need to do it for all starters as well.

@JoostGevaert
Copy link

+1 for this :)

@astrojuanlu
Copy link
Member

PEP 751 is about to undergo another change in scope https://discuss.python.org/t/pep-751-now-with-graphs/69721/106 so I'm still not sure it's a good moment to dump requirements.txt.

We should probably have a fully resolved requirements.txt, as pip-compile or uv compile would do.

@astrojuanlu astrojuanlu changed the title Replace requirements.txt with pyproject.toml for dependency management Replace requirements.txt with pyproject.toml for dependency management? Nov 17, 2024
@JoostGevaert
Copy link

And what about using hatchling (uv's default) instead of setuptools as the build-system?

@JoostGevaert
Copy link

Maybe that ☝️ question of mine shouldn't be in this issue?
In issues #681 and #4116 I found that I can create a kedro project with uv with kedro-init or copier-kedro. However, I'm still quite new to kedro, so I like being able to start a new project with an example pipeline.

@astrojuanlu
Copy link
Member

And what about using hatchling (uv's default) instead of setuptools as the build-system?

uv defaults might change too 😄 astral-sh/uv#3957

I actually proposed adding a build backend to the stdlib (probably flit) but there's no appetite for that https://discuss.python.org/t/dependencies-for-build-backends-and-debundling-issues/22840/36

But yes, this is unrelated to this issue.

@astrojuanlu
Copy link
Member

PEP 751 reached another dead end, and Brett has steam for 1 more iteration https://discuss.python.org/t/pep-751-now-with-graphs/69721/225

I think the title of this issue is misleading, in that pyproject.toml can host the library dependencies as loose as possible and requirements.txt (or its modern version if it ever exists, or uv.lock) the resolved/pinned dependencies. Hence the former is the input for the latter (pip-tools and uv pip compile would produce a requirements.txt, uv lock produces uv.lock).

I think it's not a good moment to make any changes here, given that

  • "The war of workflow tools" is still on, and uv hasn't "won" yet (lots of projects are happy with Poetry or Hatch at least for now).
  • requirements.txt doesn't have a modern replacement yet, and it's unclear if it will ever have it.

I'm closing this issue, for now.

@astrojuanlu astrojuanlu closed this as not planned Won't fix, can't repro, duplicate, stale Jan 10, 2025
@github-project-automation github-project-automation bot moved this from To Do to Done in Kedro Framework Jan 10, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: Done
Development

No branches or pull requests

4 participants