mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-16 01:26:24 +00:00
8560b5d657
* fix bad indentation * remove punctuation from end of (un)ordered lists
109 lines
3.8 KiB
Markdown
109 lines
3.8 KiB
Markdown
---
|
|
title: Python Package Manager Support
|
|
description: Python/pip dependencies support in Renovate
|
|
---
|
|
|
|
# Python Package Manager Support
|
|
|
|
Renovate supports the following Python package managers:
|
|
|
|
- `pip` (e.g. `requirements.txt`, `requirements.pip`) files
|
|
- `pipenv` (e.g. `Pipfile`)
|
|
- `setup.py`
|
|
|
|
## Versioning Support
|
|
|
|
The [PEP440](https://www.python.org/dev/peps/pep-0440/) versioning scheme has been rewritten for JavaScript for the purposes of use in this project is published as [@renovatebot/pep440](https://github.com/renovatebot/pep440).
|
|
It supports both pinned versions as well as ranges. Legacy versions (`===` prefix) are ignored.
|
|
|
|
## How It Works
|
|
|
|
1. Renovate will search each repository for any package files it finds
|
|
2. Existing dependencies will be extracted from the file(s)
|
|
3. Renovate will look up the latest version on [PyPI](https://pypi.org/) to determine if any upgrades are available
|
|
4. If the source package includes a GitHub URL as its source, and has either a "changelog" file or uses GitHub releases, then Release Notes for each version will be embedded in the generated PR
|
|
|
|
## Enabling Beta
|
|
|
|
Both `pipenv` and `setup.py` are classified a "beta", so they are not enabled by default.
|
|
To enable them, you need to add configuration like the following to your `renovate.json` file:
|
|
|
|
```json
|
|
{
|
|
"pipenv": {
|
|
"enabled": true
|
|
}
|
|
}
|
|
```
|
|
|
|
Note: if you _only_ have these package files and no other package files (like `package.json`, `Dockerfile`, etc) then Renovate won't detect them and you won't get an onboarding PR.
|
|
In that case you need to add Renovate configuration manually to skip the onboarding step.
|
|
|
|
## Alternative file names
|
|
|
|
The default file matching regex for `requirements.txt` aims to pick up the most popular conventions for file naming, but it's possible that some get missed.
|
|
If you have a specific file or file pattern you want to get found by Renovate, then you can do this by adding a new pattern under the `fileMatch` field of `pip_requirements`.
|
|
e.g. you could add this to your config:
|
|
|
|
```json
|
|
"pip_requirements": {
|
|
"fileMatch": ["my/specifically-named.file", "\.requirements$"]
|
|
}
|
|
```
|
|
|
|
## Alternate registries
|
|
|
|
Renovate will default to performing all lookups on pypi.org, but it also supports alternative index URLs.
|
|
There are two ways to achieve this:
|
|
|
|
#### index-url in `requirements.txt`
|
|
|
|
The index URL can be specified in the first line of the file.
|
|
For example:
|
|
|
|
```
|
|
--index-url http://example.com/private-pypi/
|
|
some-package==0.3.1
|
|
some-other-package==1.0.0
|
|
```
|
|
|
|
#### Sources in `Pipfile`
|
|
|
|
Renovate will detect any custom-configured sources in `Pipfile` and use them.
|
|
|
|
#### Specify URL in configuration
|
|
|
|
The configuration option `registryUrls` can be used to configure an alternate index URL.
|
|
Example:
|
|
|
|
```json
|
|
"python": {
|
|
"registryUrls": ["http://example.com/private-pypi/"]
|
|
}
|
|
```
|
|
|
|
Note: an index-url found in the `requirements.txt` will take precedent over a registryUrl configured like the above.
|
|
To override the URL found in `requirements.txt`, you need to configure it in `packageRules`, as they are applied _after_ package file extraction.
|
|
|
|
## Disabling Python Support
|
|
|
|
The most direct way to disable all Python support in Renovate is like this:
|
|
|
|
```json
|
|
"python": {
|
|
"enabled": false
|
|
}
|
|
```
|
|
|
|
Alternatively, maybe you only want one package manager, such as `npm`.
|
|
In that case this would enable _only_ `npm`:
|
|
|
|
```json
|
|
"enabledManagers": ["npm"]
|
|
```
|
|
|
|
## Future work
|
|
|
|
Feature requests are open for conda support and additional file types (e.g. `setup.cfg`).
|
|
You can locate these issues by filtering on the [#python](https://github.com/renovatebot/renovate/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc+label%3A%23python) hashtag in the repository.
|
|
Please +1 and/or add a comment to each issue that would benefit you so that we can gauge the popularity/importance of each.
|