--- image: python:3.9-bullseye stages: - test - integration - build - deploy - upload before_script: - pip3 install coverage pycodestyle - export EASYWKS_VERSION=$(python -c 'import easywks; print(easywks.__version__)') test: stage: test script: - pip3 install -e . - python3 -m coverage run --rcfile=setup.cfg -m unittest discover easywks artifacts: paths: - ".coverage*" codestyle: stage: test script: - pip3 install -e . - pycodestyle easywks easywksserver_gpgwksclient: stage: integration script: - echo "openpgpkey" > /etc/hostname - echo "127.0.0.1 openpgpkey.example.org openpgpkey example.org" > /etc/hosts - pip3 install -e . - apt update; apt install --yes gnupg2 socat ca-certificates - openssl req -x509 -newkey rsa:4096 -keyout /etc/ssl/key.pem -out /etc/ssl/cert.pem -sha256 -days 365 -nodes -subj '/CN=openpgpkey.example.org' - cp /etc/ssl/cert.pem /usr/local/share/ca-certificates/local.crt - update-ca-certificates - mkdir -p /tmp/easywks - | cat > /tmp/easywks.yml <- export FINGERPRINT="$(gpg --with-colons --fingerprint alice@example.org | grep -A1 ^pub | grep ^fpr | cut -d: -f10)" - /usr/lib/gnupg/gpg-wks-client --supported alice@example.org - /usr/lib/gnupg/gpg-wks-client --check gpgwks@example.org - PUBREQ="$(/usr/lib/gnupg/gpg-wks-client --create "${FINGERPRINT}" alice@example.org)" - CONFREQ="$(echo "${PUBREQ}" | easywks --config /tmp/easywks.yml process)" - CONFRESP="$(echo "${CONFREQ}" | /usr/lib/gnupg/gpg-wks-client --receive --verbose)" - PUBRESP="$(echo "${CONFRESP}" | easywks --config /tmp/easywks.yml process)" - echo "${PUBRESP}" | gpg --batch --decrypt - /usr/lib/gnupg/gpg-wks-client --check alice@example.org - export GNUPGHOME=/tmp/gpg - gpg --auto-key-locate=clear,wkd,nodefault --locate-keys alice@example.org - kill %2 - kill %1 coverage: stage: integration coverage: >- /(?i)total.*? (100(?:\.0+)?\%|[1-9]?\d(?:\.\d+)?\%)$/ script: - python3 -m coverage combine - python3 -m coverage report --rcfile=setup.cfg build_wheel: stage: build script: - python3 setup.py egg_info bdist_wheel - cd dist - sha256sum *.whl > SHA256SUMS artifacts: paths: - "dist/*.whl" - dist/SHA256SUMS only: - tags build_debian: stage: build script: - apt update && apt install --yes lintian rsync sudo - echo -n > package/debian/easywks/usr/share/doc/easywks/changelog - | for version in "$(cat CHANGELOG.md | grep '" | grep -B 1000 "<"'!'"-- END CHANGES ${version} -->" | tail -n +2 | head -n -1 | sed -re 's/^-/ */g' >> package/debian/easywks/usr/share/doc/easywks/changelog echo "\n -- ${PACKAGE_AUTHOR} $(date -R)\n" >> package/debian/easywks/usr/share/doc/easywks/changelog done - gzip -9n package/debian/easywks/usr/share/doc/easywks/changelog - python3 setup.py egg_info install --root=package/debian/easywks/ --prefix=/usr --optimize=1 - cd package/debian - sed -re "s/__EASYWKS_VERSION__/${EASYWKS_VERSION}/g" -i easywks/DEBIAN/control - mkdir -p easywks/usr/lib/python3/dist-packages/ - rsync -a easywks/usr/lib/python3.9/site-packages/ easywks/usr/lib/python3/dist-packages/ - rm -rf easywks/usr/lib/python3.9/site-packages - find easywks/usr/lib/python3/dist-packages -name __pycache__ -exec rm -r {} \; 2>/dev/null || true - find easywks/usr/lib/python3/dist-packages -name '*.pyc' -exec rm {} \; - find easywks/usr/lib/python3/dist-packages -name '*.pyo' -exec rm {} \; - sed -re 's$#!/usr/local/bin/python3$#!/usr/bin/python3$' -i easywks/usr/bin/easywks - find easywks -type f -exec chmod 0644 {} \; - find easywks -type d -exec chmod 755 {} \; - chmod +x easywks/usr/bin/easywks easywks/DEBIAN/postinst easywks/DEBIAN/prerm easywks/DEBIAN/postrm - dpkg-deb --build easywks - mv easywks.deb "easywks_${EASYWKS_VERSION}-1_all.deb" - sudo -u nobody lintian "easywks_${EASYWKS_VERSION}-1_all.deb" - sha256sum *.deb > SHA256SUMS artifacts: paths: - "package/debian/*.deb" - package/debian/SHA256SUMS only: - tags release: stage: deploy script: - python3 package/release.py only: - tags repo: stage: upload trigger: s3lph/custom-packages variables: MULTIPROJECT_TRIGGER_JOBNAME: easywks only: - tags