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

feat(manager): Support poetry custom repositories. #4524

Merged
merged 11 commits into from
Sep 30, 2019
4 changes: 2 additions & 2 deletions lib/manager/poetry/extract.ts
Original file line number Diff line number Diff line change
Expand Up @@ -88,12 +88,12 @@ function extractFromSection(

function extractRegistries(pyprojectfile: PoetryFile): string[] {
const sources = pyprojectfile.tool.poetry.source;
gilbsgilbs marked this conversation as resolved.
Show resolved Hide resolved
const registryUrls: string[] = ['https://pypi.org/pypi/'];
Copy link
Collaborator

Choose a reason for hiding this comment

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

Actually we prefer to handle defaults within datasource, not manager. Otherwise it's too hard to override the default registry URL in Renovate config.

Copy link
Contributor Author

@gilbsgilbs gilbsgilbs Sep 21, 2019

Choose a reason for hiding this comment

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

Do you think 0256ad0 is enough? Unless I'm missing something, I don't think I can easily use the default registry from the pypi datasource if I have other registries to add. Hence, I've done something similar to what pip_requirements manager does.


if (!Array.isArray(sources)) {
return [];
return registryUrls;
}

const registryUrls: string[] = [];
for (const source of sources) {
if (source.url) {
registryUrls.push(source.url);
Copy link
Collaborator

Choose a reason for hiding this comment

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

Should we de-dupe this in case the user configures pypi.org explicitly?

Copy link
Contributor Author

@gilbsgilbs gilbsgilbs Sep 29, 2019

Choose a reason for hiding this comment

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

Sorry, I misread this comment as a statement instead of a question. I committed code that dedupes, but I don't think it is necessary as pypi datasource will only append pypi.org if registryUrls is empty. If poetry manager adds pypi.org itself, pypi datasource won't add any other datasource. Let me revert this.

Edit: unless you meant “configures pypi.org explicitly” in pyproject.toml, which I think is a bit silly 🤔 . Anyways, it is not a bad thing to dedup I think. Let's not revert after all.

Expand Down
13 changes: 13 additions & 0 deletions test/manager/poetry/__snapshots__/extract.spec.ts.snap
Original file line number Diff line number Diff line change
@@ -1,5 +1,17 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP

exports[`lib/manager/poetry/extract extractPackageFile() can parse empty registries 1`] = `
Array [
"https://pypi.org/pypi/",
]
`;

exports[`lib/manager/poetry/extract extractPackageFile() can parse missing registries 1`] = `
Array [
"https://pypi.org/pypi/",
]
`;

exports[`lib/manager/poetry/extract extractPackageFile() extracts multiple dependencies (with dep = {version = "1.2.3"} case) 1`] = `
Array [
Object {
Expand Down Expand Up @@ -159,6 +171,7 @@ Array [

exports[`lib/manager/poetry/extract extractPackageFile() extracts registries 1`] = `
Array [
"https://pypi.org/pypi/",
"https://foo.bar/simple/",
"https://bar.baz/+simple/",
]
Expand Down
8 changes: 5 additions & 3 deletions test/manager/poetry/extract.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -70,15 +70,17 @@ describe('lib/manager/poetry/extract', () => {
it('extracts registries', () => {
const res = extractPackageFile(pyproject6toml, config);
expect(res.registryUrls).toMatchSnapshot();
expect(res.registryUrls).toHaveLength(2);
expect(res.registryUrls).toHaveLength(3);
});
it('can parse empty registries', () => {
const res = extractPackageFile(pyproject7toml, config);
expect(res.registryUrls).toEqual([]);
expect(res.registryUrls).toMatchSnapshot();
expect(res.registryUrls).toHaveLength(1);
});
it('can parse missing registries', () => {
const res = extractPackageFile(pyproject1toml, config);
expect(res.registryUrls).toEqual([]);
expect(res.registryUrls).toMatchSnapshot();
expect(res.registryUrls).toHaveLength(1);
});
it('skips git dependencies', () => {
const content =
Expand Down