summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGennadiy Civil <misterg@google.com>2018-09-25 06:42:15 (GMT)
committerGennadiy Civil <misterg@google.com>2018-09-25 06:42:15 (GMT)
commit2d3466be4785560cfc93680e28f9afb92e656665 (patch)
tree581f05fab5ea940469b29169d96becfb7eaf9071
parented6e84ccef7f3c0f31caca60a47077a46d72a806 (diff)
downloadgoogletest-2d3466be4785560cfc93680e28f9afb92e656665.zip
googletest-2d3466be4785560cfc93680e28f9afb92e656665.tar.gz
googletest-2d3466be4785560cfc93680e28f9afb92e656665.tar.bz2
Add clang format check to one of the builds to provide indication that formatting is incorrect
-rw-r--r--.travis.yml4
-rwxr-xr-xci/test-format.sh33
2 files changed, 36 insertions, 1 deletions
diff --git a/.travis.yml b/.travis.yml
index 4ec239f..d1fe6eb 100644
--- a/.travis.yml
+++ b/.travis.yml
@@ -18,8 +18,9 @@ matrix:
- os: linux
compiler: clang
sudo : true
+ env: TEST_CLANG_FORMAT="yes"
install: ./ci/install-linux.sh && ./ci/log-config.sh
- script: ./ci/build-linux-bazel.sh
+ script: ./ci/test_format.sh && ./ci/build-linux-bazel.sh
- os: linux
group: deprecated-2017Q4
compiler: gcc
@@ -65,6 +66,7 @@ addons:
packages:
- g++-4.9
- clang-3.9
+ - clang-format-3.9
notifications:
email: false
diff --git a/ci/test-format.sh b/ci/test-format.sh
new file mode 100755
index 0000000..502c84c
--- /dev/null
+++ b/ci/test-format.sh
@@ -0,0 +1,33 @@
+#!/bin/bash
+echo "clang-format - checking Code Formatting..."
+
+if [[ "${TRAVIS_OS_NAME}" == "linux" ]] && \
+ [[ "${TEST_CLANG_FORMAT}" == "yes" ]]; then
+
+ RETURN=0
+ CLANG_FORMAT="clang-format-3.9"
+
+ which clang-format-3.9
+
+ if [ ! -f ".clang-format" ]; then
+ echo ".clang-format file not found!"
+ exit 1
+ fi
+
+ FILES=`git diff master --name-only | grep -E "\.(cc|cpp|h)$"`
+
+ for FILE in $FILES; do
+
+ $CLANG_FORMAT $FILE | cmp $FILE >/dev/null
+
+ if [ $? -ne 0 ]; then
+ echo "[!] Clang-Format Found INCORRECT FORMATTING. Please re-format and re-submit. The following file failed: $FILE" >&2
+ RETURN=1
+ fi
+
+ done
+
+ exit $RETURN
+fi
+
+exit 0