summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTristan Van Berkom <tristan.vanberkom@codethink.co.uk>2017-12-22 17:45:11 -0500
committerTristan Van Berkom <tristan.vanberkom@codethink.co.uk>2017-12-22 18:05:48 -0500
commite5eb337a466949eebb7fafa08a1d1f57742f5c85 (patch)
treea92e859f81b8c64757029c86e9da31e59b36090f
parent78fc8440fdf9f007d893031275b5842fa4de7631 (diff)
downloadbuildstream-ci-on-docs.tar.gz
.gitlab-ci.yml: Build documentation in every CI pipelineci-on-docs
Build it in one stage before the `pages` target, and then only make the deployment step conditional on the branch.
-rw-r--r--.gitlab-ci.yml82
1 files changed, 58 insertions, 24 deletions
diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml
index 061d62297..7f7c948f4 100644
--- a/.gitlab-ci.yml
+++ b/.gitlab-ci.yml
@@ -5,10 +5,9 @@ cache:
- cache/buildstream/sources/
stages:
- - dist
+ - prepare
- test
- - coverage
- - docs
+ - post
before_script:
# Diagnostics
@@ -21,10 +20,14 @@ before_script:
- adduser -m buildstream
- chown -R buildstream:buildstream .
+#####################################################
+# Prepare stage #
+#####################################################
+
# Create a source distribution
#
-distcheck:
- stage: dist
+source_dist:
+ stage: prepare
script:
# Generate the source distribution tarball
@@ -57,6 +60,10 @@ distcheck:
paths:
- dist/
+#####################################################
+# Test stage #
+#####################################################
+
# Run premerge commits
#
pytest_linux:
@@ -103,7 +110,7 @@ integration_linux:
- logs-linux/
dependencies:
- - distcheck
+ - source_dist
pytest_unix:
stage: test
@@ -152,12 +159,40 @@ integration_unix:
- logs-unix/
dependencies:
- - distcheck
+ - source_dist
+
+# Automatically build documentation for every commit, we want to know
+# if building documentation fails even if we're not deploying it.
+#
+# Note: We still do not enforce a consistent installation of python2
+# or sphinx, as python2 will significantly grow the backing image.
+#
+docs:
+ stage: test
+ script:
+ - dnf install -y python2
+ - pip3 install sphinx
+ - pip3 install sphinx-click
+ - cd dist && ./unpack.sh && cd buildstream
+ - pip3 install .
+ - make -C doc
+ - cd ../..
+ - mv dist/buildstream/doc/build/html public
+ artifacts:
+ paths:
+ - public/
+ dependencies:
+ - source_dist
+
+
+#####################################################
+# Post stage #
+#####################################################
# Collate coverage reports
#
coverage:
- stage: coverage
+ stage: post
script:
- pip3 install --no-index .
- mkdir report
@@ -176,27 +211,26 @@ coverage:
- pytest_unix
- integration_unix
-# Automatically build documentation, only for merges which land
-# on master branch.
-#
-# Note: We still do not enforce a consistent installation of python2
-# or sphinx, as python2 will significantly grow the backing image.
+# Deploy, only for merges which land on master branch.
#
pages:
- stage: docs
+ stage: post
+ dependencies:
+ - source_dist
+ - docs
script:
- - dnf install -y python2
- - pip3 install sphinx
- - pip3 install sphinx-click
- - cd dist && ./unpack.sh && cd buildstream
- - pip3 install .
- - make -C doc
- - cd ../..
- - mv dist/buildstream/doc/build/html public
+ - find public/
artifacts:
paths:
- public/
only:
+ #
+ # FIXME:
+ #
+ # Ideally we want to publish to a different subdir of
+ # pages depending on which stable branch we are building here,
+ # not currently automatically supported but can be worked around.
+ #
+ # See https://gitlab.com/gitlab-org/gitlab-ce/issues/35141
+ #
- master
- dependencies:
- - distcheck