diff options
Diffstat (limited to '.circleci/config.yml')
-rw-r--r-- | .circleci/config.yml | 182 |
1 files changed, 0 insertions, 182 deletions
diff --git a/.circleci/config.yml b/.circleci/config.yml deleted file mode 100644 index 305813734..000000000 --- a/.circleci/config.yml +++ /dev/null @@ -1,182 +0,0 @@ -version: 2.0 -jobs: - build: - docker: - - image: docker.io/openwrtorg/packages-cci:v1.0.7 - environment: - - SDK_HOST: "downloads.openwrt.org" - - SDK_PATH: "snapshots/targets/ath79/generic" - - SDK_FILE: "openwrt-sdk-ath79-generic_*.Linux-x86_64.tar.xz" - - BRANCH: "master" - steps: - - checkout: - path: ~/openwrt_packages - - - run: - name: Check changes / verify commits - working_directory: ~/openwrt_packages - command: | - cat >> $BASH_ENV <<EOF - echo_red() { printf "\033[1;31m\$*\033[m\n"; } - echo_green() { printf "\033[1;32m\$*\033[m\n"; } - echo_blue() { printf "\033[1;34m\$*\033[m\n"; } - EOF - source $BASH_ENV - - RET=0 - for commit in $(git rev-list HEAD ^origin/$BRANCH); do - echo_blue "=== Checking commit '$commit'" - if git show --format='%P' -s $commit | grep -qF ' '; then - echo_red "Pull request should not include merge commits" - RET=1 - fi - - author="$(git show -s --format=%aN $commit)" - if echo $author | grep -q '\S\+\s\+\S\+'; then - echo_green "Author name ($author) seems ok" - else - echo_red "Author name ($author) need to be your real name 'firstname lastname'" - RET=1 - fi - - subject="$(git show -s --format=%s $commit)" - if echo "$subject" | grep -q -e '^[0-9A-Za-z,+/_-]\+: ' -e '^Revert '; then - echo_green "Commit subject line seems ok ($subject)" - else - echo_red "Commit subject line MUST start with '<package name>: ' ($subject)" - RET=1 - fi - - body="$(git show -s --format=%b $commit)" - sob="$(git show -s --format='Signed-off-by: %aN <%aE>' $commit)" - if echo "$body" | grep -qF "$sob"; then - echo_green "Signed-off-by match author" - else - echo_red "Signed-off-by is missing or doesn't match author (should be '$sob')" - RET=1 - fi - done - - exit $RET - - - run: - name: Download the SDK - working_directory: ~/sdk - command: | - curl "https://$SDK_HOST/$SDK_PATH/sha256sums" -sS -o sha256sums - curl "https://$SDK_HOST/$SDK_PATH/sha256sums.asc" -fs -o sha256sums.asc || true - curl "https://$SDK_HOST/$SDK_PATH/sha256sums.sig" -fs -o sha256sums.sig || true - if [ ! -f sha256sums.asc ] && [ ! -f sha256sums.sig ]; then - echo_red "Missing sha256sums signature files" - exit 1 - fi - [ ! -f sha256sums.asc ] || gpg --with-fingerprint --verify sha256sums.asc sha256sums - if [ -f sha256sums.sig ]; then - VERIFIED= - for KEY in ~/usign/*; do - echo "Trying $KEY..." - if signify-openbsd -V -q -p "$KEY" -x sha256sums.sig -m sha256sums; then - echo "...verified" - VERIFIED=1 - break - fi - done - if [ -z "$VERIFIED" ]; then - echo_red "Could not verify usign signature" - exit 1 - fi - fi - rsync -av "$SDK_HOST::downloads/$SDK_PATH/$SDK_FILE" . - sha256sum -c --ignore-missing sha256sums - - - run: - name: Prepare build_dir - working_directory: ~/build_dir - command: | - tar Jxf ~/sdk/$SDK_FILE --strip=1 - touch .config - make prepare-tmpinfo scripts/config/conf - ./scripts/config/conf --defconfig=.config Config.in - make prereq - rm .config - cat > feeds.conf <<EOF - src-git base https://github.com/openwrt/openwrt.git;$BRANCH - src-link packages $HOME/openwrt_packages - src-git luci https://github.com/openwrt/luci.git;$BRANCH - EOF - cat feeds.conf - ./scripts/feeds update -a > /dev/null - make defconfig > /dev/null - # enable BUILD_LOG - sed -i 's/# CONFIG_BUILD_LOG is not set/CONFIG_BUILD_LOG=y/' .config - - - run: - name: Install & download source, check package, compile - working_directory: ~/build_dir - command: | - set +o pipefail - PKGS=$(cd ~/openwrt_packages; git diff --diff-filter=d --name-only "origin/$BRANCH..." | grep 'Makefile$' | grep -Ev '/files/|/src/' | awk -F/ '{ print $(NF-1) }') - if [ -z "$PKGS" ] ; then - echo_blue "WARNING: No new or modified packages found!" - exit 0 - fi - - echo_blue "=== Found new/modified packages: $PKGS" - for PKG in $PKGS ; do - echo_blue "===+ Install: $PKG" - ./scripts/feeds install "$PKG" - - echo_blue "===+ Download: $PKG" - make "package/$PKG/download" V=s - - echo_blue "===+ Check package: $PKG" - make "package/$PKG/check" V=s 2>&1 | tee logtmp - RET=${PIPESTATUS[0]} - - if [ $RET -ne 0 ]; then - echo_red "=> Package check failed: $RET)" - exit $RET - fi - - badhash_msg="HASH does not match " - badhash_msg+="|HASH uses deprecated hash," - badhash_msg+="|HASH is missing," - if grep -qE "$badhash_msg" logtmp; then - echo_red "=> Package HASH check failed" - exit 1 - fi - echo_green "=> Package check OK" - done - - make \ - -f .config \ - -f tmp/.packagedeps \ - -f <(echo '$(info $(sort $(package-y) $(package-m)))'; echo -en 'a:\n\t@:') \ - | tr ' ' '\n' >enabled-package-subdirs.txt - for PKG in $PKGS ; do - if ! grep -m1 -qE "(^|/)$PKG$" enabled-package-subdirs.txt; then - echo_red "===+ Building: $PKG skipped. It cannot be enabled with $SDK_FILE" - continue - fi - echo_blue "===+ Building: $PKG" - make "package/$PKG/compile" -j3 V=s || { - RET=$? - echo_red "===+ Building: $PKG failed, rebuilding with -j1 for human readable error log" - make "package/$PKG/compile" -j1 V=s; exit $RET - } - done - - - store_artifacts: - path: ~/build_dir/logs - - - store_artifacts: - path: ~/build_dir/bin - -workflows: - version: 2 - buildpr: - jobs: - - build: - filters: - branches: - ignore: master |