Enable bashate during pep8 run
bashate checks shell script syntax (similar to pep8 for python). Fix currently available scripts and enable the check for the scripts. Change-Id: I33dc8c44a58f40e8bca9e29cd717caf46e5cd586
This commit is contained in:
		| @@ -57,13 +57,13 @@ for CG in ${CONFIG_GROUPS//,/ }; do | ||||
|         WITH_SHARE_SERVER_HANDLING_MODES=$((WITH_SHARE_SERVER_HANDLING_MODES+1)) | ||||
|     else | ||||
|         echo "Config option 'driver_handles_share_servers' either is not defined or \ | ||||
|               defined with improper value - '$DRIVER_HANDLES_SHARE_SERVERS'." | ||||
|             defined with improper value - '$DRIVER_HANDLES_SHARE_SERVERS'." | ||||
|         exit 1 | ||||
|     fi | ||||
| done | ||||
|  | ||||
| if [[ $NO_SHARE_SERVER_HANDLING_MODES -ge 1 && $WITH_SHARE_SERVER_HANDLING_MODES -ge 1 || \ | ||||
|       $NO_SHARE_SERVER_HANDLING_MODES -eq 0 && $WITH_SHARE_SERVER_HANDLING_MODES -eq 0 ]]; then | ||||
|     $NO_SHARE_SERVER_HANDLING_MODES -eq 0 && $WITH_SHARE_SERVER_HANDLING_MODES -eq 0 ]]; then | ||||
|     echo 'Allowed only same driver modes for all backends to be run with Tempest job.' | ||||
|     exit 1 | ||||
| elif [[ $NO_SHARE_SERVER_HANDLING_MODES -ge 1 ]]; then | ||||
|   | ||||
| @@ -99,7 +99,8 @@ DEPRECATED_TEXT="$DEPRECATED_TEXT\n'MANILA_MULTI_BACKEND' is deprecated, | ||||
|     Use 'MANILA_ENABLED_BACKENDS' instead if you want to use custom setting. | ||||
|     Set there a list of back end names to be enabled.\n | ||||
|     To configure custom back ends use (any opt in any group can be set in this way) following: | ||||
|     MANILA_OPTGROUP_foo_bar=value, where 'foo' is name of config group and 'bar' is name of option.\n" | ||||
|     MANILA_OPTGROUP_foo_bar=value | ||||
|     where 'foo' is name of config group and 'bar' is name of option.\n" | ||||
|  | ||||
| # First share backend data, that will be used in any installation | ||||
| MANILA_BACKEND1_CONFIG_GROUP_NAME=${MANILA_BACKEND1_CONFIG_GROUP_NAME:-generic1}  # deprecated | ||||
|   | ||||
							
								
								
									
										299
									
								
								run_tests.sh
									
									
									
									
									
								
							
							
						
						
									
										299
									
								
								run_tests.sh
									
									
									
									
									
								
							| @@ -3,75 +3,75 @@ | ||||
