From 86bd8de81501cd4b538ad8513e9742fd423d3208 Mon Sep 17 00:00:00 2001 From: fosslinux Date: Tue, 17 Dec 2024 18:50:53 +1100 Subject: [PATCH] Modernise the Github Actions workflow & test Python - It now also tests the --early-preseed and --repo options implicitly. - Upgraded all actions to v4. - Test Python bootstrap separately. --- .github/workflows/bwrap.yml | 126 +++++++++++++++++++++++------------- rootfs.py | 9 +-- steps/manifest | 2 +- 3 files changed, 86 insertions(+), 51 deletions(-) diff --git a/.github/workflows/bwrap.yml b/.github/workflows/bwrap.yml index 66cea846..414dc0cf 100644 --- a/.github/workflows/bwrap.yml +++ b/.github/workflows/bwrap.yml @@ -13,13 +13,13 @@ on: jobs: pass1: - name: Run up to Linux build under bubblewrap + name: Run up to bash under bubblewrap runs-on: ubuntu-latest steps: - name: Install bubblewrap run: sudo apt install bubblewrap - name: Checkout repo - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: submodules: recursive # There is a strange bug(?) in nongnu, when you clone a git repository @@ -27,7 +27,7 @@ jobs: fetch-depth: 0 - name: Query cache for sources id: cache - uses: actions/cache/restore@v3 + uses: actions/cache/restore@v4 with: path: | distfiles @@ -37,50 +37,42 @@ jobs: run: ./download-distfiles.sh - name: Cache sources if: steps.cache.outputs.cache-hit != 'true' - uses: actions/cache/save@v3 + uses: actions/cache/save@v4 with: path: | distfiles key: cache-${{ hashFiles('steps/*/sources') }} - name: Run bootstrap run: ./rootfs.py --bwrap --external-sources --build-kernels --cores 2 --internal-ci pass1 - - name: Archive created packages - if: failure() # archive failed builds progress - uses: actions/upload-artifact@v3 - with: - name: packages - path: target/external/repo/** - - name: Tar pass1 image - run: tar -cf pass1_image.tar target - - name: Archive pass1_image - uses: actions/upload-artifact@v3 + - name: Create early-preseed.tar + run: rm -rf target/external target/steps && tar -C target/ -cf early-preseed.tar . + - name: Archive early-preseed + uses: actions/upload-artifact@v4 with: - name: internal_pass1_image - path: pass1_image.tar + name: early-preseed + path: early-preseed.tar pass2: - name: Run up to Python bootstrap under bubblewrap + name: Run up to just before GCC 10 under bubblewrap needs: pass1 runs-on: ubuntu-latest steps: - name: Install bubblewrap run: sudo apt install bubblewrap - name: Checkout repo - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: submodules: recursive # There is a strange bug(?) in nongnu, when you clone a git repository # against a commit != HEAD with depth=1, it errors out. fetch-depth: 0 - - name: Get pass1_image - uses: actions/download-artifact@v3 + - name: Get early_preseed + uses: actions/download-artifact@v4 with: - name: internal_pass1_image - - name: Extract pass1_image - run: tar -xf pass1_image.tar + name: early-preseed - name: Query cache for sources id: cache - uses: actions/cache/restore@v3 + uses: actions/cache/restore@v4 with: path: | distfiles @@ -90,26 +82,18 @@ jobs: run: ./download-distfiles.sh - name: Cache sources if: steps.cache.outputs.cache-hit != 'true' - uses: actions/cache/save@v3 + uses: actions/cache/save@v4 with: path: | distfiles key: cache-${{ hashFiles('steps/*/sources') }} - name: Run bootstrap - run: ./rootfs.py --bwrap --external-sources --build-kernels --cores 2 --internal-ci pass2 + run: ./rootfs.py --bwrap --external-sources --build-kernels --cores 2 --internal-ci pass2 --early-preseed early-preseed.tar - name: Archive created packages - if: failure() # archive failed builds progress - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: internal_packages_pass2 path: target/external/repo/** - - name: Tar pass2 image - run: tar -cf pass2_image.tar target - - name: Archive pass2_image - uses: actions/upload-artifact@v3 - with: - name: internal_pass2_image - path: pass2_image.tar pass3: name: Run remaining builds under bubblewrap @@ -119,21 +103,24 @@ jobs: - name: Install bubblewrap run: sudo apt install bubblewrap - name: Checkout repo - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: submodules: recursive # There is a strange bug(?) in nongnu, when you clone a git repository # against a commit != HEAD with depth=1, it errors out. fetch-depth: 0 - - name: Get pass2_image - uses: actions/download-artifact@v3 + - name: Get early_preseed + uses: actions/download-artifact@v4 + with: + name: early-preseed + - name: Get pass2 packages + uses: actions/download-artifact@v4 with: name: internal_pass2_image - - name: Extract pass2_image - run: tar -xf pass2_image.tar + path: repo/ - name: Query cache for sources id: cache - uses: actions/cache/restore@v3 + uses: actions/cache/restore@v4 with: path: | distfiles @@ -143,16 +130,67 @@ jobs: run: ./download-distfiles.sh - name: Cache sources if: steps.cache.outputs.cache-hit != 'true' - uses: actions/cache/save@v3 + uses: actions/cache/save@v4 with: path: | distfiles key: cache-${{ hashFiles('steps/*/sources') }} - name: Run bootstrap - run: ./rootfs.py --bwrap --external-sources --build-kernels --cores 2 --internal-ci pass3 + run: ./rootfs.py --bwrap --external-sources --build-kernels --cores 2 --internal-ci pass3 --early-preseed early_preseed.tar --repo repo - name: Archive created packages if: always() # archive both failed and successful builds - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 + with: + name: packages + path: target/external/repo/** + + python: + name: Run the Python bootstrap + needs: pass3 + runs-on: ubuntu-latest + steps: + - name: Install bubblewrap + run: sudo apt install bubblewrap + - name: Checkout repo + uses: actions/checkout@v4 + with: + submodules: recursive + # There is a strange bug(?) in nongnu, when you clone a git repository + # against a commit != HEAD with depth=1, it errors out. + fetch-depth: 0 + - name: Get early_preseed + uses: actions/download-artifact@v4 + with: + name: early-preseed + - name: Get full set of packages + uses: actions/download-artifact@v4 + with: + name: packages + path: repo/ + - name: Query cache for sources + id: cache + uses: actions/cache/restore@v4 + with: + path: | + distfiles + key: cache-${{ hashFiles('steps/*/sources') }} + - name: Get sources + if: steps.cache.outputs.cache-hit != 'true' + run: ./download-distfiles.sh + - name: Cache sources + if: steps.cache.outputs.cache-hit != 'true' + uses: actions/cache/save@v4 + with: + path: | + distfiles + key: cache-${{ hashFiles('steps/*/sources') }} + - name: Run bootstrap + run: ./rootfs.py --bwrap --external-sources --build-kernels --cores 2 --early-preseed early_preseed.tar --repo repo --extras python + - name: Remove non-new packages + run: comm -12 <(ls -1 repo) <(ls -1 target/external/repo) | xargs -I{} rm target/external/repo/{} + - name: Archive Python packages + if: always() # archive both failed and successful builds + uses: actions/upload-artifact@v4 with: name: packages path: target/external/repo/** diff --git a/rootfs.py b/rootfs.py index 3749be81..a2918d35 100755 --- a/rootfs.py +++ b/rootfs.py @@ -220,13 +220,10 @@ def bootstrap(args, generator, target, size): elif args.bwrap: init = '/init' - if not args.internal_ci or args.internal_ci == "pass1": - generator.prepare(target, using_kernel=False) + generator.prepare(target, using_kernel=False) - arch = stage0_arch_map.get(args.arch, args.arch) - init = os.path.join(os.sep, 'bootstrap-seeds', 'POSIX', arch, 'kaem-optional-seed') - else: - generator.reuse(target) + arch = stage0_arch_map.get(args.arch, args.arch) + init = os.path.join(os.sep, 'bootstrap-seeds', 'POSIX', arch, 'kaem-optional-seed') run('env', '-i', 'bwrap', '--unshare-user', '--uid', '0', diff --git a/steps/manifest b/steps/manifest index ac0923c9..b2fa828c 100644 --- a/steps/manifest +++ b/steps/manifest @@ -52,6 +52,7 @@ build: bzip2-1.0.8 build: coreutils-5.0 build: byacc-20240109 build: bash-2.05b +jump: break ( INTERNAL_CI == pass1 ) improve: setup_repo improve: update_env improve: merged_usr @@ -127,7 +128,6 @@ build: kexec-tools-2.0.22 ( BUILD_LINUX == True ) improve: clean_sources improve: clean_artifacts build: linux-4.14.341-openela ( BUILD_LINUX == True ) -jump: break ( INTERNAL_CI == pass1 ) improve: populate_device_nodes jump: linux ( CHROOT == False ) jump: move_disk ( KERNEL_BOOTSTRAP == True )