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

Allow to specify the source when adding a package #1886

Closed
2 tasks done
k4nar opened this issue Jan 14, 2020 · 11 comments
Closed
2 tasks done

Allow to specify the source when adding a package #1886

k4nar opened this issue Jan 14, 2020 · 11 comments
Labels
kind/feature Feature requests/implementations
Milestone

Comments

@k4nar
Copy link
Contributor

k4nar commented Jan 14, 2020

  • I have searched the issues of this repo and believe that this is not a duplicate.
  • I have searched the documentation and believe that my question is not covered.

Feature Request

Since Poetry 1.0 we can specify the source of package in the pyproject.toml, in order to use another index than PyPI. This is very convenient, but there is no way to specify this when using the poetry add command.

This is especially inconvenient when you're trying to update an existing private dependency with poetry add, as it will erase its source.

My suggestion would be to add a --source option to poetry add, taking the name of a source defined in the pyproject.toml. I don't think adding a package from a source not defined previously should be accepted.

@k4nar k4nar added the kind/feature Feature requests/implementations label Jan 14, 2020
@k4nar
Copy link
Contributor Author

k4nar commented Jan 17, 2020

I'm working on a PR, the solution seems to be very easy in the end.

@ghost
Copy link

ghost commented Sep 17, 2020

It looks like #1912 was merged but then later lost again in 9ab2581. Was this by accident?

In light of GitLab's new feature (git/source repository specific package repositories), this would be a rather useful feature.

@k4nar
Copy link
Contributor Author

k4nar commented Sep 17, 2020

I think it was intentionally delayed for the version 1.1. Apparently the commit is still present in the branch 1.1.0b2 so I'm hopeful :) .

@abn abn added this to the 1.1 milestone Sep 17, 2020
@abn
Copy link
Member

abn commented Sep 17, 2020

This already added for 1.1.0 and available in the current pre-release.

@abn abn closed this as completed Sep 17, 2020
@GuillaumeLegoy
Copy link

Hi, it looks like this was never implemented or I'm maybe missing something? We have a use case where a custom package bears the same name as a public PyPi package and specifying the source when running poetry add would be great.

@sinoroc
Copy link

sinoroc commented Dec 9, 2020

@GuillaumeLegoy You probably should use something like devpi and configure it correctly so that private packages are preferred over public ones (PyPI). This is the only correct way of dealing with such cases in the end. A lot of background information in this discussion if you are interested.

@GuillaumeLegoy
Copy link

Thanks will take a look. However it doesn't answer the above question as it looks like it was implemented but somehow never made it to live?
Also I've experienced with the secondary vs default settings of poetry sources and ran into errors as well. If we could simply specify a private repository as default and PyPi as fallback that would solve it as well (first look into private repo, if not found revert to PyPi).

@sinoroc
Copy link

sinoroc commented Dec 9, 2020

However it doesn't answer the above question as it looks like it was implemented but somehow never made it to live?

I have poetry 1.1.4 and I can see the --source flag:

$ poetry add --help
USAGE
  poetry add [-D] [-E <...>] [--optional] [--python <...>] [--platform <...>] [--source <...>] [--allow-
             prereleases] [--dry-run] [--lock] <name1> ... [<nameN>]

ARGUMENTS
  <name>                 The packages to add.

OPTIONS
  -D (--dev)             Add as a development dependency.
  -E (--extras)          Extras to activate for the dependency. (multiple values allowed)
  --optional             Add as an optional dependency.
  --python               Python version for which the dependency must be installed.
  --platform             Platforms for which the dependency must be installed.
  --source               Name of the source to use to install the package.
  --allow-prereleases    Accept prereleases.
  --dry-run              Output the operations but do not execute anything (implicitly enables
                         --verbose).
  --lock                 Do not perform operations (only update the lockfile).

[...]

If we could simply specify a private repository as default and PyPi as fallback that would solve it as well (first look into private repo, if not found revert to PyPi).

In Python packaging world, this is not a real thing as far as I understood. There can not be priorities between indexes. Poetry might offer this, but in general the packaging ecosystem was not built to allow this (for example pip does not allow ordering the indexes), so I would not recommend relying on this too much. See also more details in /~https://github.com/python-poetry/poetry/issues/3269. From my point of view a well configured private index (devpi or other), is a much better solution that will work with any tool (poetry, pip, etc.).

Also I've experienced with the secondary vs default settings of poetry sources and ran into errors as well.

I don't think I ever seriously experimented with this. Indeed poetry claims to support a single primary index plus multiple secondary indexes (which I assume means that distributions are searched in the primary first, and if it fails in the secondary ones). So if that does not work as expected it might be a poetry bug. Maybe there are already tickets on this, if not feel free to open a bug tracking ticket.

@GuillaumeLegoy
Copy link

@sinoroc you are right, I see the tag as well. It's not in the doc yet (might go ahead and submit a PR!).

Thanks for the info, it was really helpful, appreciate it!

@dangreenisrael
Copy link

Anybody have thoughts on extending this to show. The use case I'm thinking of is checking if the current version of the package being worked on (private) matches the version in the private repo.

This is for the sake of auto-publishing in CI

Copy link

github-actions bot commented Mar 2, 2024

This issue has been automatically locked since there has not been any recent activity after it was closed. Please open a new issue for related bugs.

@github-actions github-actions bot locked as resolved and limited conversation to collaborators Mar 2, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
kind/feature Feature requests/implementations
Projects
None yet
Development

No branches or pull requests

5 participants