summaryrefslogtreecommitdiff
path: root/tools/misc-sanity-checks.sh
diff options
context:
space:
mode:
authorarmando-migliaccio <armamig@gmail.com>2014-12-22 13:02:14 -0800
committerarmando-migliaccio <armamig@gmail.com>2014-12-23 16:25:06 -0800
commit4fdda65a5b9f379af997e1e971865ccfa7a93156 (patch)
tree09017c7f5d30ff38c7bbb937ebf8ce02f05d6645 /tools/misc-sanity-checks.sh
parent481d366298c83733f2bb6e897015bc2a382ff73b (diff)
downloadneutron-4fdda65a5b9f379af997e1e971865ccfa7a93156.tar.gz
Clean-up sanity checks done via shell scripts
Move the various checks done via shell into a single file; this is cleaner and we'll have a lot more space to explain what is going on. Related-bug: #1404605 Change-Id: Ibb451c6a25217f37b73983c30891f55b35f143cd
Diffstat (limited to 'tools/misc-sanity-checks.sh')
-rw-r--r--tools/misc-sanity-checks.sh71
1 files changed, 71 insertions, 0 deletions
diff --git a/tools/misc-sanity-checks.sh b/tools/misc-sanity-checks.sh
new file mode 100644
index 0000000000..49991457b7
--- /dev/null
+++ b/tools/misc-sanity-checks.sh
@@ -0,0 +1,71 @@
+#! /bin/sh
+
+# Copyright (C) 2014 VA Linux Systems Japan K.K.
+# Copyright (C) 2014 YAMAMOTO Takashi <yamamoto at valinux co jp>
+# All Rights Reserved.
+#
+# Licensed under the Apache License, Version 2.0 (the "License"); you may
+# not use this file except in compliance with the License. You may obtain
+# a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations
+# under the License.
+
+# The purpose of this script is to avoid casual introduction of more
+# bash dependency. Please consider alternatives before commiting code
+# which uses bash specific features.
+
+export TMPDIR=`/bin/mktemp -d`
+trap "rm -rf $TMPDIR" EXIT
+
+FAILURES=$TMPDIR/failures
+
+
+check_opinionated_shell () {
+ # Check that shell scripts are not bash opinionated (ignore comments though)
+ # If you cannot avoid the use of bash, please change the EXPECTED var below.
+ OBSERVED=$(grep -E '^([^#]|#!).*bash' tox.ini tools/* | wc -l)
+ EXPECTED=5
+ if [ ${EXPECTED} -ne ${OBSERVED} ]; then
+ echo "Bash usage has been detected!" >>$FAILURES
+ fi
+}
+
+
+check_no_symlinks_allowed () {
+ # Symlinks break the package build process, so ensure that they
+ # do not slip in, except hidden symlinks.
+ if [ $(find . -type l ! -path '*/\.*' | wc -l) -ge 1 ]; then
+ echo "Symlinks are not allowed!" >>$FAILURES
+ fi
+}
+
+
+check_pot_files_errors () {
+ # The job neutron-propose-translation-update does not update from
+ # transifex since our po files contain duplicate entries where
+ # obsolete entries duplicate normal entries. Prevent obsolete
+ # entries to slip in
+ find neutron -type f -regex '.*\.pot?' \
+ -print0|xargs -0 -n 1 msgfmt --check-format \
+ -o /dev/null
+ if [ "$?" -ne 0 ]; then
+ echo "PO files syntax is not correct!" >>$FAILURES
+ fi
+}
+
+# Add your checks here...
+check_opinionated_shell
+check_no_symlinks_allowed
+check_pot_files_errors
+
+# Fail, if there are emitted failures
+if [ -f $FAILURES ]; then
+ cat $FAILURES
+ exit 1
+fi