From 5b661830df3cee2202d11bf7c108d43229c899a4 Mon Sep 17 00:00:00 2001 From: "Daniel A. Wozniak" Date: Mon, 2 Sep 2024 17:24:23 -0700 Subject: [PATCH 01/15] Update workflows to get wheels built --- .github/workflows/ci.yml | 97 ++++++++++++++++- .github/workflows/deploy-package-action.yml | 22 ++++ .github/workflows/package-action.yml | 110 ++++++++------------ .github/workflows/pre-commit-action.yml | 8 +- .github/workflows/release.yml | 32 ++++++ .github/workflows/test-action.yml | 39 +++++++ pyproject.toml | 2 +- src/relenv_gdb/build.py | 27 ++++- 8 files changed, 268 insertions(+), 69 deletions(-) create mode 100644 .github/workflows/deploy-package-action.yml create mode 100644 .github/workflows/release.yml create mode 100644 .github/workflows/test-action.yml diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 83f04ed..40ca50a 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -32,9 +32,37 @@ on: jobs: + get-changed-files: + name: Get Changed Files + runs-on: ubuntu-latest + permissions: + contents: read # for dorny/paths-filter to fetch a list of changed files + pull-requests: read # for dorny/paths-filter to read pull requests + outputs: + changed-files: ${{ toJSON(steps.changed-files.outputs) }} + steps: + - uses: actions/checkout@v3 + - name: Get Changed Files + id: changed-files + uses: dorny/paths-filter@v2 + with: + token: ${{ github.token }} + list-files: json + filters: | + repo: + - added|modified: + - '**' + deleted: + - deleted: + - '**' + pre-commit: name: Pre-Commit uses: ./.github/workflows/pre-commit-action.yml + needs: + - get-changed-files + with: + changed-files: ${{ needs.get-changed-files.outputs.changed-files }} build-python-package: name: Python Package @@ -44,5 +72,72 @@ jobs: - pre-commit with: kind: "${{ inputs.kind }}" - cmd: "${{ inputs.package_command }}" + cmd: python -m build + #cmd: "${{ inputs.package_command }}" + + test: + name: Test + needs: + - get-changed-files + uses: ./.github/workflows/test-action.yml + with: + changed-files: ${{ needs.get-changed-files.outputs.changed-files }} + + deploy-python-package: + name: Deploy Python Package + uses: ./.github/workflows/deploy-package-action.yml + if: ${{ inputs.kind == 'release' && success() }} + needs: + - pre-commit + - test + - build-python-package + secrets: + PYPI_API_TOKEN: "${{ secrets.PYPI_API_TOKEN }}" + + push-tag: + name: Push Version Tag + runs-on: ubuntu-latest + permissions: + contents: write + if: ${{ inputs.kind == 'release' && success() }} + needs: + - build-python-package + - deploy-python-package + steps: + - name: Checkout + uses: actions/checkout@v3 + - name: Push Tag + uses: rickstaa/action-create-tag@v1 + with: + tag: "v${{ needs.build-python-package.outputs.version }}" + message: "Version ${{ needs.build-python-package.outputs.version }}" + + set-pipeline-exit-status: + # This step is just so we can make github require this step, to pass checks + # on a pull request instead of requiring all + name: Set the CI Pipeline Exit Status + runs-on: ubuntu-latest + if: always() + needs: + - pre-commit + - test + - deploy-python-package + - push-tag + steps: + - name: Get workflow information + id: get-workflow-info + uses: technote-space/workflow-conclusion-action@v3 + + - name: Set Pipeline Exit Status + shell: bash + run: | + if [ "${{ steps.get-workflow-info.outputs.conclusion }}" != "success" ]; then + exit 1 + else + exit 0 + fi + - name: Done + if: always() + run: + echo "All workflows finished" diff --git a/.github/workflows/deploy-package-action.yml b/.github/workflows/deploy-package-action.yml new file mode 100644 index 0000000..27605e1 --- /dev/null +++ b/.github/workflows/deploy-package-action.yml @@ -0,0 +1,22 @@ +name: Relenv Python Package + +on: + workflow_call: + secrets: + PYPI_API_TOKEN: + required: true + +jobs: + build: + name: Publish Python Wheel + runs-on: ubuntu-latest + steps: + - name: Download Python Package Artifacts + uses: actions/download-artifact@v3 + with: + name: dist + path: dist + - name: Publish distribution to PyPI + uses: pypa/gh-action-pypi-publish@release/v1 + with: + password: ${{ secrets.PYPI_API_TOKEN }} diff --git a/.github/workflows/package-action.yml b/.github/workflows/package-action.yml index 729a025..ff217e1 100644 --- a/.github/workflows/package-action.yml +++ b/.github/workflows/package-action.yml @@ -25,80 +25,62 @@ on: jobs: build: name: Build Python Wheel - strategy: - matrix: - host: - - x86_64 - - aarch64 - runs-on: - - self-hosted - - linux - - src-build - - ${{ matrix.host }} + runs-on: ubuntu-latest + container: + image: debian:11 outputs: version: ${{ steps.version.outputs.version }} - steps: - - uses: actions/checkout@master + - uses: actions/checkout@master -# - name: Set up Python 3.10 -# uses: actions/setup-python@v4 -# with: -# python-version: "3.10" + - name: Update Apt + run: >- + apt-get update - - name: Install pypa/build - run: >- - python -m - pip install - build - --user + - name: Install OS Dependencies + run: >- + apt-get install -y gcc python3 + python3-pip python3-venv flex make + texinfo unzip help2man gawk libtool-bin libncurses5-dev + bison wget rsync git - - name: Install pypa/pkginffo - run: >- - python -m - pip install - pkginfo - --user + - name: Create virtualenv + run: >- + python3 -m venv venv - - name: Install relenv - run: >- - python -m - pip install - relenv - --user + - name: Activate virtualenv + run: | + . venv/bin/activate + echo PATH=$PATH >> $GITHUB_ENV - - name: Install relenv toolchain - run: >- - python -m - relenv - toolchain - fetch + - name: Python Version + run: >- + python3 --version - - name: Install relenv fetch - run: >- - python -m - relenv - fetch + - name: Install Python Dependencies + run: >- + pip install build wheel setuptools pkginfo - - name: Echo Build Wheel Command - run: echo "${{ inputs.cmd }}" + - name: Echo Build Wheel Command + run: echo "${{ inputs.cmd }}" - - name: Build Wheel - run: "${{ inputs.cmd }}" + - name: Build Wheel + run: | + ${{ inputs.cmd }} - - name: Wheel Artifact ${{matrix.host}} - uses: actions/upload-artifact@v3 - if: always() - with: - name: relenv-gdb-debug-${{ matrix.host }}-wheel - path: dist/*.whl - retention-days: 5 + - name: Python Build Artifact + uses: actions/upload-artifact@v3 + if: always() + with: + name: dist + path: dist/* + retention-days: 5 - - name: Read Version - run: >- - python3 - -c - "from pkginfo import Wheel; s = Wheel('dist/$(ls dist/)'); print(f'version={s.version}')" - >> - $GITHUB_OUTPUT - id: version + - name: Read Version + run: >- + python3 + -c + "from pkginfo import Wheel; s = Wheel('''$(ls dist/*.whl)'''); print('version='+str(s.version))" + >> + $GITHUB_OUTPUT + id: version diff --git a/.github/workflows/pre-commit-action.yml b/.github/workflows/pre-commit-action.yml index 86324c1..12d334b 100644 --- a/.github/workflows/pre-commit-action.yml +++ b/.github/workflows/pre-commit-action.yml @@ -4,7 +4,7 @@ on: workflow_call: inputs: changed-files: - required: false + required: true type: string description: JSON string containing information about changed files @@ -30,5 +30,11 @@ jobs: pre-commit install --install-hooks - name: Check ALL Files On Branch + if: github.event_name != 'pull_request' run: | pre-commit run --show-diff-on-failure --color=always --all-files + + - name: Check Changed Files On PR + if: github.event_name == 'pull_request' && fromJSON(inputs.changed-files)['repo'] == 'true' + run: | + pre-commit run --show-diff-on-failure --color=always --files ${{ join(fromJSON(inputs.changed-files)['repo_files'], ' ') }} diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml new file mode 100644 index 0000000..5c458a7 --- /dev/null +++ b/.github/workflows/release.yml @@ -0,0 +1,32 @@ +name: Build and Release + +on: + workflow_dispatch: + inputs: + kind: + required: false + type: string + default: dev + package_command: + required: false + type: string + description: Command used to build python package + default: >- + python -m + build + --wheel + --outdir dist/ + +jobs: + ci: + name: CI + permissions: + contents: write + pull-requests: read + uses: ./.github/workflows/ci.yml + if: contains('["dwoz", "twangboy", "dmurphy18"]', github.actor) + with: + kind: "${{ inputs.kind }}" + package_command: "${{ inputs.package_command }}" + secrets: + PYPI_API_TOKEN: ${{ secrets.PYPI_API_TOKEN }} diff --git a/.github/workflows/test-action.yml b/.github/workflows/test-action.yml new file mode 100644 index 0000000..e88027a --- /dev/null +++ b/.github/workflows/test-action.yml @@ -0,0 +1,39 @@ +name: Unit Tests + +on: + workflow_call: + inputs: + changed-files: + required: true + type: string + description: JSON string containing information about changed files + +jobs: + test: + strategy: + fail-fast: false + matrix: + runs-on: + - ubuntu-latest + - macos-12 + - macos-13-xlarge + - windows-latest + + name: Unit Test ${{ matrix.runs-on }} + runs-on: ${{ matrix.runs-on }} + + steps: + - uses: actions/checkout@v3 + + - name: Set up Python 3.10 + uses: actions/setup-python@v4 + with: + python-version: "3.10" + + - name: Install python dependencies + run: | + pip3 install pytest + + - name: Run tests + run: | + pytest -v diff --git a/pyproject.toml b/pyproject.toml index 132b443..eae03cd 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -2,7 +2,7 @@ requires = [ "setuptools", "wheel", - "relenv@git+https://github.com/saltstack/relative-environment-for-python@buildenv", + "relenv", ] build-backend = "build" backend-path = ["src/relenv_gdb"] diff --git a/src/relenv_gdb/build.py b/src/relenv_gdb/build.py index bee6c4b..1ec06c5 100644 --- a/src/relenv_gdb/build.py +++ b/src/relenv_gdb/build.py @@ -10,10 +10,14 @@ import shutil import subprocess import tempfile +import pprint import relenv.buildenv import relenv.common import relenv.create +import relenv.build +import relenv.fetch +import relenv.toolchain from setuptools.build_meta import * _build_wheel = build_wheel @@ -53,9 +57,8 @@ def build_gdb(prefix): os.environ[ "CPPFLAGS" ] = f"{os.environ['CPPFLAGS']} -I{os.environ['RELENV_PATH']}/include/ncursesw" - import pprint - pprint.pprint(dict(os.environ)) + print(f"Build environment: {pprint.pformat(dict(os.environ))}") with pushd(src / dir_name): subprocess.run( @@ -116,8 +119,24 @@ def build_wheel(wheel_directory, metadata_directory=None, config_settings=None): # relenv.common.get_triplet(relenv.common.build_arch()), # ) static_build_dir = os.environ.get("PY_STATIC_BUILD_DIR", "") + + #XXX should be in relenv + dirs = relenv.common.work_dirs() + if not dirs.toolchain.exists(): + os.makedirs(dirs.toolchain) + if not dirs.build.exists(): + os.makedirs(dirs.build) + + arch = relenv.common.build_arch() + triplet = relenv.common.get_triplet(machine=arch) + python = relenv.build.platform_versions()[0] + if static_build_dir: relenvdir = (pathlib.Path(static_build_dir) / "gdb").resolve() + relenv.toolchain.fetch( + arch, dirs.toolchain + ) + relenv.fetch.fetch(relenv.common.__version__, triplet, python) relenv.create.create(str(relenvdir)) build_gdb(relenvdir) try: @@ -127,6 +146,10 @@ def build_wheel(wheel_directory, metadata_directory=None, config_settings=None): else: with tempfile.TemporaryDirectory() as tmp_dist_dir: relenvdir = pathlib.Path(tmp_dist_dir) / "gdb" + relenv.toolchain.fetch( + arch, dirs.toolchain + ) + relenv.fetch.fetch(relenv.common.__version__, triplet, python) relenv.create.create(str(relenvdir)) build_gdb(relenvdir) try: From 02adf2973bb383a56fe0c3ecd273991c65c2438d Mon Sep 17 00:00:00 2001 From: "Daniel A. Wozniak" Date: Mon, 2 Sep 2024 17:25:51 -0700 Subject: [PATCH 02/15] Simplifiy os depenencies --- .github/workflows/package-action.yml | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/.github/workflows/package-action.yml b/.github/workflows/package-action.yml index ff217e1..0cd445b 100644 --- a/.github/workflows/package-action.yml +++ b/.github/workflows/package-action.yml @@ -39,11 +39,8 @@ jobs: - name: Install OS Dependencies run: >- - apt-get install -y gcc python3 - python3-pip python3-venv flex make - texinfo unzip help2man gawk libtool-bin libncurses5-dev - bison wget rsync git - + apt-get install -y python3 + python3-pip python3-venv build-essentials - name: Create virtualenv run: >- python3 -m venv venv From 76da07310f2234eeea11584c319fa157cd57bc8e Mon Sep 17 00:00:00 2001 From: "Daniel A. Wozniak" Date: Mon, 2 Sep 2024 17:30:55 -0700 Subject: [PATCH 03/15] Fix python version and platform name --- setup.py | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/setup.py b/setup.py index 376eb70..3cea5f9 100644 --- a/setup.py +++ b/setup.py @@ -1,14 +1,22 @@ # Copyright 2023 VMware, Inc. # SPDX-License-Identifier: Apache-2.0 # +import platform + from setuptools import Distribution, setup -class BinaryDistribution(Distribution): - def has_ext_modules(self): - return True +GLIBC_VERSION = "2.17" + +def plat_name(): + return f"manylinux_{GLIBC_VERSION.replace('.', '_')}_{platform.machine()}" setup( - distclass=BinaryDistribution, + options={ + "bdist_wheel": { + "plat_name": f"{plat_name()}", + "python_tag": "py3", + } + } ) From d244ab532298291419795c55a6bf8e2990fda18f Mon Sep 17 00:00:00 2001 From: "Daniel A. Wozniak" Date: Mon, 2 Sep 2024 17:33:41 -0700 Subject: [PATCH 04/15] Add noop test so pipelines finish --- pyproject.toml | 5 +++++ tests/test_relenv_gdb.py | 4 ++++ 2 files changed, 9 insertions(+) create mode 100644 tests/test_relenv_gdb.py diff --git a/pyproject.toml b/pyproject.toml index eae03cd..fb4a8be 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -12,3 +12,8 @@ skip = "src/relenv_gdb/libpython.py" [tool.black] force_exclude = "libpython.py" + +[tool.pytest.ini_options] +pythonpath = [ + "src" +] diff --git a/tests/test_relenv_gdb.py b/tests/test_relenv_gdb.py new file mode 100644 index 0000000..6b53161 --- /dev/null +++ b/tests/test_relenv_gdb.py @@ -0,0 +1,4 @@ + + +def test_noop(): + return From 6219cb21ffe002d122cfb6ec62cd90c55fa4efd0 Mon Sep 17 00:00:00 2001 From: "Daniel A. Wozniak" Date: Mon, 2 Sep 2024 17:38:48 -0700 Subject: [PATCH 05/15] Fix typo in package name --- .github/workflows/package-action.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/package-action.yml b/.github/workflows/package-action.yml index 0cd445b..cfb7d80 100644 --- a/.github/workflows/package-action.yml +++ b/.github/workflows/package-action.yml @@ -40,7 +40,7 @@ jobs: - name: Install OS Dependencies run: >- apt-get install -y python3 - python3-pip python3-venv build-essentials + python3-pip python3-venv build-essential - name: Create virtualenv run: >- python3 -m venv venv From 54442f44fd04914e016452f2193823df312e7e24 Mon Sep 17 00:00:00 2001 From: "Daniel A. Wozniak" Date: Mon, 2 Sep 2024 19:20:44 -0700 Subject: [PATCH 06/15] More reliable inject --- src/relenv_gdb/inject.py | 33 +++++++++++++-------------------- 1 file changed, 13 insertions(+), 20 deletions(-) diff --git a/src/relenv_gdb/inject.py b/src/relenv_gdb/inject.py index 8710f82..3cf7214 100644 --- a/src/relenv_gdb/inject.py +++ b/src/relenv_gdb/inject.py @@ -26,24 +26,17 @@ INJ_TPL = """ set pagination off source {libpython} -source {s_path} echo acquire gill\\n call (char *) PyGILState_Ensure() -p $SCRIPT -call (void) PyRun_SimpleString($SCRIPT) +call (PyObject *) Py_BuildValue("s", "{inject_path}") +call (FILE *) _Py_fopen_obj($2, "r+") +call (void) PyRun_SimpleFile($3, "{inject_path}") echo release gill\\n call (void) PyGILState_Release($1) quit """ -SCRIPT = """#!/usr/bin/python -import gdb -with open("{}", "r") as fp: - gdb.set_convenience_variable("SCRIPT", fp.read()) -""" - - def main(): """ The inject program entrypoint. @@ -63,30 +56,30 @@ def main(): except IndexError: print("Please provide an input file as the second argument") - s_fd, s_path = tempfile.mkstemp(suffix=".py") - with open(s_path, "w") as fp: - fp.write(SCRIPT.format(file)) - - fd, path = tempfile.mkstemp() + s_fd, inject_path = tempfile.mkstemp(suffix=".py") + with open(file, "r") as fp: + with open(inject_path, "w") as fp2: + fp2.write(fp.read()) + fd, gdb_command = tempfile.mkstemp() try: - with open(path, "w") as fp: + with open(gdb_command, "w") as fp: fp.write( INJ_TPL.format( - s_path=s_path, + inject_path=inject_path, libpython=( pathlib.Path(__file__).parent / "libpython.py" ).resolve(), ) ) subprocess.run( - [str(find_relenv_gdb()), "-p", f"{pid}", "--command", path], + [str(find_relenv_gdb()), "-p", f"{pid}", "--command", gdb_command], capture_output=False, ) finally: os.close(fd) - os.remove(path) + os.remove(gdb_command) os.close(s_fd) - os.remove(s_path) + os.remove(inject_path) if __name__ == "__main__": From a0afd065043a5fa777a5a21592de0096acc0e2ec Mon Sep 17 00:00:00 2001 From: "Daniel A. Wozniak" Date: Mon, 2 Sep 2024 19:24:34 -0700 Subject: [PATCH 07/15] Use self hosted runners --- .github/workflows/package-action.yml | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/.github/workflows/package-action.yml b/.github/workflows/package-action.yml index cfb7d80..b2ad9bb 100644 --- a/.github/workflows/package-action.yml +++ b/.github/workflows/package-action.yml @@ -25,7 +25,18 @@ on: jobs: build: name: Build Python Wheel - runs-on: ubuntu-latest + strategy: + matrix: + host: + - x86_64 + - aarch64 + + runs-on: + - self-hosted + - linux + - src-build + - ${{ matrix.host }} + container: image: debian:11 outputs: From e54755da05cf1c051f266bdbc8da62c49c08cd5d Mon Sep 17 00:00:00 2001 From: "Daniel A. Wozniak" Date: Mon, 2 Sep 2024 20:32:25 -0700 Subject: [PATCH 08/15] Install patchelf --- .github/workflows/package-action.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/package-action.yml b/.github/workflows/package-action.yml index b2ad9bb..71afeef 100644 --- a/.github/workflows/package-action.yml +++ b/.github/workflows/package-action.yml @@ -51,7 +51,7 @@ jobs: - name: Install OS Dependencies run: >- apt-get install -y python3 - python3-pip python3-venv build-essential + python3-pip python3-venv patchelf build-essential - name: Create virtualenv run: >- python3 -m venv venv @@ -80,7 +80,7 @@ jobs: uses: actions/upload-artifact@v3 if: always() with: - name: dist + name: dist-${{ matrix.host }} path: dist/* retention-days: 5 From 5ebb840ae43631669212511f8f11ae1d9cc9e875 Mon Sep 17 00:00:00 2001 From: "Daniel A. Wozniak" Date: Mon, 2 Sep 2024 20:51:24 -0700 Subject: [PATCH 09/15] Add m4 to dependencies --- .github/workflows/package-action.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/package-action.yml b/.github/workflows/package-action.yml index 71afeef..fd3f1bb 100644 --- a/.github/workflows/package-action.yml +++ b/.github/workflows/package-action.yml @@ -51,7 +51,8 @@ jobs: - name: Install OS Dependencies run: >- apt-get install -y python3 - python3-pip python3-venv patchelf build-essential + python3-pip python3-venv patchelf build-essential m4 + - name: Create virtualenv run: >- python3 -m venv venv From 692aad8d8b92cfa3cb211b8c11da7fb83731db6d Mon Sep 17 00:00:00 2001 From: "Daniel A. Wozniak" Date: Mon, 2 Sep 2024 21:32:55 -0700 Subject: [PATCH 10/15] point to correct python --- dockerbuild.sh | 25 +++++++++++++++++++++++++ src/relenv_gdb/build.py | 5 +++-- 2 files changed, 28 insertions(+), 2 deletions(-) create mode 100755 dockerbuild.sh diff --git a/dockerbuild.sh b/dockerbuild.sh new file mode 100755 index 0000000..3264487 --- /dev/null +++ b/dockerbuild.sh @@ -0,0 +1,25 @@ +#!/bin/sh +# +# Build a ppt wheel in a docker container. +# +if [ -n "$UID" ] +then + CHOWN="" +else + CHOWN="" #chown -R $UID dist build src/ppbt/_toolchain" +fi + +export CHOWN + +CMD=" +apt-get update; +apt-get install -y gcc python3 \ + python3-pip python3-venv build-essential patchelf +cd /src +python3 -m venv venv +venv/bin/pip install build wheel setuptools +venv/bin/python3 -m build +$CHOWN +" + +docker run --rm -v $(pwd):/src debian:11 /bin/sh -c "$CMD" diff --git a/src/relenv_gdb/build.py b/src/relenv_gdb/build.py index 1ec06c5..f2cf6c0 100644 --- a/src/relenv_gdb/build.py +++ b/src/relenv_gdb/build.py @@ -51,6 +51,7 @@ def build_gdb(prefix): relenv.common.extract_archive(str(src), archive_name) dir_name = archive_name.split(".tar")[0] os.environ.update(relenv.buildenv.buildenv(prefix)) + os.environ["RELENV_PATH"] = str(prefix) os.environ[ "CFLAGS" ] = f"{os.environ['CFLAGS']} -I{os.environ['RELENV_PATH']}/include/ncursesw" @@ -67,8 +68,8 @@ def build_gdb(prefix): f"--prefix={os.environ['RELENV_PATH']}/lib/python3.10/site-packages/relenv_gdb/gdb", ] ) - subprocess.run(["make"]) - subprocess.run(["make", "install"]) + subprocess.run(["make"], check=True) + subprocess.run(["make", "install"], check=True) url = "https://ftp.gnu.org/gnu/gdb/gdb-13.2.tar.xz" relenv.common.download_url( From 4a5bd1d8beb672d4aabdd311251f4f27e18502b9 Mon Sep 17 00:00:00 2001 From: "Daniel A. Wozniak" Date: Mon, 2 Sep 2024 22:01:55 -0700 Subject: [PATCH 11/15] Check build commands --- src/relenv_gdb/build.py | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/src/relenv_gdb/build.py b/src/relenv_gdb/build.py index f2cf6c0..7c32422 100644 --- a/src/relenv_gdb/build.py +++ b/src/relenv_gdb/build.py @@ -67,6 +67,7 @@ def build_gdb(prefix): "./configure", f"--prefix={os.environ['RELENV_PATH']}/lib/python3.10/site-packages/relenv_gdb/gdb", ] + check=True ) subprocess.run(["make"], check=True) subprocess.run(["make", "install"], check=True) @@ -88,8 +89,9 @@ def build_gdb(prefix): "--with-lzma", "--with-separate-debug-dir=/usr/lib/debug", ] + check=True ) - subprocess.run(["make"]) + subprocess.run(["make"], check=True) bins = ["gdb/gdb", "gdbserver/gdbserver", "gdbserver/libinproctrace.so"] for _ in bins: subprocess.run( @@ -98,7 +100,8 @@ def build_gdb(prefix): "--add-rpath", f"{os.environ['TOOLCHAIN_PATH']}/{os.environ['TRIPLET']}/sysroot/lib", _, - ] + ], + check=True ) subprocess.run(["make", "install"]) @@ -115,10 +118,8 @@ def build_gdb(prefix): def build_wheel(wheel_directory, metadata_directory=None, config_settings=None): """PEP 517 wheel creation hook.""" - # relenv.fetch.fetch( - # relenv.common.__version__, - # relenv.common.get_triplet(relenv.common.build_arch()), - # ) + import logging + logging.basicConfig(level=logging.DEBUG) static_build_dir = os.environ.get("PY_STATIC_BUILD_DIR", "") #XXX should be in relenv From 6119d6947c1bca46fc4a8ea311d70f7326f48633 Mon Sep 17 00:00:00 2001 From: "Daniel A. Wozniak" Date: Mon, 2 Sep 2024 22:03:46 -0700 Subject: [PATCH 12/15] Update to current gdb and python --- .github/workflows/package-action.yml | 2 +- .pre-commit-hooks/copyright_headers.py | 2 +- dockerbuild.sh | 2 +- src/relenv_gdb/build.py | 115 ++++++++++++++----------- 4 files changed, 67 insertions(+), 54 deletions(-) diff --git a/.github/workflows/package-action.yml b/.github/workflows/package-action.yml index fd3f1bb..da1d3ce 100644 --- a/.github/workflows/package-action.yml +++ b/.github/workflows/package-action.yml @@ -51,7 +51,7 @@ jobs: - name: Install OS Dependencies run: >- apt-get install -y python3 - python3-pip python3-venv patchelf build-essential m4 + python3-pip python3-venv patchelf build-essential m4 texinfo - name: Create virtualenv run: >- diff --git a/.pre-commit-hooks/copyright_headers.py b/.pre-commit-hooks/copyright_headers.py index eb0fedb..aa65dee 100644 --- a/.pre-commit-hooks/copyright_headers.py +++ b/.pre-commit-hooks/copyright_headers.py @@ -1,5 +1,5 @@ #!/usr/bin/env python3 -# Copyright 2021-2023 VMware, Inc. +# Copyright 2021-2024 VMware, Inc. # SPDX-License-Identifier: Apache-2.0 # # pylint: disable=invalid-name,missing-module-docstring,missing-function-docstring diff --git a/dockerbuild.sh b/dockerbuild.sh index 3264487..6369d4d 100755 --- a/dockerbuild.sh +++ b/dockerbuild.sh @@ -14,7 +14,7 @@ export CHOWN CMD=" apt-get update; apt-get install -y gcc python3 \ - python3-pip python3-venv build-essential patchelf + python3-pip python3-venv build-essential patchelf m4 texinfo cd /src python3 -m venv venv venv/bin/pip install build wheel setuptools diff --git a/src/relenv_gdb/build.py b/src/relenv_gdb/build.py index 7c32422..d334842 100644 --- a/src/relenv_gdb/build.py +++ b/src/relenv_gdb/build.py @@ -1,21 +1,22 @@ -# Copyright 2023 VMware, Inc. +# Copyright 2023-2024 VMware, Inc. # SPDX-License-Identifier: Apache-2.0 # """ Build our python wheel. """ import contextlib +import logging import os import pathlib +import pprint import shutil import subprocess -import tempfile -import pprint +import sys +import relenv.build import relenv.buildenv import relenv.common import relenv.create -import relenv.build import relenv.fetch import relenv.toolchain from setuptools.build_meta import * @@ -39,40 +40,69 @@ def pushd(path): def build_gdb(prefix): """Compile and install gdb to the prefix.""" src = prefix / "src" - src.mkdir() + src.mkdir(exist_ok=True) + + os.environ.update(relenv.buildenv.buildenv(prefix)) + os.environ["CFLAGS"] = ( + f"{os.environ['CFLAGS']} -I{os.environ['RELENV_PATH']}/include/ncursesw " + f"-I{os.environ['RELENV_PATH']}/include/readline " + f"-I{os.environ['RELENV_PATH']}/lib/python3.10/site-packages/relenv_gdb/gdb/include" + ) + os.environ["CPPFLAGS"] = ( + f"{os.environ['CPPFLAGS']} -I{os.environ['RELENV_PATH']}/include/ncursesw " + f"-I{os.environ['RELENV_PATH']}/include/readline " + f"-I{os.environ['RELENV_PATH']}/lib/python3.10/site-packages/relenv_gdb/gdb/include" + ) + os.environ["LDFLAGS"] = ( + f"{os.environ['LDFLAGS']} " + f"-L{os.environ['RELENV_PATH']}/lib/python3.10/site-packages/relenv_gdb/gdb/lib " + ) + + print(f"Build environment: {pprint.pformat(dict(os.environ))}") + sys.stdout.flush() url = "https://gmplib.org/download/gmp/gmp-6.3.0.tar.xz" relenv.common.download_url( url, src, ) - archive_name = str(src / pathlib.Path(url).name) relenv.common.extract_archive(str(src), archive_name) dir_name = archive_name.split(".tar")[0] - os.environ.update(relenv.buildenv.buildenv(prefix)) - os.environ["RELENV_PATH"] = str(prefix) - os.environ[ - "CFLAGS" - ] = f"{os.environ['CFLAGS']} -I{os.environ['RELENV_PATH']}/include/ncursesw" - os.environ[ - "CPPFLAGS" - ] = f"{os.environ['CPPFLAGS']} -I{os.environ['RELENV_PATH']}/include/ncursesw" - print(f"Build environment: {pprint.pformat(dict(os.environ))}") + with pushd(src / dir_name): + subprocess.run( + [ + "./configure", + f"--prefix={os.environ['RELENV_PATH']}/lib/python3.10/site-packages/relenv_gdb/gdb", + ], + check=True, + ) + subprocess.run(["make"], check=True) + subprocess.run(["make", "install"], check=True) + + url = "https://www.mpfr.org/mpfr-current/mpfr-4.2.1.tar.xz" + relenv.common.download_url( + url, + src, + ) + archive_name = str(src / pathlib.Path(url).name) + relenv.common.extract_archive(str(src), archive_name) + dir_name = archive_name.split(".tar")[0] with pushd(src / dir_name): subprocess.run( [ "./configure", f"--prefix={os.environ['RELENV_PATH']}/lib/python3.10/site-packages/relenv_gdb/gdb", - ] - check=True + ], + check=True, ) subprocess.run(["make"], check=True) subprocess.run(["make", "install"], check=True) - url = "https://ftp.gnu.org/gnu/gdb/gdb-13.2.tar.xz" + os.environ["LDFLAGS"] = f"{os.environ['LDFLAGS']} -lreadline" + url = "https://ftp.gnu.org/gnu/gdb/gdb-15.1.tar.xz" relenv.common.download_url( url, src, @@ -88,8 +118,8 @@ def build_gdb(prefix): f"--with-python={os.environ['RELENV_PATH']}/bin/python3", "--with-lzma", "--with-separate-debug-dir=/usr/lib/debug", - ] - check=True + ], + check=True, ) subprocess.run(["make"], check=True) bins = ["gdb/gdb", "gdbserver/gdbserver", "gdbserver/libinproctrace.so"] @@ -101,7 +131,7 @@ def build_gdb(prefix): f"{os.environ['TOOLCHAIN_PATH']}/{os.environ['TRIPLET']}/sysroot/lib", _, ], - check=True + # check=True, ) subprocess.run(["make", "install"]) @@ -118,11 +148,8 @@ def build_gdb(prefix): def build_wheel(wheel_directory, metadata_directory=None, config_settings=None): """PEP 517 wheel creation hook.""" - import logging logging.basicConfig(level=logging.DEBUG) - static_build_dir = os.environ.get("PY_STATIC_BUILD_DIR", "") - #XXX should be in relenv dirs = relenv.common.work_dirs() if not dirs.toolchain.exists(): os.makedirs(dirs.toolchain) @@ -131,32 +158,18 @@ def build_wheel(wheel_directory, metadata_directory=None, config_settings=None): arch = relenv.common.build_arch() triplet = relenv.common.get_triplet(machine=arch) + python = relenv.build.platform_versions()[0] + version = relenv.common.__version__ - if static_build_dir: - relenvdir = (pathlib.Path(static_build_dir) / "gdb").resolve() - relenv.toolchain.fetch( - arch, dirs.toolchain - ) - relenv.fetch.fetch(relenv.common.__version__, triplet, python) - relenv.create.create(str(relenvdir)) - build_gdb(relenvdir) - try: - return _build_wheel(wheel_directory, metadata_directory, config_settings) - finally: - shutil.rmtree("src/relenv_gdb/gdb") - else: - with tempfile.TemporaryDirectory() as tmp_dist_dir: - relenvdir = pathlib.Path(tmp_dist_dir) / "gdb" - relenv.toolchain.fetch( - arch, dirs.toolchain - ) - relenv.fetch.fetch(relenv.common.__version__, triplet, python) - relenv.create.create(str(relenvdir)) - build_gdb(relenvdir) - try: - return _build_wheel( - wheel_directory, metadata_directory, config_settings - ) - finally: - shutil.rmtree("src/relenv_gdb/gdb") + root = pathlib.Path(os.environ.get("PWD", os.getcwd())) + build = root / "build" + + relenvdir = (build / "gdb").resolve() + + relenv.toolchain.fetch(arch, dirs.toolchain) + relenv.fetch.fetch(version, triplet, python) + if not relenvdir.exists(): + relenv.create.create(str(relenvdir), version=python) + build_gdb(relenvdir) + return _build_wheel(wheel_directory, metadata_directory, config_settings) From f2d13ef1e6fc5d918b06ceaba46978b61dd6506d Mon Sep 17 00:00:00 2001 From: "Daniel A. Wozniak" Date: Wed, 4 Sep 2024 01:30:56 -0700 Subject: [PATCH 13/15] Enforce check=True on patchelf --- dockerbuild.sh => scripts/dockerbuild.sh | 5 +++++ src/relenv_gdb/build.py | 4 +++- 2 files changed, 8 insertions(+), 1 deletion(-) rename dockerbuild.sh => scripts/dockerbuild.sh (72%) diff --git a/dockerbuild.sh b/scripts/dockerbuild.sh similarity index 72% rename from dockerbuild.sh rename to scripts/dockerbuild.sh index 6369d4d..4159216 100755 --- a/dockerbuild.sh +++ b/scripts/dockerbuild.sh @@ -2,6 +2,11 @@ # # Build a ppt wheel in a docker container. # +# This script is meant to build a wheel in the same docker container images as +# we do in CI/CD. Run it from the root of the github repository. +# +# `scripts/dockerbuild.sh1 +# if [ -n "$UID" ] then CHOWN="" diff --git a/src/relenv_gdb/build.py b/src/relenv_gdb/build.py index d334842..7b3f6e0 100644 --- a/src/relenv_gdb/build.py +++ b/src/relenv_gdb/build.py @@ -124,6 +124,8 @@ def build_gdb(prefix): subprocess.run(["make"], check=True) bins = ["gdb/gdb", "gdbserver/gdbserver", "gdbserver/libinproctrace.so"] for _ in bins: + if not pathlib.Path(_).resolve().exists(): + print(f"File not found {_}") subprocess.run( [ "patchelf", @@ -131,7 +133,7 @@ def build_gdb(prefix): f"{os.environ['TOOLCHAIN_PATH']}/{os.environ['TRIPLET']}/sysroot/lib", _, ], - # check=True, + check=True, ) subprocess.run(["make", "install"]) From 6a47a86564a84b0b28eef7e3f0091e6032e96b33 Mon Sep 17 00:00:00 2001 From: "Daniel A. Wozniak" Date: Wed, 4 Sep 2024 01:57:46 -0700 Subject: [PATCH 14/15] Combine path with --add-rpath option --- src/relenv_gdb/build.py | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/relenv_gdb/build.py b/src/relenv_gdb/build.py index 7b3f6e0..2525f7f 100644 --- a/src/relenv_gdb/build.py +++ b/src/relenv_gdb/build.py @@ -129,8 +129,7 @@ def build_gdb(prefix): subprocess.run( [ "patchelf", - "--add-rpath", - f"{os.environ['TOOLCHAIN_PATH']}/{os.environ['TRIPLET']}/sysroot/lib", + f"--add-rpath={os.environ['TOOLCHAIN_PATH']}/{os.environ['TRIPLET']}/sysroot/lib", _, ], check=True, From ed72f73739d48b496808a6e0e7a1f99d5735b1a3 Mon Sep 17 00:00:00 2001 From: "Daniel A. Wozniak" Date: Wed, 4 Sep 2024 02:45:19 -0700 Subject: [PATCH 15/15] patchelf on debian 11 is too old --- src/relenv_gdb/build.py | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) diff --git a/src/relenv_gdb/build.py b/src/relenv_gdb/build.py index 2525f7f..bd1edb4 100644 --- a/src/relenv_gdb/build.py +++ b/src/relenv_gdb/build.py @@ -101,6 +101,18 @@ def build_gdb(prefix): subprocess.run(["make"], check=True) subprocess.run(["make", "install"], check=True) + # Newer patchelf for now + arch = relenv.common.build_arch() + url = f"https://github.com/NixOS/patchelf/releases/download/0.18.0/patchelf-0.18.0-{arch}.tar.gz" + relenv.common.download_url( + url, + src, + ) + archive_name = str(src / pathlib.Path(url).name) + relenv.common.extract_archive(str(src), archive_name) + dir_name = archive_name.split(".tar")[0] + patchelf = (src / "bin" / "patchelf").resolve() + os.environ["LDFLAGS"] = f"{os.environ['LDFLAGS']} -lreadline" url = "https://ftp.gnu.org/gnu/gdb/gdb-15.1.tar.xz" relenv.common.download_url( @@ -128,8 +140,9 @@ def build_gdb(prefix): print(f"File not found {_}") subprocess.run( [ - "patchelf", - f"--add-rpath={os.environ['TOOLCHAIN_PATH']}/{os.environ['TRIPLET']}/sysroot/lib", + str(patchelf), + "--add-rpath", + f"{os.environ['TOOLCHAIN_PATH']}/{os.environ['TRIPLET']}/sysroot/lib", _, ], check=True,