CI #127
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: CI | |
on: | |
workflow_dispatch: | |
push: | |
branches: | |
- readme | |
paths: | |
- .github/workflows/ci.yml | |
env: | |
SCRIPT_REPO: ${{ github.repository }} | |
SCRIPT_REF: ${{ github.ref_name }} | |
UBOOT_REPO: hzyitc/u-boot-onecloud | |
UBOOT_RELEASE: latest | |
UBOOT_BURNIMG: eMMC.burn.img | |
ARMBIAN_REPO: armbian/build | |
ARMBIAN_REF: main | |
PATCHES: 4077,5076 | |
PATCHES_DISABLED: 5082 | |
permissions: | |
contents: write | |
jobs: | |
prepare: | |
name: Prepare | |
runs-on: ubuntu-22.04 | |
outputs: | |
env: ${{ steps.get.outputs.env }} | |
steps: | |
- id: get | |
name: Get repositories information | |
run: | | |
TIME="$(curl https://api.github.com/repos/${SCRIPT_REPO}/actions/runs/${GITHUB_RUN_ID} | jq -r .created_at)" | |
TAG="ci-$(date -d "${TIME}" -u +'%Y%m%d-%H%M%S-%Z')" | |
SCRIPT_SHA=$(curl https://api.github.com/repos/${SCRIPT_REPO}/commits/${SCRIPT_REF} | jq -r .sha) | |
UBOOT_TAG=$(curl https://api.github.com/repos/${UBOOT_REPO}/releases/${UBOOT_RELEASE} | jq -r .tag_name) | |
ARMBIAN_SHA=$(curl https://api.github.com/repos/${ARMBIAN_REPO}/commits/${ARMBIAN_REF} | jq -r .sha) | |
cat <<EOF | sed -E 's/^ //' >>$GITHUB_ENV | |
TIME=$TIME | |
TAG=$TAG | |
SCRIPT_SHA=$SCRIPT_SHA | |
UBOOT_TAG=$UBOOT_TAG | |
ARMBIAN_SHA=$ARMBIAN_SHA | |
EOF | |
echo "env=$(cat $GITHUB_ENV | base64 -w 0)" >>$GITHUB_OUTPUT | |
- name: Show repositories information | |
run: | | |
C_RESET="\e[0m" | |
C_BLACK="\e[30m" | |
C_RED="\e[31m" | |
C_GREEN="\e[32m" | |
C_YELLOW="\e[33m" | |
C_BLUE="\e[34m" | |
C_MAGENTA="\e[35m" | |
C_CYAN="\e[36m" | |
C_GRAY="\e[37m" | |
echo -e "$(cat <<EOF | sed -E 's/^ //' | |
TIME: ${C_GREEN}$(date -d "$TIME" +'%Y-%m-%d %H:%M:%S %Z(%:z)')${C_RESET} | |
Script: ${C_BLUE}${SCRIPT_REPO}${C_RESET}@${C_MAGENTA}${SCRIPT_REF}${C_RESET}(https://github.com/${SCRIPT_REPO}/tree/${SCRIPT_REF}) | |
${C_YELLOW}${SCRIPT_SHA}${C_RESET}(https://github.com/${SCRIPT_REPO}/tree/${SCRIPT_SHA}) | |
U-Boot: ${C_BLUE}${UBOOT_REPO}${C_RESET}@${C_MAGENTA}${UBOOT_RELEASE}${C_RESET}(https://github.com/${UBOOT_REPO}/releases/tag/${UBOOT_RELEASE}) | |
${C_MAGENTA}${UBOOT_TAG}${C_RESET}(https://github.com/${UBOOT_REPO}/releases/tag/${UBOOT_TAG}) | |
Armbian: ${C_BLUE}${ARMBIAN_REPO}${C_RESET}@${C_MAGENTA}${ARMBIAN_REF}${C_RESET}(https://github.com/${ARMBIAN_REPO}/tree/${ARMBIAN_REF}) | |
${C_YELLOW}${ARMBIAN_SHA}${C_RESET}(https://github.com/${ARMBIAN_REPO}/tree/${ARMBIAN_SHA}) | |
EOF | |
)" | |
if [[ -n "${PATCHES}" ]]; then | |
echo -e "\nPatches:" | |
while read -r id; do | |
echo -e " ${C_BLUE}armbian/build${C_RESET}#${C_MAGENTA}${id}${C_RESET}(http://github.com/armbian/build/pull/${id})" | |
done < <(echo -e "${PATCHES}" | tr ',' '\n') | |
fi | |
cat <<EOF | sed -E 's/^ //' >>$GITHUB_STEP_SUMMARY | |
# $(date -d "$TIME" +'%Y-%m-%d %H:%M:%S %Z(%:z)') | |
## Sources | |
Script: [${SCRIPT_REPO}@${SCRIPT_REF}](https://github.com/${SCRIPT_REPO}/tree/${SCRIPT_REF}) ([\`${SCRIPT_SHA}\`](https://github.com/${SCRIPT_REPO}/tree/${SCRIPT_SHA})) | |
U-Boot: [${UBOOT_REPO}@${UBOOT_RELEASE}](https://github.com/${UBOOT_REPO}/releases/tag/${UBOOT_RELEASE}) ([\`${UBOOT_TAG}\`](https://github.com/${UBOOT_REPO}/releases/tag/${UBOOT_TAG})) | |
Armbian: [${ARMBIAN_REPO}@${ARMBIAN_REF}](https://github.com/${ARMBIAN_REPO}/tree/${ARMBIAN_REF}) ([\`${ARMBIAN_SHA}\`](https://github.com/${ARMBIAN_REPO}/tree/${ARMBIAN_SHA})) | |
${PATCHES:+$( | |
echo "## Patches" | |
echo "${PATCHES}" | tr ',' '\n' | sed -E 's|(.*)|[armbian/build#\1](http://github.com/armbian/build/pull/\1)|' | |
)} | |
EOF | |
- name: Generate release informations | |
run: | | |
cat <<EOF | sed -E 's/^ //' | tee Release.md | |
CI $(date -d "$TIME" +'%Y-%m-%d %H:%M:%S %Z(%:z)') | |
# Sources | |
Script: [${SCRIPT_REPO}@${SCRIPT_REF}](https://github.com/${SCRIPT_REPO}/tree/${SCRIPT_REF}) ([\`${SCRIPT_SHA}\`](https://github.com/${SCRIPT_REPO}/tree/${SCRIPT_SHA})) | |
U-Boot: [${UBOOT_REPO}@${UBOOT_RELEASE}](https://github.com/${UBOOT_REPO}/releases/tag/${UBOOT_RELEASE}) ([\`${UBOOT_TAG}\`](https://github.com/${UBOOT_REPO}/releases/tag/${UBOOT_TAG})) | |
Armbian: [${ARMBIAN_REPO}@${ARMBIAN_REF}](https://github.com/${ARMBIAN_REPO}/tree/${ARMBIAN_REF}) ([\`${ARMBIAN_SHA}\`](https://github.com/${ARMBIAN_REPO}/tree/${ARMBIAN_SHA})) | |
${PATCHES:+$( | |
echo "# Patches" | |
echo "${PATCHES}" | tr ',' '\n' | sed -E 's|(.*)|[armbian/build#\1](http://github.com/armbian/build/pull/\1)|' | |
)} | |
# SHA256 | |
EOF | |
echo "NAME=$(head --line=1 Release.md)" >>$GITHUB_ENV | |
tail --line=+2 Release.md >Body.md | |
- name: Create release | |
uses: softprops/action-gh-release@v1 | |
with: | |
tag_name: ${{ env.TAG }} | |
target_commitish: ${{ github.sha }} | |
name: ${{ env.NAME }} | |
body_path: Body.md | |
build-debs: | |
name: Build ${{ matrix.BRANCH }} | |
needs: prepare | |
runs-on: ubuntu-22.04 | |
strategy: | |
fail-fast: false | |
matrix: | |
BRANCH: | |
- edge | |
- current | |
steps: | |
- name: Import env | |
run: | | |
echo "$(echo "${{ needs.prepare.outputs.env }}" | base64 -d)" >>$GITHUB_ENV | |
- name: Checkout | |
uses: actions/checkout@v3 | |
with: | |
repository: ${{ env.ARMBIAN_REPO }} | |
ref: ${{ env.ARMBIAN_SHA }} | |
- name: "Apply patch ${{ env.PATCHES }}" | |
if: ${{ env.PATCHES }} | |
run: | | |
echo "::group::Download" | |
curl -L -O "https://github.com/armbian/build/pull/{${PATCHES}}.patch" | |
echo "::endgroup::" | |
for file in *.patch; do | |
echo "::group::Applying $file" | |
patch --batch -p1 -N <"$file" | |
echo "::endgroup::" | |
done | |
- name: Build | |
run: | | |
# Don't update remote cache | |
export GITHUB_ACTIONS=false | |
sudo --preserve-env \ | |
./compile.sh kernel \ | |
ALLOW_ROOT=yes \ | |
BOARD=onecloud \ | |
BRANCH=${{ matrix.BRANCH }} \ | |
EXPERT=yes \ | |
USE_CCACHE=no | |
sudo chown $(id -u):$(id -g) -R output/ | |
- name: Upload artifacts | |
uses: actions/upload-artifact@v3 | |
with: | |
name: debs-${{ matrix.BRANCH }} | |
path: output/debs/* | |
- name: Upload to release | |
uses: softprops/action-gh-release@v1 | |
with: | |
tag_name: ${{ env.TAG }} | |
files: | | |
output/debs/* | |
build: | |
name: Build ${{ matrix.RELEASE }}-${{ matrix.BRANCH }}-${{ matrix.TYPE == 'desktop' && matrix.DESKTOP_ENVIRONMENT || matrix.TYPE }} | |
needs: [ prepare, build-debs ] | |
runs-on: ubuntu-22.04 | |
strategy: | |
fail-fast: false | |
matrix: | |
BRANCH: | |
- edge | |
- current | |
RELEASE: | |
# - focal # Ubuntu 20.04 LTS | |
- jammy # Ubuntu 22.04 LTS | |
# - lunar # Ubuntu 23.04 | |
# - buster # Debian 10 | |
- bullseye # Debian 11 | |
- bookworm # Debian 12 | |
- sid # Debian unstable | |
TYPE: | |
- minimal | |
- cli | |
- desktop | |
include: | |
- TYPE: desktop | |
DESKTOP_ENVIRONMENT: xfce | |
DESKTOP_ENVIRONMENT_CONFIG_NAME: config_base | |
DESKTOP_APPGROUPS_SELECTED: "" | |
exclude: | |
- RELEASE: sid | |
TYPE: desktop | |
steps: | |
- name: Import env | |
run: | | |
echo "$(echo "${{ needs.prepare.outputs.env }}" | base64 -d)" >>$GITHUB_ENV | |
- name: Checkout | |
uses: actions/checkout@v3 | |
with: | |
repository: ${{ env.ARMBIAN_REPO }} | |
ref: ${{ env.ARMBIAN_SHA }} | |
- name: "Apply patch ${{ env.PATCHES }}" | |
if: ${{ env.PATCHES }} | |
run: | | |
echo "::group::Download" | |
curl -L -O "https://github.com/armbian/build/pull/{${PATCHES}}.patch" | |
echo "::endgroup::" | |
for file in *.patch; do | |
echo "::group::Applying $file" | |
patch --batch -p1 -N <"$file" | |
echo "::endgroup::" | |
done | |
- name: Download debs | |
uses: actions/download-artifact@v3 | |
with: | |
name: debs-${{ matrix.BRANCH }} | |
path: output/debs/ | |
- name: Build | |
run: | | |
# Don't update remote cache | |
export GITHUB_ACTIONS=false | |
sudo --preserve-env \ | |
./compile.sh build \ | |
ALLOW_ROOT=yes \ | |
BOARD=onecloud \ | |
BRANCH=${{ matrix.BRANCH }} \ | |
RELEASE=${{ matrix.RELEASE }} \ | |
KERNEL_CONFIGURE=no \ | |
BUILD_MINIMAL=${{ matrix.TYPE == 'minimal' && 'yes' || 'no' }} \ | |
BUILD_DESKTOP=${{ matrix.TYPE == 'desktop' && 'yes' || 'no' }} \ | |
DESKTOP_ENVIRONMENT=${{ matrix.DESKTOP_ENVIRONMENT }} \ | |
DESKTOP_ENVIRONMENT_CONFIG_NAME=${{ matrix.DESKTOP_ENVIRONMENT_CONFIG_NAME }} \ | |
DESKTOP_APPGROUPS_SELECTED=${{ matrix.DESKTOP_APPGROUPS_SELECTED }} \ | |
EXPERT=yes \ | |
SKIP_EXTERNAL_TOOLCHAINS=yes \ | |
CLEAN_LEVEL= \ | |
USE_CCACHE=no \ | |
COMPRESS_OUTPUTIMAGE=img | |
sudo chown $(id -u):$(id -g) -R output/ | |
- name: Install Dependents | |
run: | | |
sudo apt install img2simg | |
ver="v0.3.1" | |
curl -L -o ./AmlImg https://github.com/hzyitc/AmlImg/releases/download/$ver/AmlImg_${ver}_linux_amd64 | |
chmod +x ./AmlImg | |
- name: Download and unpack the latest u-boot | |
run: | | |
echo "::group::Download" | |
curl -L -o ./uboot.img https://github.com/${UBOOT_REPO}/releases/download/${UBOOT_TAG}/${UBOOT_BURNIMG} | |
echo "::endgroup::" | |
echo "::group::Unpack" | |
./AmlImg unpack ./uboot.img burn/ | |
echo "::endgroup::" | |
- name: Extract boot and rootfs partitions | |
run: | | |
diskimg=$(ls output/images/*.img) | |
loop=$(sudo losetup --find --show --partscan $diskimg) | |
sudo img2simg ${loop}p1 burn/boot.simg | |
sudo img2simg ${loop}p2 burn/rootfs.simg | |
sudo losetup -d $loop | |
sudo chown $(id -u):$(id -g) -R burn/ | |
- name: Generate burn image | |
run: | | |
echo -n "sha1sum $(sha1sum burn/boot.simg | awk '{print $1}')" >burn/boot.VERIFY | |
echo -n "sha1sum $(sha1sum burn/rootfs.simg | awk '{print $1}')" >burn/rootfs.VERIFY | |
cat <<EOF >>burn/commands.txt | |
PARTITION:boot:sparse:boot.simg | |
VERIFY:boot:normal:boot.VERIFY | |
PARTITION:rootfs:sparse:rootfs.simg | |
VERIFY:rootfs:normal:rootfs.VERIFY | |
EOF | |
prefix=$(ls output/images/*.img | sed 's/\.img$//') | |
burnimg=${prefix}.burn.img | |
./AmlImg pack $burnimg burn/ | |
- name: Hash and compress images | |
run: | | |
for f in output/images/*.img; do | |
sha256sum "$f" | tee -a sha256sum | |
xz --threads=0 --compress "$f" | |
done | |
- name: Upload artifacts | |
uses: actions/upload-artifact@v3 | |
with: | |
name: ${{ matrix.RELEASE }}-${{ matrix.BRANCH }}-${{ matrix.TYPE == 'desktop' && matrix.DESKTOP_ENVIRONMENT || matrix.TYPE }} | |
path: output/images/* | |
- name: Generate release informations | |
run: | | |
cat <<EOF | sed -E 's/^ //' | tee Release.md | |
$(cat sha256sum | awk '{printf "%s: `%s`\n", $2, $1}') | |
EOF | |
- name: Upload to release | |
uses: softprops/action-gh-release@v1 | |
with: | |
tag_name: ${{ env.TAG }} | |
append_body: true | |
body_path: Release.md | |
files: | | |
output/images/Armbian_* |