From 51eae5bf34f1ac50313c00cb2c691deb626bf9ef Mon Sep 17 00:00:00 2001 From: initramfs Date: Thu, 11 Aug 2016 00:19:20 +0800 Subject: [PATCH 1/4] chore(build): deploy doxygen documentation on master branch pushes This commit enables travis to automatically build doxygen documentation on updates to the master branch. The documentation is accessible from the qTox website under the URL: https://qtox.github.io/doxygen --- .travis.yml | 3 +++ .travis/build-docs.sh | 52 +++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 55 insertions(+) create mode 100644 .travis/build-docs.sh diff --git a/.travis.yml b/.travis.yml index b70b4a64d..df2aebbb4 100644 --- a/.travis.yml +++ b/.travis.yml @@ -17,3 +17,6 @@ deploy: repo: qTox/qTox tags: true skip_cleanup: true + +after_success: +- test $TRAVIS_PULL_REQUEST == "false" && test $TRAVIS_BRANCH == "master" && bash ./.travis/build-docs.sh diff --git a/.travis/build-docs.sh b/.travis/build-docs.sh new file mode 100644 index 000000000..3c47d592f --- /dev/null +++ b/.travis/build-docs.sh @@ -0,0 +1,52 @@ +#!/bin/bash +# +# Copyright © 2016 by The qTox Project +# +# This program is libre software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . + + +# Obtain doxygen +sudo apt-get install doxygen + +CONFIG_FILE="doxygen.conf" +CONFIG_FILE_TMP="$CONFIG_FILE.tmp.autogen" + +GIT_DESC=$(git describe --tags 2> /dev/null) +GIT_CHASH=$(git rev-parse HEAD) + +# Create temporary config file +cp "$CONFIG_FILE" "$CONFIG_FILE_TMP" + +# Append git version to doxygen version string +echo "PROJECT_NUMBER = \"Version: $GIT_DESC | Commit: $GIT_CHASH\"" >> "$CONFIG_FILE_TMP" + +# Generate documentation +echo "Generating documentation..." +echo + +doxygen "$CONFIG_FILE_TMP" +rm "$CONFIG_FILE_TMP" + +# Push generated doxygen to GitHub pages +cd ./doc/html/ + +git init +git config user.name "Travis CI" +git config user.email "qTox@users.noreply.github.com" + +git add . +git commit -m "Deploy to GH pages from commit: $GIT_CHASH" + +echo "Pushing to GH pages..." +git push --force --quiet "https://${GH_TOKEN}@github.com/qTox/doxygen.git" master:gh-pages &> /dev/null From e124bd85b641bf6ee48b164cb2ab9acab4461631 Mon Sep 17 00:00:00 2001 From: initramfs Date: Thu, 11 Aug 2016 03:34:27 +0800 Subject: [PATCH 2/4] chore(build): parallelize travis and separate out doc build/deploy This commit takes the existing travis task list and attempts to split it into multiple jobs for the sake of efficiency. Also properly separates out the build/deploy of documentation. --- .travis.yml | 21 ++++++--- .travis/build-docs.sh | 24 ++--------- .travis/build-osx.sh | 25 +++++++++++ ...-ubuntu_14_04.sh => build-ubuntu-14-04.sh} | 0 .travis/deploy-docs.sh | 43 +++++++++++++++++++ .travis/travis.sh | 22 ---------- .travis/verify-commit-format.sh | 22 ++++++++++ 7 files changed, 109 insertions(+), 48 deletions(-) mode change 100644 => 100755 .travis/build-docs.sh create mode 100755 .travis/build-osx.sh rename .travis/{build-ubuntu_14_04.sh => build-ubuntu-14-04.sh} (100%) create mode 100755 .travis/deploy-docs.sh delete mode 100755 .travis/travis.sh create mode 100755 .travis/verify-commit-format.sh diff --git a/.travis.yml b/.travis.yml index df2aebbb4..dbbdcda7c 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,11 +1,20 @@ sudo: required dist: trusty language: cpp -os: -- linux -- osx -script: -- bash ./.travis/travis.sh + +matrix: + fast_finish: true + include: + - os: linux + env: JOB=verify-commit-format + - os: linux + env: JOB=build-docs + - os: linux + env: JOB=build-ubuntu-14-04 + - os: osx + env: JOB=build-osx + +script: "./.travis/$JOB.sh" deploy: provider: releases @@ -19,4 +28,4 @@ deploy: skip_cleanup: true after_success: -- test $TRAVIS_PULL_REQUEST == "false" && test $TRAVIS_BRANCH == "master" && bash ./.travis/build-docs.sh + - test $TRAVIS_PULL_REQUEST == "false" && test $TRAVIS_BRANCH == "master" && bash ./.travis/deploy-docs.sh diff --git a/.travis/build-docs.sh b/.travis/build-docs.sh old mode 100644 new mode 100755 index 3c47d592f..57d9e1f1d --- a/.travis/build-docs.sh +++ b/.travis/build-docs.sh @@ -15,38 +15,22 @@ # You should have received a copy of the GNU General Public License # along with this program. If not, see . +# Fail out on error +set -eu -o pipefail # Obtain doxygen sudo apt-get install doxygen CONFIG_FILE="doxygen.conf" -CONFIG_FILE_TMP="$CONFIG_FILE.tmp.autogen" GIT_DESC=$(git describe --tags 2> /dev/null) GIT_CHASH=$(git rev-parse HEAD) -# Create temporary config file -cp "$CONFIG_FILE" "$CONFIG_FILE_TMP" - # Append git version to doxygen version string -echo "PROJECT_NUMBER = \"Version: $GIT_DESC | Commit: $GIT_CHASH\"" >> "$CONFIG_FILE_TMP" +echo "PROJECT_NUMBER = \"Version: $GIT_DESC | Commit: $GIT_CHASH\"" >> "$CONFIG_FILE" # Generate documentation echo "Generating documentation..." echo -doxygen "$CONFIG_FILE_TMP" -rm "$CONFIG_FILE_TMP" - -# Push generated doxygen to GitHub pages -cd ./doc/html/ - -git init -git config user.name "Travis CI" -git config user.email "qTox@users.noreply.github.com" - -git add . -git commit -m "Deploy to GH pages from commit: $GIT_CHASH" - -echo "Pushing to GH pages..." -git push --force --quiet "https://${GH_TOKEN}@github.com/qTox/doxygen.git" master:gh-pages &> /dev/null +doxygen "$CONFIG_FILE" diff --git a/.travis/build-osx.sh b/.travis/build-osx.sh new file mode 100755 index 000000000..950efb3f3 --- /dev/null +++ b/.travis/build-osx.sh @@ -0,0 +1,25 @@ +#!/bin/bash +# +# Copyright © 2016 by The qTox Project +# +# This program is libre software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# + +# Fail out on error +set -e -o pipefail + +# Build OSX +bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -i +bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -b +bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -d +# The following line can randomly fail due to travis emitting the error: +# "hdiutil: create failed - Resource busy" +bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -dmg diff --git a/.travis/build-ubuntu_14_04.sh b/.travis/build-ubuntu-14-04.sh similarity index 100% rename from .travis/build-ubuntu_14_04.sh rename to .travis/build-ubuntu-14-04.sh diff --git a/.travis/deploy-docs.sh b/.travis/deploy-docs.sh new file mode 100755 index 000000000..0fdccded1 --- /dev/null +++ b/.travis/deploy-docs.sh @@ -0,0 +1,43 @@ +#!/bin/bash +# +# Copyright © 2016 by The qTox Project +# +# This program is libre software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . + +# Fail out on error +set -eu -o pipefail + +DOCS_FOLDER="./doc/html" + +# Ensure docs exists +if [ ! -d "$DOCS_FOLDER" ] +then + exit 1 +fi + +# Obtain git commit hash from HEAD +GIT_CHASH=$(git rev-parse HEAD) + +# Push generated doxygen to GitHub pages +cd "$DOCS_FOLDER" + +git --quiet init +git config user.name "Travis CI" +git config user.email "qTox@users.noreply.github.com" + +git add . +git commit --quiet -m "Deploy to GH pages from commit: $GIT_CHASH" + +echo "Pushing to GH pages..." +git push --force --quiet "https://${GH_TOKEN}@github.com/qTox/doxygen.git" master:gh-pages &> /dev/null diff --git a/.travis/travis.sh b/.travis/travis.sh deleted file mode 100755 index 2b082cb6d..000000000 --- a/.travis/travis.sh +++ /dev/null @@ -1,22 +0,0 @@ -#!/bin/bash -# -# Script that runs all the necessary tests on travis. -# -# Exits as soon as there's a failure in test. - -set -e - -if [[ "$TRAVIS_OS_NAME" == "linux" ]] -then - # osx cannot into extended regexp for grep, thus verify only on Linux - bash ./verify-commit-messages.sh "$TRAVIS_COMMIT_RANGE" - bash ./.travis/build-ubuntu_14_04.sh -elif [[ "$TRAVIS_OS_NAME" == "osx" ]] -then - bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -i - bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -b - bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -d - # The following line can randomly fail due to travis emitting the error: - # "hdiutil: create failed - Resource busy" - bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -dmg -fi diff --git a/.travis/verify-commit-format.sh b/.travis/verify-commit-format.sh new file mode 100755 index 000000000..c419be8a1 --- /dev/null +++ b/.travis/verify-commit-format.sh @@ -0,0 +1,22 @@ +#!/bin/bash +# +# Copyright © 2016 by The qTox Project +# +# This program is libre software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . + +# Fail out on error +set -eu -o pipefail + +# Verify commit messages +bash ./verify-commit-messages.sh "$TRAVIS_COMMIT_RANGE" From 80581aa966f7c3364cf923e2abbcecbee2be1649 Mon Sep 17 00:00:00 2001 From: initramfs Date: Thu, 11 Aug 2016 15:39:14 +0800 Subject: [PATCH 3/4] chore(build): add an error message on failure to deploy documentation --- .travis.yml | 2 +- .travis/deploy-docs.sh | 3 ++- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/.travis.yml b/.travis.yml index dbbdcda7c..ba9fd5e8a 100644 --- a/.travis.yml +++ b/.travis.yml @@ -28,4 +28,4 @@ deploy: skip_cleanup: true after_success: - - test $TRAVIS_PULL_REQUEST == "false" && test $TRAVIS_BRANCH == "master" && bash ./.travis/deploy-docs.sh + - test $TRAVIS_PULL_REQUEST == "false" && test $TRAVIS_BRANCH == "master" && test $JOB == "build-docs" && bash ./.travis/deploy-docs.sh diff --git a/.travis/deploy-docs.sh b/.travis/deploy-docs.sh index 0fdccded1..ee6f38b0d 100755 --- a/.travis/deploy-docs.sh +++ b/.travis/deploy-docs.sh @@ -18,11 +18,12 @@ # Fail out on error set -eu -o pipefail -DOCS_FOLDER="./doc/html" +DOCS_FOLDER="./doc/html/" # Ensure docs exists if [ ! -d "$DOCS_FOLDER" ] then + echo "Docs deploy failing, no $DOCS_DIR present." exit 1 fi From 1f65ecf08ce17f14525224bedf4ea467a1e8a16e Mon Sep 17 00:00:00 2001 From: initramfs Date: Thu, 11 Aug 2016 17:51:53 +0800 Subject: [PATCH 4/4] chore(build): extract documentation build directory from doxygen config --- .travis.yml | 2 +- .travis/build-docs.sh | 7 +++---- .travis/build-osx.sh | 3 +++ .travis/build-ubuntu-14-04.sh | 1 + .travis/deploy-docs.sh | 11 ++++++++--- .travis/verify-commit-format.sh | 1 + 6 files changed, 17 insertions(+), 8 deletions(-) diff --git a/.travis.yml b/.travis.yml index ba9fd5e8a..4ba1625aa 100644 --- a/.travis.yml +++ b/.travis.yml @@ -8,7 +8,7 @@ matrix: - os: linux env: JOB=verify-commit-format - os: linux - env: JOB=build-docs + env: JOB=build-docs DOXYGEN_CONFIG_FILE=doxygen.conf - os: linux env: JOB=build-ubuntu-14-04 - os: osx diff --git a/.travis/build-docs.sh b/.travis/build-docs.sh index 57d9e1f1d..ddf2b87d9 100755 --- a/.travis/build-docs.sh +++ b/.travis/build-docs.sh @@ -14,6 +14,7 @@ # # You should have received a copy of the GNU General Public License # along with this program. If not, see . +# # Fail out on error set -eu -o pipefail @@ -21,16 +22,14 @@ set -eu -o pipefail # Obtain doxygen sudo apt-get install doxygen -CONFIG_FILE="doxygen.conf" - GIT_DESC=$(git describe --tags 2> /dev/null) GIT_CHASH=$(git rev-parse HEAD) # Append git version to doxygen version string -echo "PROJECT_NUMBER = \"Version: $GIT_DESC | Commit: $GIT_CHASH\"" >> "$CONFIG_FILE" +echo "PROJECT_NUMBER = \"Version: $GIT_DESC | Commit: $GIT_CHASH\"" >> "$DOXYGEN_CONFIG_FILE" # Generate documentation echo "Generating documentation..." echo -doxygen "$CONFIG_FILE" +doxygen "$DOXYGEN_CONFIG_FILE" diff --git a/.travis/build-osx.sh b/.travis/build-osx.sh index 950efb3f3..ca4f43a12 100755 --- a/.travis/build-osx.sh +++ b/.travis/build-osx.sh @@ -12,6 +12,9 @@ # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . +# # Fail out on error set -e -o pipefail diff --git a/.travis/build-ubuntu-14-04.sh b/.travis/build-ubuntu-14-04.sh index 30f6a2f94..385f4d013 100755 --- a/.travis/build-ubuntu-14-04.sh +++ b/.travis/build-ubuntu-14-04.sh @@ -14,6 +14,7 @@ # # You should have received a copy of the GNU General Public License # along with this program. If not, see . +# # stop as soon as one of steps will fail set -e -o pipefail diff --git a/.travis/deploy-docs.sh b/.travis/deploy-docs.sh index ee6f38b0d..ac75eac62 100755 --- a/.travis/deploy-docs.sh +++ b/.travis/deploy-docs.sh @@ -14,14 +14,19 @@ # # You should have received a copy of the GNU General Public License # along with this program. If not, see . +# # Fail out on error set -eu -o pipefail -DOCS_FOLDER="./doc/html/" +# Extract html documentation directory from doxygen configuration +OUTPUT_DIR_CFG=( $(grep 'OUTPUT_DIRECTORY' "$DOXYGEN_CONFIG_FILE") ) +HTML_OUTPUT_CFG=( $(grep 'HTML_OUTPUT' "$DOXYGEN_CONFIG_FILE") ) + +DOCS_DIR="./${OUTPUT_DIR_CFG[2]}/${HTML_OUTPUT_CFG[2]}/" # Ensure docs exists -if [ ! -d "$DOCS_FOLDER" ] +if [ ! -d "$DOCS_DIR" ] then echo "Docs deploy failing, no $DOCS_DIR present." exit 1 @@ -31,7 +36,7 @@ fi GIT_CHASH=$(git rev-parse HEAD) # Push generated doxygen to GitHub pages -cd "$DOCS_FOLDER" +cd "$DOCS_DIR" git --quiet init git config user.name "Travis CI" diff --git a/.travis/verify-commit-format.sh b/.travis/verify-commit-format.sh index c419be8a1..86083d883 100755 --- a/.travis/verify-commit-format.sh +++ b/.travis/verify-commit-format.sh @@ -14,6 +14,7 @@ # # You should have received a copy of the GNU General Public License # along with this program. If not, see . +# # Fail out on error set -eu -o pipefail