 36b59c001c
			
		
	
	36b59c001c
	
	
	
		
			
			There is a wide variety of tracing options through the various shell
scripts.  Some use "set -eux", others explicity set xtrace and others
do nothing.  There is a "-x" option to bin/disk-image-create but it
doesn't flow down to the many scripts it calls.
This adds a global integer variable set by disk-image-create
DIB_DEBUG_TRACE.  All scripts have a stanza added to detect this and
turn on tracing.  Any other tracing methods are rolled into this.  So
the standard header is
---
if [ "${DIB_DEBUG_TRACE:-0}" -gt 0 ]; then
    set -x
fi
set -eu
set -o pipefail
---
Multiple -x options can be specified to dib-create-image, which
increases the value of DIB_DEBUG_TRACE.  If script authors feel their
script should only trace at higher levels, they should modify the
"-gt" value.  If they feel it should trace by default, they can modify
the default value also.
Changes to pachset 16 : scripts which currently trace themselves by
default have retained this behaviour with DIB_DEBUG_TRACE defaulting
to "1".  This was done by running [1] on patch set 15.  See the thread
beginning at [2]
dib-lint is also updated to look for the variable being matched.
[1] https://gist.github.com/ianw/71bbda9e6acc74ccd0fd
[2] http://lists.openstack.org/pipermail/openstack-dev/2014-November/051575.html
Change-Id: I6c5a962260741dcf6f89da9a33b96372a719b7b0
		
	
		
			
				
	
	
		
			146 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			146 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/bash
 | |
| 
 | |
| # Copyright 2014 Red Hat, Inc.
 | |
| #
 | |
| # 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.
 | |
| 
 | |
| # This script checks all files in the "elements" directory for some
 | |
| # common mistakes and exits with a non-zero status if it finds any.
 | |
| 
 | |
| set -eu
 | |
| set -o pipefail
 | |
| 
 | |
| parse_exclusions() {
 | |
|     # Per-file exclusions
 | |
|     # Example: # dib-lint: disable=sete setpipefail
 | |
|     local filename=$1
 | |
|     local disable_pattern="# dib-lint: disable="
 | |
|     local exclusions=$(grep "^$disable_pattern.*$" $filename | sed "s/$disable_pattern//g")
 | |
| 
 | |
|     # Global exclusions read from tox.ini
 | |
|     # Example section in tox.ini:
 | |
|     #   [dib-lint]
 | |
|     #   ignore = sete setu
 | |
|     section="dib-lint"
 | |
|     option="ignore"
 | |
|     global_exclusions=$(python -c \
 | |
|         "import ConfigParser; \
 | |
|         conf=ConfigParser.ConfigParser(); \
 | |
|         conf.read('tox.ini'); \
 | |
|         print conf.get('$section', '$option') if conf.has_option('$section', '$option') else ''"
 | |
|     )
 | |
|     echo $exclusions $global_exclusions
 | |
| }
 | |
| 
 | |
| excluded() {
 | |
|     local test_name=$1
 | |
|     for e in $exclusions; do
 | |
|         if [ "$e" = "$test_name" ]; then
 | |
|             return 0
 | |
|         fi
 | |
|     done
 | |
|     return 1
 | |
| }
 | |
| 
 | |
| error() {
 | |
|     echo "ERROR: $1"
 | |
|     rc=1
 | |
| }
 | |
| 
 | |
| rc=0
 | |
| TMPDIR=$(mktemp -d)
 | |
| trap "rm -rf $TMPDIR" EXIT
 | |
| for i in $(find elements -type f); do
 | |
|     exclusions=("$(parse_exclusions $i)")
 | |
|     # Check that files starting with a shebang are +x
 | |
|     firstline=$(head -n 1 "$i")
 | |
|     if [ "${firstline:0:2}" = "#!" ]; then
 | |
|         if [ ! -x "$i" ] && ! excluded executable; then
 | |
|             error "$i is not executable"
 | |
|         fi
 | |
| 
 | |
|         # Ensure 4 spaces indent are used
 | |
| 
 | |
|         if [ "$(file -b --mime-type $i)" = "text/x-python" ]; then
 | |
|             flake8 $i
 | |
|         else
 | |
|             if ! excluded indent ; then
 | |
|                 if grep -q "^ \{4\}* \{1,3\}[^ ]" ${i}; then
 | |
|                     error "$i should use 4 spaces indent"
 | |
|                 fi
 | |
|             fi
 | |
|         fi
 | |
|     fi
 | |
| 
 | |
|     # Check alphabetical ordering of element-deps
 | |
|     if [ $(basename $i) = "element-deps" ]; then
 | |
|         UNSORTED=${TMPDIR}/element-deps.unsorted
 | |
|         SORTED=${TMPDIR}/element-deps.sorted
 | |
|         grep -v '^#' $i > ${UNSORTED}
 | |
|         sort ${UNSORTED} > ${SORTED}
 | |
|         if [ -n "$(diff -c ${UNSORTED} ${SORTED})" ]; then
 | |
|             error "$i is not sorted alphabetically"
 | |
|         fi
 | |
|     fi
 | |
| 
 | |
|     # Check that all scripts are set -eu -o pipefail and look for
 | |
|     # DIB_DEBUG_TRACE
 | |
|     # NOTE(bnemec): This doesn't verify that the set call occurs high
 | |
|     # enough in the file to be useful, but hopefully nobody will be
 | |
|     # sticking set calls at the end of their file to trick us.  And if
 | |
|     # they are, that's easy enough to catch in reviews.
 | |
|     # Also, this is only going to check bash scripts - we've decided to
 | |
|     # explicitly require bash for any scripts that don't have a specific
 | |
|     # need to run under other shells, and any exceptions to that rule
 | |
|     # may not want these checks either.
 | |
|     if [ -n "$(echo $firstline | grep '#!/bin/bash')" ]; then
 | |
|         if ! excluded sete; then
 | |
|             if [ -z "$(grep "^set -[^ ]*e" $i)" ]; then
 | |
|                 error "$i is not set -e"
 | |
|             fi
 | |
|         fi
 | |
|         if ! excluded setu; then
 | |
|             if [ -z "$(grep "^set -[^ ]*u" $i)" ]; then
 | |
|                 error "$i is not set -u"
 | |
|             fi
 | |
|         fi
 | |
|         if ! excluded setpipefail; then
 | |
|             if [ -z "$(grep "^set -o pipefail" $i)" ]; then
 | |
|                 error "$i is not set -o pipefail"
 | |
|             fi
 | |
|         fi
 | |
|         if ! excluded dibdebugtrace; then
 | |
|             if [ -z "$(grep "DIB_DEBUG_TRACE" $i)" ]; then
 | |
|                 error "$i does not follow DIB_DEBUG_TRACE"
 | |
|             fi
 | |
|         fi
 | |
|     fi
 | |
| done
 | |
| 
 | |
| for i in $(find elements -type f -and -name '*.md' -or -type f -executable); do
 | |
|     # Check for tab indentation
 | |
|     if ! excluded tabindent; then
 | |
|         if grep -q $'^ *\t' ${i}; then
 | |
|             error "$i contains tab characters"
 | |
|         fi
 | |
|     fi
 | |
| 
 | |
|     if ! excluded newline; then
 | |
|         if [ "$(tail -c 1 $i)" != "" ]; then
 | |
|             error "No newline at end of file: $i"
 | |
|         fi
 | |
|     fi
 | |
| done
 | |
| exit $rc
 |