summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorxebd <xeb@mail.ru>2022-09-12 10:55:26 +0300
committerGitHub <noreply@github.com>2022-09-12 10:55:26 +0300
commit25c72614bf8106b0e4f71e2bce70514b03858463 (patch)
tree34377047de0a3515ae175bce1e822765184951c5
parent38d96b8e20608fb743d543fe3f08ad4b9d1dcd66 (diff)
parent785798c6f19863e49a5f061c42ad3331c76055d6 (diff)
downloadaccel-ppp-25c72614bf8106b0e4f71e2bce70514b03858463.tar.gz
accel-ppp-25c72614bf8106b0e4f71e2bce70514b03858463.zip
Merge pull request #60 from svlobanov/ci2
ci: add build jobs (Github CI)
-rw-r--r--.github/workflows/build-and-run.yml167
-rw-r--r--cmake/cpack.cmake10
2 files changed, 177 insertions, 0 deletions
diff --git a/.github/workflows/build-and-run.yml b/.github/workflows/build-and-run.yml
new file mode 100644
index 00000000..3794f31f
--- /dev/null
+++ b/.github/workflows/build-and-run.yml
@@ -0,0 +1,167 @@
+name: Build and Run
+
+on:
+ workflow_dispatch:
+ pull_request:
+ push:
+ branches:
+ - master
+
+jobs:
+ Build-in-VM:
+ #if: ${{ false }} # disable for now
+ strategy:
+ fail-fast: false
+ matrix:
+ distro: ["ubuntu-22.04", "ubuntu-20.04"]
+ runs-on: ${{ matrix.distro }}
+ steps:
+ - name: Set vars for Ubuntu 20.04
+ if: ${{ matrix.distro == 'ubuntu-20.04' }}
+ run: |
+ echo "DISTRO=ubuntu20.04" >> $GITHUB_ENV
+ echo "CPACK_TYPE=Ubuntu20" >> $GITHUB_ENV
+ - name: Set vars for Ubuntu 22.04
+ if: ${{ matrix.distro == 'ubuntu-22.04' }}
+ run: |
+ echo "DISTRO=ubuntu22.04" >> $GITHUB_ENV
+ echo "CPACK_TYPE=Ubuntu20" >> $GITHUB_ENV
+ - name: Set common vars
+ run: |
+ echo UNAME_R=`uname -r` >> $GITHUB_ENV
+ echo UNAME_M=`uname -m` >> $GITHUB_ENV;
+ - name: Install build tools
+ run: >
+ sudo apt update &&
+ sudo apt -y install git build-essential cmake gcc linux-headers-`uname -r`
+ libpcre3-dev libssl-dev liblua5.1-0-dev kmod
+ - name: Check out repository code
+ uses: actions/checkout@v3
+ with:
+ fetch-depth: 0
+ - name: mkdir build
+ run: mkdir build
+ - name: cmake
+ working-directory: ./build
+ run: >
+ cmake -DBUILD_IPOE_DRIVER=TRUE -DBUILD_VLAN_MON_DRIVER=TRUE -DCMAKE_INSTALL_PREFIX=/usr
+ -DKDIR=/usr/src/linux-headers-`uname -r`
+ -DLUA=TRUE -DSHAPER=FALSE -DRADIUS=TRUE
+ -DCPACK_TYPE=${{ env.CPACK_TYPE }} ..
+ - name: make
+ working-directory: ./build
+ run: make
+ - name: Generate debian package
+ working-directory: ./build
+ run: cpack -G DEB
+ - name: Rename accel-ppp deb package
+ working-directory: ./build
+ run: >
+ mv -v accel-ppp.deb
+ accel-ppp_`git describe --tags --long | sed 's/^v//' | sed 's/-/+/' | sed 's/-/~/'`-1+${{ env.DISTRO }}_`uname -m`.deb
+ - name: Install debian package
+ working-directory: ./build
+ run: sudo apt -y install ./accel-ppp*.deb
+ - name: Copy default config
+ run: sudo cp /etc/accel-ppp.conf.dist /etc/accel-ppp.conf
+ - name: Start accel-ppp
+ run: sudo systemctl start accel-ppp
+ - name: Check accel-ppp running status
+ run: sudo systemctl status accel-ppp
+ - name: Check accel-ppp stat
+ run: accel-cmd show stat
+ - name: Upload .deb package as artifact
+ uses: actions/upload-artifact@v3
+ with:
+ name: deb-package-${{ matrix.distro }}-${{ env.UNAME_M }}-${{ env.UNAME_R }}
+ path: build/accel-ppp_*.deb
+ if-no-files-found: error
+
+ Build-in-Container:
+ #if: ${{ false }} # disable for now
+ strategy:
+ fail-fast: false
+ matrix:
+ distro:
+ [
+ "debian:10",
+ "debian:11",
+ "debian:bookworm",
+ "ubuntu:18.04",
+ "ubuntu:20.04",
+ "ubuntu:22.04",
+ ]
+ runs-on: ubuntu-latest
+ container:
+ image: ${{ matrix.distro }}
+ steps:
+ - name: Set distro-specific vars
+ run: >
+ HEADERS_SUFFIX=`uname -m | sed s/aarch64/arm64/ | sed s/x86_64/amd64/`;
+ DISTRO=`echo ${{ matrix.distro }} | sed 's/://'`;
+ case "${{ matrix.distro }}" in
+ debian:bookworm) DISTRO=debian12; CPACK_TYPE=Debian12 ;;
+ debian:11) CPACK_TYPE=Debian11 ;;
+ debian:10) CPACK_TYPE=Debian10 ;;
+ ubuntu:22.04) CPACK_TYPE=Ubuntu22 ; HEADERS_SUFFIX=generic ;;
+ ubuntu:20.04) CPACK_TYPE=Ubuntu20 ; HEADERS_SUFFIX=generic ;;
+ ubuntu:18.04) CPACK_TYPE=Ubuntu18 ; HEADERS_SUFFIX=generic ;;
+ esac;
+ echo HEADERS_SUFFIX=$HEADERS_SUFFIX >> $GITHUB_ENV;
+ echo DISTRO=$DISTRO >> $GITHUB_ENV;
+ echo CPACK_TYPE=$CPACK_TYPE >> $GITHUB_ENV;
+ echo UNAME_M=`uname -m` >> $GITHUB_ENV;
+ cat $GITHUB_ENV
+ - name: Install build tools
+ run: >
+ apt update && apt -y upgrade && apt -y dist-upgrade &&
+ DEBIAN_FRONTEND=noninteractive DEBCONF_NONINTERACTIVE_SEEN=true apt -y install git build-essential cmake gcc
+ linux-headers-${{ env.HEADERS_SUFFIX }}
+ libpcre3-dev libssl-dev liblua5.1-0-dev kmod
+ - name: Get kernel name from headers
+ run: >
+ echo KERNEL_NAME=`ls -1 /usr/src/ | grep 'linux-headers.*${{ env.HEADERS_SUFFIX }}' |
+ sed 's/linux-headers-//'` >> $GITHUB_ENV;
+ cat $GITHUB_ENV
+ - name: Check out repository code
+ uses: actions/checkout@v3
+ with:
+ fetch-depth: 0
+ - name: mkdir build
+ run: mkdir build
+ - name: Disable git security warnings
+ run: git config --global --add safe.directory '*'
+ - name: cmake
+ working-directory: ./build
+ run: >
+ cmake -DBUILD_IPOE_DRIVER=TRUE -DBUILD_VLAN_MON_DRIVER=TRUE -DCMAKE_INSTALL_PREFIX=/usr
+ -DKDIR=/usr/src/linux-headers-${{ env.KERNEL_NAME }}
+ -DMODULES_KDIR=${{ env.KERNEL_NAME }}
+ -DLUA=TRUE -DSHAPER=FALSE -DRADIUS=TRUE
+ -DCPACK_TYPE=${{ env.CPACK_TYPE }} ..
+ - name: make
+ working-directory: ./build
+ run: make
+ - name: Generate debian package
+ working-directory: ./build
+ run: cpack -G DEB
+ - name: Rename accel-ppp deb package
+ working-directory: ./build
+ run: >
+ mv -v accel-ppp.deb
+ accel-ppp_`git describe --tags --long | sed 's/^v//' | sed 's/-/+/' | sed 's/-/~/'`-1+${{ env.DISTRO }}_${{ env.UNAME_M }}.deb
+ - name: Install debian package
+ working-directory: ./build
+ run: apt -y install ./accel-ppp*.deb
+ - name: Start accel-ppp with default config
+ run: accel-pppd -d -c /etc/accel-ppp.conf.dist
+ - name: Sleep for 1 sec
+ run: sleep 1
+ - name: Check accel-ppp stat
+ run: accel-cmd show stat
+ - name: Upload .deb package as artifact
+ uses: actions/upload-artifact@v3
+ with:
+ name: deb-package-${{ env.DISTRO }}-${{ env.UNAME_M }}-${{ env.KERNEL_NAME }}
+ path: build/accel-ppp_*.deb
+ if-no-files-found: error
diff --git a/cmake/cpack.cmake b/cmake/cpack.cmake
index 7de53ad6..db7fe123 100644
--- a/cmake/cpack.cmake
+++ b/cmake/cpack.cmake
@@ -48,6 +48,11 @@ IF(CPACK_TYPE STREQUAL Debian11)
INCLUDE(${CMAKE_HOME_DIRECTORY}/cmake/debian/debian.cmake)
ENDIF(CPACK_TYPE STREQUAL Debian11)
+IF(CPACK_TYPE STREQUAL Debian12)
+ SET(CPACK_DEBIAN_PACKAGE_DEPENDS "libc6 (>= 2.34), libssl3 (>= 3.0.5), libpcre3 (>= 8.39)")
+ INCLUDE(${CMAKE_HOME_DIRECTORY}/cmake/debian/debian.cmake)
+ENDIF(CPACK_TYPE STREQUAL Debian12)
+
IF(CPACK_TYPE STREQUAL Ubuntu16)
SET(CPACK_DEBIAN_PACKAGE_DEPENDS "libc6 (>= 2.23), libssl1.0.0 (>= 1.0.0), libpcre3 (>= 8.39)")
INCLUDE(${CMAKE_HOME_DIRECTORY}/cmake/debian/debian.cmake)
@@ -63,6 +68,11 @@ IF(CPACK_TYPE STREQUAL Ubuntu20)
INCLUDE(${CMAKE_HOME_DIRECTORY}/cmake/debian/debian.cmake)
ENDIF(CPACK_TYPE STREQUAL Ubuntu20)
+IF(CPACK_TYPE STREQUAL Ubuntu22)
+ SET(CPACK_DEBIAN_PACKAGE_DEPENDS "libc6 (>= 2.35), libssl3 (>= 3.0.2), libpcre3 (>= 8.39)")
+ INCLUDE(${CMAKE_HOME_DIRECTORY}/cmake/debian/debian.cmake)
+ENDIF(CPACK_TYPE STREQUAL Ubuntu22)
+
IF(CPACK_TYPE STREQUAL Centos7)
SET(CPACK_RPM_PACKAGE_LICENSE "GPL")
SET(CPACK_RPM_PACKAGE_URL "http://accel-ppp.org")