Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alkasm/vcs-url-install-example
https://github.com/alkasm/vcs-url-install-example
Last synced: 13 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/alkasm/vcs-url-install-example
- Owner: alkasm
- Created: 2022-06-23T18:49:49.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2022-06-23T18:55:45.000Z (over 2 years ago)
- Last Synced: 2024-11-13T18:06:09.857Z (2 months ago)
- Language: Python
- Size: 7.81 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
This repo demonstrates the problem of "offline installations of a package with a VCS URL dependency fails even if the dependency is already installed."
This was tested with `pip 22.1.2`, but as far as I know can be reproduced on any version of `pip` since the new resolver was rolled out.
1. With a connection to the internet, `pip install .` pulls the VCS URL at install time and succeeds:
```
Processing /Users/alkasm/prog/test-vcs-url
Preparing metadata (setup.py) ... done
Collecting theta-alkasm@ git+ssh://[email protected]/alkasm/theta
Cloning ssh://****@github.com/alkasm/theta to /private/var/folders/f0/_dkywzrd7f3bd4hdj2bmfv4m0000gp/T/pip-install-2yry1xt_/theta-alkasm_50aee5ce640c490494d6c7fabdb084fc
Running command git clone --filter=blob:none --quiet 'ssh://****@github.com/alkasm/theta' /private/var/folders/f0/_dkywzrd7f3bd4hdj2bmfv4m0000gp/T/pip-install-2yry1xt_/theta-alkasm_50aee5ce640c490494d6c7fabdb084fc
Resolved ssh://****@github.com/alkasm/theta to commit 796aa646d65c998cf9b68370d22f0e1a2dc0bd87
Installing build dependencies ... done
Getting requirements to build wheel ... done
Preparing metadata (pyproject.toml) ... done
Using legacy 'setup.py install' for test-pkg, since package 'wheel' is not installed.
Installing collected packages: test-pkg
Running setup.py install for test-pkg ... done
Successfully installed test-pkg-0.0.0
```
2. If you then disconnect from the internet and try to `pip install .` again, the package will fail to install with an error like:
```
pip install .
Processing /Users/alkasm/prog/test-vcs-url
Preparing metadata (setup.py) ... done
Collecting theta-alkasm@ git+ssh://[email protected]/alkasm/theta
Cloning ssh://****@github.com/alkasm/theta to /private/var/folders/f0/_dkywzrd7f3bd4hdj2bmfv4m0000gp/T/pip-install-c25yoka6/theta-alkasm_fb490879532a46778a6bce77390048c9
Running command git clone --filter=blob:none --quiet 'ssh://****@github.com/alkasm/theta' /private/var/folders/f0/_dkywzrd7f3bd4hdj2bmfv4m0000gp/T/pip-install-c25yoka6/theta-alkasm_fb490879532a46778a6bce77390048c9
ssh: connect to host github.com port 22: Undefined error: 0
fatal: Could not read from remote repository.Please make sure you have the correct access rights
and the repository exists.
error: subprocess-exited-with-error× git clone --filter=blob:none --quiet 'ssh://****@github.com/alkasm/theta' /private/var/folders/f0/_dkywzrd7f3bd4hdj2bmfv4m0000gp/T/pip-install-c25yoka6/theta-alkasm_fb490879532a46778a6bce77390048c9 did not run successfully.
│ exit code: 128
╰─> See above for output.note: This error originates from a subprocess, and is likely not a problem with pip.
error: subprocess-exited-with-error× git clone --filter=blob:none --quiet 'ssh://****@github.com/alkasm/theta' /private/var/folders/f0/_dkywzrd7f3bd4hdj2bmfv4m0000gp/T/pip-install-c25yoka6/theta-alkasm_fb490879532a46778a6bce77390048c9 did not run successfully.
│ exit code: 128
╰─> See above for output.note: This error originates from a subprocess, and is likely not a problem with pip.
```
3. If you instead opt for the legacy resolver via `pip install . --use-deprecated legacy-resolver` it will succeed (assuming the dependency has been installed previously):
```
Processing /Users/alkasm/prog/test-vcs-url
Preparing metadata (setup.py) ... done
Requirement already satisfied: theta-alkasm@ git+ssh://[email protected]/alkasm/theta from git+ssh://****@github.com/alkasm/theta in ./venv/lib/python3.8/site-packages (from test-pkg==0.0.0) (1.2.0)
Using legacy 'setup.py install' for test-pkg, since package 'wheel' is not installed.
Installing collected packages: test-pkg
Attempting uninstall: test-pkg
Found existing installation: test-pkg 0.0.0
Uninstalling test-pkg-0.0.0:
Successfully uninstalled test-pkg-0.0.0
Running setup.py install for test-pkg ... done
Successfully installed test-pkg-0.0.0
```