summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlan Coopersmith <alan.coopersmith@oracle.com>2022-07-23 10:33:20 -0700
committerAlan Coopersmith <alan.coopersmith@oracle.com>2022-07-23 11:02:54 -0700
commitf6ede3004e5c4bd4be90187e9b8554664d0bc066 (patch)
tree5505d132f1ec4316fe964f8f456bf3f1b72932c3
parent0fc6197034c49d9fdf5607cae201f1ac3270e7de (diff)
downloadxcb-proto-f6ede3004e5c4bd4be90187e9b8554664d0bc066.tar.gz
gitlab CI: add a basic build test
Signed-off-by: Alan Coopersmith <alan.coopersmith@oracle.com>
-rw-r--r--.gitlab-ci.yml129
1 files changed, 129 insertions, 0 deletions
diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml
new file mode 100644
index 0000000..3b0ea3f
--- /dev/null
+++ b/.gitlab-ci.yml
@@ -0,0 +1,129 @@
+# vim: set expandtab shiftwidth=2 tabstop=8 textwidth=0 filetype=yaml:
+#
+# This CI uses the freedesktop.org ci-templates.
+# Please see the ci-templates documentation for details:
+# https://freedesktop.pages.freedesktop.org/ci-templates/
+
+.templates_sha: &template_sha c5626190ec14b475271288dda7a7dae8dbe0cd76 # see https://docs.gitlab.com/ee/ci/yaml/#includefile
+
+
+include:
+ # Arch container builder template
+ - project: 'freedesktop/ci-templates'
+ ref: *template_sha
+ file: '/templates/arch.yml'
+ - project: 'freedesktop/ci-templates'
+ ref: *template_sha
+ file: '/templates/ci-fairy.yml'
+ - template: Security/SAST.gitlab-ci.yml
+
+
+stages:
+ - prep # prep work like rebuilding the container images if there is a change
+ - build # for actually building and testing things in a container
+ - test
+ - deploy
+
+
+variables:
+ FDO_UPSTREAM_REPO: 'xorg/proto/xcbproto'
+ # The tag should be updated each time the list of packages is updated.
+ # Changing a tag forces the associated image to be rebuilt.
+ # Note: the tag has no meaning, we use a date format purely for readability
+ FDO_DISTRIBUTION_TAG: '2022-07-23.0'
+ # Packages needed to build xcbproto
+ XCBPROTO_PACKAGES: 'git gcc pkgconf autoconf automake make libxml2 python'
+ # Additional packages needed to build libxcb
+ LIBXCB_PACKAGES: 'libtool xorg-util-macros doxygen graphviz check libxslt libxau libxdmcp'
+ FDO_DISTRIBUTION_PACKAGES: $XCBPROTO_PACKAGES $LIBXCB_PACKAGES
+
+#
+# Verify that commit messages are as expected
+#
+check-commits:
+ extends:
+ - .fdo.ci-fairy
+ stage: prep
+ script:
+ - ci-fairy check-commits --junit-xml=results.xml
+ except:
+ - master@xorg/proto/xcbproto
+ variables:
+ GIT_DEPTH: 100
+ artifacts:
+ reports:
+ junit: results.xml
+ allow_failure: true
+
+#
+# Verify that the merge request has the allow-collaboration checkbox ticked
+#
+check-merge-request:
+ extends:
+ - .fdo.ci-fairy
+ stage: deploy
+ script:
+ - ci-fairy check-merge-request --require-allow-collaboration --junit-xml=results.xml
+ artifacts:
+ when: on_failure
+ reports:
+ junit: results.xml
+ allow_failure: true
+
+
+#
+# Build a container with the given tag and the packages pre-installed.
+# This only happens if/when the tag changes, otherwise the existing image is
+# re-used.
+#
+container-prep:
+ extends:
+ - .fdo.container-build@arch
+ stage: prep
+ variables:
+ GIT_STRATEGY: none
+
+
+#
+# The default build, runs on the image built above.
+#
+build:
+ stage: build
+ extends:
+ - .fdo.distribution-image@arch
+ script:
+ - export INSTDIR="$PWD/_inst"
+ - mkdir _builddir
+ - pushd _builddir > /dev/null
+ - ../autogen.sh --disable-silent-rules --prefix="$INSTDIR"
+ - make
+ - make check
+ - make install
+ - make distcheck
+ - popd > /dev/null
+ variables:
+ artifacts:
+ paths:
+ - _inst
+
+#
+# Build libxcb with the new xcbproto, runs on the image built above.
+#
+build-libxcb:
+ stage: test
+ extends:
+ - .fdo.distribution-image@arch
+ script:
+ - export INSTDIR="$PWD/_inst"
+ - export PKG_CONFIG_PATH=$(find $INSTDIR/ -name '*.pc' -printf "%h:")
+ - git clone --depth=1 https://gitlab.freedesktop.org/xorg/lib/libxcb
+ - pushd libxcb > /dev/null
+ - mkdir _builddir
+ - pushd _builddir > /dev/null
+ - ../autogen.sh --disable-silent-rules --enable-devel-docs --with-doxygen
+ - make
+ - make check
+ - make install
+ - make distcheck
+ - popd > /dev/null
+ - popd > /dev/null