1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-02-22 18:22:12 +01:00

Merge pull request #1430 from dmach/virtualenv

Support installing osc into virtualenv
This commit is contained in:
Daniel Mach 2023-11-15 13:02:53 +01:00 committed by GitHub
commit 7fff395e7d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 50 additions and 4 deletions

View File

@ -121,3 +121,28 @@ jobs:
- name: 'Run installed osc'
run: |
osc --help
virtualenv:
name: 'virtualenv install test'
runs-on: 'ubuntu-latest'
strategy:
fail-fast: false
steps:
- name: 'Install packages'
run: |
sudo apt-get -y update
sudo apt-get -y --no-install-recommends install git python3-pip python3-rpm python3-virtualenv
- uses: actions/checkout@v3
- name: 'Initialize virtualenv'
run: |
python3 -m venv .env3
source .env3/bin/activate
pip3 install .
- name: 'Run installed osc'
run: |
source .env3/bin/activate
osc --help

View File

@ -5,6 +5,9 @@ Extending osc with plugins
.. note::
New in osc 1.1.0
.. warning::
Plugins are currently NOT supported in virtualenv.
This is a simple tutorial.
More details can be found in the :py:class:`osc.commandline.OscCommand` reference.

View File

@ -17,6 +17,9 @@ def print_msg(*args, print_to="debug"):
elif print_to == "stdout":
# print the message to stdout
print(*args)
elif print_to == "stderr":
# print the message to stderr
print(*args, file=sys.stderr)
else:
raise ValueError(f"Invalid value of the 'print_to' option: {print_to}")

View File

@ -40,6 +40,10 @@ from .util import cpio, rpmquery, safewriter
from .util.helper import _html_escape, format_table
# python3.6 requires reading sys.real_prefix to detect virtualenv
IN_VENV = getattr(sys, "real_prefix", sys.base_prefix) != sys.prefix
class Command:
#: Name of the command as used in the argument parser.
name: str = None
@ -262,6 +266,9 @@ class MainCommand(Command):
return cmd
def load_commands(self):
if IN_VENV:
_private.print_msg("Running in virtual environment, skipping loading plugins installed outside the virtual environment.", print_to="stderr")
for module_prefix, module_path in self.MODULES:
module_path = os.path.expanduser(module_path)
@ -317,12 +324,16 @@ class OscMainCommand(MainCommand):
MODULES = (
("osc.commands", osc_commands.__path__[0]),
("osc.commands.usr_lib", "/usr/lib/osc-plugins"),
("osc.commands.usr_local_lib", "/usr/local/lib/osc-plugins"),
("osc.commands.home_local_lib", "~/.local/lib/osc-plugins"),
("osc.commands.home", "~/.osc-plugins"),
)
if not IN_VENV:
MODULES += (
("osc.commands.usr_lib", "/usr/lib/osc-plugins"),
("osc.commands.usr_local_lib", "/usr/local/lib/osc-plugins"),
("osc.commands.home_local_lib", "~/.local/lib/osc-plugins"),
("osc.commands.home", "~/.osc-plugins"),
)
def __init__(self):
super().__init__()
self.args = None
@ -10056,6 +10067,10 @@ Please submit there instead, or use --nodevelproject to force direct submission.
print(result)
def _load_plugins(self):
if IN_VENV:
_private.print_msg("Running in virtual environment, skipping loading legacy plugins.", print_to="stderr")
return
plugin_dirs = [
'/usr/lib/osc-plugins',
'/usr/local/lib/osc-plugins',