From 00e58a8707e399e684a248048908fab10869c97a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alexis=20M=C3=A9taireau?= Date: Mon, 6 Jan 2025 13:02:52 +0100 Subject: [PATCH 1/2] build: add poetry-plugin-export to the dependencies Since Poetry 2.0.0, the `export` command has been removed and it's advised to use the "poetry-plugin-export" package instead. This commit adds this dependency to the different places it's needed (debian environments, CI, build instructions, etc). --- .github/workflows/scan.yml | 5 ++++- BUILD.md | 6 ++++-- RELEASE.md | 4 ++-- dev_scripts/env.py | 1 + dev_scripts/qa.py | 6 ++++-- 5 files changed, 15 insertions(+), 7 deletions(-) diff --git a/.github/workflows/scan.yml b/.github/workflows/scan.yml index caea49f5b..c4bd6a35c 100644 --- a/.github/workflows/scan.yml +++ b/.github/workflows/scan.yml @@ -17,7 +17,10 @@ jobs: with: fetch-depth: 0 - name: Install container build dependencies - run: sudo apt install pipx && pipx install poetry + run: | + sudo apt install pipx + pipx install poetry + pipx inject poetry poetry-plugin-export - name: Build container image run: python3 ./install/common/build-image.py --runtime docker --no-save - name: Get image tag diff --git a/BUILD.md b/BUILD.md index b4f1c7f12..167d969c1 100644 --- a/BUILD.md +++ b/BUILD.md @@ -70,6 +70,7 @@ methods](https://python-poetry.org/docs/#installation))_ ```sh pipx ensurepath pipx install poetry +pipx inject poetry poetry-plugin-export ``` After this, restart the terminal window, for the `poetry` command to be in your @@ -157,6 +158,7 @@ Install Poetry using `pipx`: ```sh pipx install poetry +pipx inject poetry poetry-plugin-export ``` Clone this repository: @@ -369,7 +371,7 @@ cd dangerzone Install Python dependencies: ```sh -python3 -m pip install poetry +python3 -m pip install poetry poetry-plugin-export poetry install ``` @@ -430,7 +432,7 @@ Install Microsoft Visual C++ 14.0 or greater. Get it with ["Microsoft C++ Build Install [poetry](https://python-poetry.org/). Open PowerShell, and run: ``` -python -m pip install poetry +python -m pip install poetry poetry-plugin-export ``` Install git from [here](https://git-scm.com/download/win), open a Windows terminal (`cmd.exe`) and clone this repository: diff --git a/RELEASE.md b/RELEASE.md index 38f7e5af8..6e58338ca 100644 --- a/RELEASE.md +++ b/RELEASE.md @@ -113,7 +113,7 @@ Here is what you need to do: # In case of a new Python installation or minor version upgrade, e.g., from # 3.11 to 3.12, reinstall Poetry - python3 -m pip install poetry + python3 -m pip install poetry poetry-plugin-export # You can verify the correct Python version is used poetry debug info @@ -195,7 +195,7 @@ The Windows release is performed in a Windows 11 virtual machine (as opposed to ```bash # In case of a new Python installation or minor version upgrade, e.g., from # 3.11 to 3.12, reinstall Poetry - python3 -m pip install poetry + python3 -m pip install poetry poetry-plugin-export # You can verify the correct Python version is used poetry debug info diff --git a/dev_scripts/env.py b/dev_scripts/env.py index b395f61ac..dcbb79a12 100755 --- a/dev_scripts/env.py +++ b/dev_scripts/env.py @@ -183,6 +183,7 @@ # FIXME: pipx install poetry does not work for Ubuntu Focal. ENV PATH="$PATH:/home/user/.local/bin" RUN pipx install poetry +RUN pipx inject poetry poetry-plugin-export COPY pyproject.toml poetry.lock /home/user/dangerzone/ RUN cd /home/user/dangerzone && poetry --no-ansi install diff --git a/dev_scripts/qa.py b/dev_scripts/qa.py index dfc352b30..ef2b321c8 100755 --- a/dev_scripts/qa.py +++ b/dev_scripts/qa.py @@ -287,6 +287,7 @@ ```sh pipx ensurepath pipx install poetry +pipx inject poetry poetry-plugin-export ``` After this, restart the terminal window, for the `poetry` command to be in your @@ -375,6 +376,7 @@ ```sh pipx install poetry +pipx inject poetry poetry-plugin-export ``` Clone this repository: @@ -440,7 +442,7 @@ Install [poetry](https://python-poetry.org/). Open PowerShell, and run: ``` -python -m pip install poetry +python -m pip install poetry poetry-plugin-export ``` Install git from [here](https://git-scm.com/download/win), open a Windows terminal (`cmd.exe`) and clone this repository: @@ -878,7 +880,7 @@ def install_docker(self): "Install Poetry and the project's dependencies", ref=REF_BUILD, auto=True ) def install_poetry(self): - self.run("python", "-m", "pip", "install", "poetry") + self.run("python", "-m", "pip", "install", "poetry", "poetry-plugin-export") self.run("poetry", "install", "--sync") @QABase.task("Build Dangerzone container image", ref=REF_BUILD, auto=True) From 1298e9c3981d160d63a5992ba97521c644b1cbd5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alexis=20M=C3=A9taireau?= Date: Mon, 6 Jan 2025 14:20:06 +0100 Subject: [PATCH 2/2] build: add `build_scripts/env.py` to the hashed files It contains information that define the build environments, and as such, modifying it should result in a new release of the dev containers. --- dev_scripts/env.py | 1 + 1 file changed, 1 insertion(+) diff --git a/dev_scripts/env.py b/dev_scripts/env.py index dcbb79a12..ff4e48906 100755 --- a/dev_scripts/env.py +++ b/dev_scripts/env.py @@ -292,6 +292,7 @@ def get_build_dir_sources(distro, version): sources = [ git_root() / "pyproject.toml", git_root() / "poetry.lock", + git_root() / "dev_scripts" / "env.py", git_root() / "dev_scripts" / "storage.conf", git_root() / "dev_scripts" / "containers.conf", ]