| set -eu | ||||
|  | ||||
| function usage { | ||||
|   echo "Usage: $0 [OPTION]..." | ||||
|   echo "Run Manila's test suite(s)" | ||||
|   echo "" | ||||
|   echo "  -V, --virtual-env           Always use virtualenv.  Install automatically if not present" | ||||
|   echo "  -N, --no-virtual-env        Don't use virtualenv.  Run tests in local environment" | ||||
|   echo "  -s, --no-site-packages      Isolate the virtualenv from the global Python environment" | ||||
|   echo "  -r, --recreate-db           Recreate the test database (deprecated, as this is now the default)." | ||||
|   echo "  -n, --no-recreate-db        Don't recreate the test database." | ||||
|   echo "  -f, --force                 Force a clean re-build of the virtual environment. Useful when dependencies have been added." | ||||
|   echo "  -u, --update                Update the virtual environment with any     newer package versions" | ||||
|   echo "  -p, --pep8                  Just run PEP8 and HACKING compliance check" | ||||
|   echo "  -P, --no-pep8               Don't run static code checks" | ||||
|   echo "  -c, --coverage              Generate coverage report" | ||||
|   echo "  -d, --debug                 Run tests with testtools instead of testr. This allows you to use the debugger." | ||||
|   echo "  -h, --help                  Print this usage message" | ||||
|   echo "  --hide-elapsed              Don't print the elapsed time for each test along with slow test list" | ||||
|   echo "  --virtual-env-path <path>   Location of the virtualenv directory." | ||||
|   echo "                                  Default: \$(pwd)" | ||||
|   echo "  --virtual-env-name <name>   Name of the virtualenv directory." | ||||
|   echo "                                  Default: .venv" | ||||
|   echo "  --tools-path <dir>          Location of the tools directory." | ||||
|   echo "                                  Default: \$(pwd)" | ||||
|   echo "  --concurrency <concurrency> How many processes to use when running the tests." | ||||
|   echo "                                  A value of 0 autodetects concurrency from your CPU count." | ||||
|   echo "                                  Default: 1" | ||||
|   echo "" | ||||
|   echo "Note: with no options specified, the script will try to run the tests in a virtual environment," | ||||
|   echo "      If no virtualenv is found, the script will ask if you would like to create one.  If you " | ||||
|   echo "      prefer to run tests NOT in a virtual environment, simply pass the -N option." | ||||
|   exit | ||||
|     echo "Usage: $0 [OPTION]..." | ||||
|     echo "Run Manila's test suite(s)" | ||||
|     echo "" | ||||
|     echo "  -V, --virtual-env           Always use virtualenv.  Install automatically if not present" | ||||
|     echo "  -N, --no-virtual-env        Don't use virtualenv.  Run tests in local environment" | ||||
|     echo "  -s, --no-site-packages      Isolate the virtualenv from the global Python environment" | ||||
|     echo "  -r, --recreate-db           Recreate the test database (deprecated, as this is now the default)." | ||||
|     echo "  -n, --no-recreate-db        Don't recreate the test database." | ||||
|     echo "  -f, --force                 Force a clean re-build of the virtual environment. Useful when dependencies have been added." | ||||
|     echo "  -u, --update                Update the virtual environment with any     newer package versions" | ||||
|     echo "  -p, --pep8                  Just run PEP8 and HACKING compliance check" | ||||
|     echo "  -P, --no-pep8               Don't run static code checks" | ||||
|     echo "  -c, --coverage              Generate coverage report" | ||||
|     echo "  -d, --debug                 Run tests with testtools instead of testr. This allows you to use the debugger." | ||||
|     echo "  -h, --help                  Print this usage message" | ||||
|     echo "  --hide-elapsed              Don't print the elapsed time for each test along with slow test list" | ||||
|     echo "  --virtual-env-path <path>   Location of the virtualenv directory." | ||||
|     echo "                                  Default: \$(pwd)" | ||||
|     echo "  --virtual-env-name <name>   Name of the virtualenv directory." | ||||
|     echo "                                  Default: .venv" | ||||
|     echo "  --tools-path <dir>          Location of the tools directory." | ||||
|     echo "                                  Default: \$(pwd)" | ||||
|     echo "  --concurrency <concurrency> How many processes to use when running the tests." | ||||
|     echo "                                  A value of 0 autodetects concurrency from your CPU count." | ||||
|     echo "                                  Default: 1" | ||||
|     echo "" | ||||
|     echo "Note: with no options specified, the script will try to run the tests in a virtual environment," | ||||
|     echo "      If no virtualenv is found, the script will ask if you would like to create one.  If you " | ||||
|     echo "      prefer to run tests NOT in a virtual environment, simply pass the -N option." | ||||
|     exit | ||||
| } | ||||
|  | ||||
| function process_options { | ||||
|   i=1 | ||||
|   while [ $i -le $# ]; do | ||||
|     case "${!i}" in | ||||
|       -h|--help) usage;; | ||||
|       -V|--virtual-env) always_venv=1; never_venv=0;; | ||||
|       -N|--no-virtual-env) always_venv=0; never_venv=1;; | ||||
|       -s|--no-site-packages) no_site_packages=1;; | ||||
|       -r|--recreate-db) recreate_db=1;; | ||||
|       -n|--no-recreate-db) recreate_db=0;; | ||||
|       -f|--force) force=1;; | ||||
|       -u|--update) update=1;; | ||||
|       -p|--pep8) just_pep8=1;; | ||||
|       -P|--no-pep8) no_pep8=1;; | ||||
|       -c|--coverage) coverage=1;; | ||||
|       -d|--debug) debug=1;; | ||||
|       --virtual-env-path) | ||||
|     i=1 | ||||
|     while [ $i -le $# ]; do | ||||
|         case "${!i}" in | ||||
|             -h|--help) usage;; | ||||
|             -V|--virtual-env) always_venv=1; never_venv=0;; | ||||
|             -N|--no-virtual-env) always_venv=0; never_venv=1;; | ||||
|             -s|--no-site-packages) no_site_packages=1;; | ||||
|             -r|--recreate-db) recreate_db=1;; | ||||
|             -n|--no-recreate-db) recreate_db=0;; | ||||
|             -f|--force) force=1;; | ||||
|             -u|--update) update=1;; | ||||
|             -p|--pep8) just_pep8=1;; | ||||
|             -P|--no-pep8) no_pep8=1;; | ||||
|             -c|--coverage) coverage=1;; | ||||
|             -d|--debug) debug=1;; | ||||
|             --virtual-env-path) | ||||
|                 (( i++ )) | ||||
|                 venv_path=${!i} | ||||
|                 ;; | ||||
|             --virtual-env-name) | ||||
|                 (( i++ )) | ||||
|                 venv_dir=${!i} | ||||
|                 ;; | ||||
|             --tools-path) | ||||
|                 (( i++ )) | ||||
|                 tools_path=${!i} | ||||
|                 ;; | ||||
|             --concurrency) | ||||
|                 (( i++ )) | ||||
|                 concurrency=${!i} | ||||
|                 ;; | ||||
|             -*) testropts="$testropts ${!i}";; | ||||
|             *) testrargs="$testrargs ${!i}" | ||||
|         esac | ||||
|         (( i++ )) | ||||
|         venv_path=${!i} | ||||
|         ;; | ||||
|       --virtual-env-name) | ||||
|         (( i++ )) | ||||
|         venv_dir=${!i} | ||||
|         ;; | ||||
|       --tools-path) | ||||
|         (( i++ )) | ||||
|         tools_path=${!i} | ||||
|         ;; | ||||
|       --concurrency) | ||||
|         (( i++ )) | ||||
|         concurrency=${!i} | ||||
|         ;; | ||||
|       -*) testropts="$testropts ${!i}";; | ||||
|       *) testrargs="$testrargs ${!i}" | ||||
|     esac | ||||
|     (( i++ )) | ||||
|   done | ||||
|     done | ||||
| } | ||||
|  | ||||
| tool_path=${tools_path:-$(pwd)} | ||||
| @@ -103,113 +103,110 @@ export tools_dir | ||||
| export venv=${venv_path}/${venv_dir} | ||||
|  | ||||
| if [ $no_site_packages -eq 1 ]; then | ||||
|   installvenvopts="--no-site-packages" | ||||
|     installvenvopts="--no-site-packages" | ||||
| fi | ||||
|  | ||||
| function init_testr { | ||||
|   if [ ! -d .testrepository ]; then | ||||
|     ${wrapper} testr init | ||||
|   fi | ||||
|     if [ ! -d .testrepository ]; then | ||||
|         ${wrapper} testr init | ||||
|     fi | ||||
| } | ||||
|  | ||||
| function run_tests { | ||||
|   # Cleanup *pyc | ||||
|   ${wrapper} find . -type f -name "*.pyc" -delete | ||||
|     # Cleanup *pyc | ||||
|     ${wrapper} find . -type f -name "*.pyc" -delete | ||||
|  | ||||
|   if [ $debug -eq 1 ]; then | ||||
|     if [ "$testropts" = "" ] && [ "$testrargs" = "" ]; then | ||||
|       # Default to running all tests if specific test is not | ||||
|       # provided. | ||||
|       testrargs="discover ./manila/tests" | ||||
|     if [ $debug -eq 1 ]; then | ||||
|         if [ "$testropts" = "" ] && [ "$testrargs" = "" ]; then | ||||
|             # Default to running all tests if specific test is not | ||||
|             # provided. | ||||
|             testrargs="discover ./manila/tests" | ||||
|         fi | ||||
|         ${wrapper} python -m testtools.run $testropts $testrargs | ||||
|  | ||||
|         # Short circuit because all of the testr and coverage stuff | ||||
|         # below does not make sense when running testtools.run for | ||||
|         # debugging purposes. | ||||
|         return $? | ||||
|     fi | ||||
|     ${wrapper} python -m testtools.run $testropts $testrargs | ||||
|  | ||||
|     # Short circuit because all of the testr and coverage stuff | ||||
|     # below does not make sense when running testtools.run for | ||||
|     # debugging purposes. | ||||
|     return $? | ||||
|   fi | ||||
|     if [ $coverage -eq 1 ]; then | ||||
|         TESTRTESTS="$TESTRTESTS --coverage" | ||||
|     else | ||||
|         TESTRTESTS="$TESTRTESTS" | ||||
|     fi | ||||
|  | ||||
|   if [ $coverage -eq 1 ]; then | ||||
|     TESTRTESTS="$TESTRTESTS --coverage" | ||||
|   else | ||||
|     TESTRTESTS="$TESTRTESTS" | ||||
|   fi | ||||
|     # Just run the test suites in current environment | ||||
|     set +e | ||||
|     testrargs=`echo "$testrargs" | sed -e's/^\s*\(.*\)\s*$/\1/'` | ||||
|     TESTRTESTS="$TESTRTESTS --testr-args='--subunit --concurrency $concurrency $testropts $testrargs'" | ||||
|     if [ setup.cfg -nt manila.egg-info/entry_points.txt ]; then | ||||
|         ${wrapper} python setup.py egg_info | ||||
|     fi | ||||
|     echo "Running \`${wrapper} $TESTRTESTS\`" | ||||
|     if ${wrapper} which subunit-2to1 2>&1 > /dev/null; then | ||||
|         # subunit-2to1 is present, testr subunit stream should be in version 2 | ||||
|         # format. Convert to version one before colorizing. | ||||
|         bash -c "${wrapper} $TESTRTESTS | ${wrapper} subunit-2to1 | ${wrapper} tools/colorizer.py" | ||||
|     else | ||||
|         bash -c "${wrapper} $TESTRTESTS | ${wrapper} tools/colorizer.py" | ||||
|     fi | ||||
|     RESULT=$? | ||||
|     set -e | ||||
|  | ||||
|   # Just run the test suites in current environment | ||||
|   set +e | ||||
|   testrargs=`echo "$testrargs" | sed -e's/^\s*\(.*\)\s*$/\1/'` | ||||
|   TESTRTESTS="$TESTRTESTS --testr-args='--subunit --concurrency $concurrency $testropts $testrargs'" | ||||
|   if [ setup.cfg -nt manila.egg-info/entry_points.txt ] | ||||
|   then | ||||
|     ${wrapper} python setup.py egg_info | ||||
|   fi | ||||
|   echo "Running \`${wrapper} $TESTRTESTS\`" | ||||
|   if ${wrapper} which subunit-2to1 2>&1 > /dev/null | ||||
|   then | ||||
|     # subunit-2to1 is present, testr subunit stream should be in version 2 | ||||
|     # format. Convert to version one before colorizing. | ||||
|     bash -c "${wrapper} $TESTRTESTS | ${wrapper} subunit-2to1 | ${wrapper} tools/colorizer.py" | ||||
|   else | ||||
|     bash -c "${wrapper} $TESTRTESTS | ${wrapper} tools/colorizer.py" | ||||
|   fi | ||||
|   RESULT=$? | ||||
|   set -e | ||||
|     copy_subunit_log | ||||
|  | ||||
|   copy_subunit_log | ||||
|     if [ $coverage -eq 1 ]; then | ||||
|         echo "Generating coverage report in covhtml/" | ||||
|         # Don't compute coverage for common code, which is tested elsewhere | ||||
|         ${wrapper} coverage combine | ||||
|         ${wrapper} coverage html --include='manila/*' --omit='manila/openstack/common/*' -d covhtml -i | ||||
|     fi | ||||
|  | ||||
|   if [ $coverage -eq 1 ]; then | ||||
|     echo "Generating coverage report in covhtml/" | ||||
|     # Don't compute coverage for common code, which is tested elsewhere | ||||
|     ${wrapper} coverage combine | ||||
|     ${wrapper} coverage html --include='manila/*' --omit='manila/openstack/common/*' -d covhtml -i | ||||
|   fi | ||||
|  | ||||
|   return $RESULT | ||||
|     return $RESULT | ||||
| } | ||||
|  | ||||
| function copy_subunit_log { | ||||
|   LOGNAME=`cat .testrepository/next-stream` | ||||
|   LOGNAME=$(($LOGNAME - 1)) | ||||
|   LOGNAME=".testrepository/${LOGNAME}" | ||||
|   cp $LOGNAME subunit.log | ||||
|     LOGNAME=`cat .testrepository/next-stream` | ||||
|     LOGNAME=$(($LOGNAME - 1)) | ||||
|     LOGNAME=".testrepository/${LOGNAME}" | ||||
|     cp $LOGNAME subunit.log | ||||
| } | ||||
|  | ||||
| function run_pep8 { | ||||
|   echo "Running flake8..." | ||||
|   bash -c "${wrapper} flake8" | ||||
|     echo "Running flake8..." | ||||
|     bash -c "${wrapper} flake8" | ||||
| } | ||||
|  | ||||
| TESTRTESTS="python setup.py testr" | ||||
|  | ||||
| if [ $never_venv -eq 0 ] | ||||
| then | ||||
|   # Remove the virtual environment if --force used | ||||
|   if [ $force -eq 1 ]; then | ||||
|     echo "Cleaning virtualenv..." | ||||
|     rm -rf ${venv} | ||||
|   fi | ||||
|   if [ $update -eq 1 ]; then | ||||
|       echo "Updating virtualenv..." | ||||
|       python tools/install_venv.py $installvenvopts | ||||
|   fi | ||||
|   if [ -e ${venv} ]; then | ||||
|     wrapper="${with_venv}" | ||||
|   else | ||||
|     if [ $always_venv -eq 1 ]; then | ||||
|       # Automatically install the virtualenv | ||||
|       python tools/install_venv.py $installvenvopts | ||||
|       wrapper="${with_venv}" | ||||
|     else | ||||
|       echo -e "No virtual environment found...create one? (Y/n) \c" | ||||
|       read use_ve | ||||
|       if [ "x$use_ve" = "xY" -o "x$use_ve" = "x" -o "x$use_ve" = "xy" ]; then | ||||
|         # Install the virtualenv and run the test suite in it | ||||
|         python tools/install_venv.py $installvenvopts | ||||
|         wrapper=${with_venv} | ||||
|       fi | ||||
| if [ $never_venv -eq 0 ]; then | ||||
|     # Remove the virtual environment if --force used | ||||
|     if [ $force -eq 1 ]; then | ||||
|         echo "Cleaning virtualenv..." | ||||
|         rm -rf ${venv} | ||||
|     fi | ||||
|     if [ $update -eq 1 ]; then | ||||
|         echo "Updating virtualenv..." | ||||
|         python tools/install_venv.py $installvenvopts | ||||
|     fi | ||||
|     if [ -e ${venv} ]; then | ||||
|         wrapper="${with_venv}" | ||||
|     else | ||||
|         if [ $always_venv -eq 1 ]; then | ||||
|             # Automatically install the virtualenv | ||||
|             python tools/install_venv.py $installvenvopts | ||||
|             wrapper="${with_venv}" | ||||
|         else | ||||
|             echo -e "No virtual environment found...create one? (Y/n) \c" | ||||
|             read use_ve | ||||
|             if [ "x$use_ve" = "xY" -o "x$use_ve" = "x" -o "x$use_ve" = "xy" ]; then | ||||
|                 # Install the virtualenv and run the test suite in it | ||||
|                 python tools/install_venv.py $installvenvopts | ||||
|                 wrapper=${with_venv} | ||||
|             fi | ||||
|         fi | ||||
|     fi | ||||
|   fi | ||||
| fi | ||||
|  | ||||
| # Delete old coverage data from previous runs | ||||
| @@ -234,7 +231,7 @@ run_tests | ||||
| # distinguish between options (testropts), which begin with a '-', and | ||||
| # arguments (testrargs). | ||||
| if [ -z "$testrargs" ]; then | ||||
|   if [ $no_pep8 -eq 0 ]; then | ||||
|     run_pep8 | ||||
|   fi | ||||
|     if [ $no_pep8 -eq 0 ]; then | ||||
|         run_pep8 | ||||
|     fi | ||||
| fi | ||||
|   | ||||
| @@ -5,6 +5,7 @@ | ||||
| # hacking should be first | ||||
| hacking>=0.9.2,<0.10 | ||||
|  | ||||
| bashate>=0.2  # Apache-2.0 | ||||
| coverage>=3.6 | ||||
| ddt>=0.4.0 | ||||
| discover | ||||
|   | ||||
							
								
								
									
										9
									
								
								tox.ini
									
									
									
									
									
								
							
							
						
						
									
										9
									
								
								tox.ini
									
									
									
									
									
								
							| @@ -18,6 +18,15 @@ downloadcache = ~/cache/pip | ||||
| commands = | ||||
|   flake8 {posargs} | ||||
|   flake8 --filename=manila* bin | ||||
|   # Run bashate during pep8 runs to ensure violations are caught by | ||||
|   # the check and gate queues. | ||||
|   bashate tools/enable-pre-commit-hook.sh \ | ||||
|          contrib/ci/pre_test_hook.sh \ | ||||
|          contrib/ci/post_test_hook.sh \ | ||||
|          contrib/ci/multi_backend/pre_test_hook.sh \ | ||||
|          contrib/ci/multi_backend/post_test_hook.sh \ | ||||
|          devstack/plugin.sh \ | ||||
|          run_tests.sh | ||||
|  | ||||
| [testenv:genconfig] | ||||
| whitelist_externals = bash | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Thomas Bechtold
					Thomas Bechtold