diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 8c690a15..ec817cb8 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -1,20 +1,19 @@ # Build Icecast - test -make_dist: - variables: - GIT_SUBMODULE_STRATEGY: recursive + +default: + image: alpine:3.15 tags: - - docker - - image: alpine:3.12 - - stage: build + - docker + - linux +.TemplateAlpine: before_script: + - set -xe - apk update - cat /etc/os* - - apk add musl-dev git make gcc automake autoconf libtool - - apk add curl-dev libogg-dev libvorbis-dev libxslt-dev libxml2-dev + - apk add musl-dev git make gcc automake autoconf libtool curl ca-certificates + - apk add curl-dev libogg-dev libvorbis-dev libxslt-dev libxml2-dev libc6-compat # gzip required because busybox gzip does not understand best / zip for make dist - apk add gzip zip tar # Required for tests @@ -22,25 +21,65 @@ make_dist: # Create user to run tests #- adduser -s /bin/sh -D -H icecast - script: +make_dist: + extends: .TemplateAlpine + variables: + GIT_SUBMODULE_STRATEGY: recursive + LIBIGLOO_PACKAGE_PREFIX: "alpine-libigloo-bins" + LIBIGLOO_PACKAGE_VERSION: "0.91" + LIBIGLOO_PROJECT_ID: 143 + + stage: build + + script: + - set -xe # yes i know the scripts will be merged... but for sanities sake - ./autogen.sh + - mkdir EXTRA-LIBS + - export PKG_CONFIG_PATH=`pwd`/EXTRA-LIBS/usr/local/lib/pkgconfig + # we build these in script as gitlab does not support nested expansion in above variables(or it is not well documented) + - if echo "$CI_COMMIT_REF_NAME" | grep -- '-with-libigloo$'; then export LIBIGLOO_PACKAGE_SUFFIX=`echo "$CI_COMMIT_REF_NAME" | sed 's/-with-libigloo$//'`; elif echo "$CI_COMMIT_REF_NAME" | grep '^devel'; then export LIBIGLOO_PACKAGE_SUFFIX='devel'; else export LIBIGLOO_PACKAGE_SUFFIX='master'; fi + - export LIBIGLOO_PACKAGE_BASE=$LIBIGLOO_PACKAGE_PREFIX-$LIBIGLOO_PACKAGE_SUFFIX + - export LIBIGLOO_PACKAGE_ARCHIVE=$LIBIGLOO_PACKAGE_BASE.tar.gz + - export LIBIGLOO_PACKAGE_VERSION_WITH_SUFFIX=$LIBIGLOO_PACKAGE_VERSION-$LIBIGLOO_PACKAGE_SUFFIX + - 'curl -LO --header "JOB-TOKEN: $CI_JOB_TOKEN" "${CI_API_V4_URL}/projects/$LIBIGLOO_PROJECT_ID/packages/generic/$LIBIGLOO_PACKAGE_PREFIX/$LIBIGLOO_PACKAGE_VERSION_WITH_SUFFIX/$LIBIGLOO_PACKAGE_ARCHIVE"' + - tar -C ./EXTRA-LIBS -xvzf $LIBIGLOO_PACKAGE_ARCHIVE + - sed -i "s#/usr/local#`pwd`/EXTRA-LIBS/\0#g" `pwd`/EXTRA-LIBS/usr/local/lib/pkgconfig/*.pc + - grep . `pwd`/EXTRA-LIBS/usr/local/lib/pkgconfig/*.pc + - ls -la `pwd`/EXTRA-LIBS/usr/local/lib - ./configure || cat config.log + - make - make dist - - ls -la + # Tests #- su -c "./tests/admin-tests.sh" icecast artifacts: - paths: - - icecast-*.tar.gz - - icecast-*.zip + untracked: true expire_in: 1 week -upload_dist: - tags: - - docker - - linux +upload_package: + extends: .TemplateAlpine + stage: deploy + variables: + ICECAST_SERVER_VERSION: "2.4.99.3" + ICECAST_SERVER_PREFIX: "alpine-icecast-server-bins" + script: + - make install DESTDIR=`pwd`/_install_base/ + - cd _install_base/ + # see above + - export ICECAST_SERVER_BASE=$ICECAST_SERVER_PREFIX-$CI_COMMIT_REF_NAME + - export ICECAST_SERVER_ARCHIVE=$ICECAST_SERVER_BASE.tar.gz + - export ICECAST_SERVER_VERSION_WITH_SUFFIX=$ICECAST_SERVER_VERSION-$CI_COMMIT_REF_NAME + - tar -cvzf ../$ICECAST_SERVER_ARCHIVE * + - cd .. + - 'curl --header "JOB-TOKEN: $CI_JOB_TOKEN" --upload-file $ICECAST_SERVER_ARCHIVE "${CI_API_V4_URL}/projects/${CI_PROJECT_ID}/packages/generic/$ICECAST_SERVER_PREFIX/$ICECAST_SERVER_VERSION_WITH_SUFFIX/$ICECAST_SERVER_ARCHIVE"' + + needs: + - "make_dist" + + +upload_dist: only: - master - devel @@ -57,10 +96,6 @@ upload_dist: - ./ci/osc/handle-osc-upload.sh upload_dist_release: - tags: - - docker - - linux - only: - tags