add debug flag to tcup

Change-Id: I79a2019b47d2f138cd7fd3a4f26d137ab2f31c40

Change-Id: Id4ae3b8b904cd4a0f2b78a0631f2b7b958974ff1
This commit is contained in:
Rob Hirschfeld 2014-04-04 12:55:09 -05:00
parent f49642de75
commit 3f4311be67
2 changed files with 35 additions and 27 deletions

View File

@ -9,7 +9,13 @@ The following instructions are designs run Refstack/Tempest in a container with
1. Install Docker using [[https://www.docker.io/gettingstarted/#h_installation]] 1. Install Docker using [[https://www.docker.io/gettingstarted/#h_installation]]
1. Note: if you are in an environment with a proxy, make sure you configure `/etc/default/docker` to leverage the proxy too! 1. Note: if you are in an environment with a proxy, make sure you configure `/etc/default/docker` to leverage the proxy too!
1. You may want to prep-the environment using 1. You may want to prep-the environment using `sudo docker pull ubuntu:13.10`
1. Setup Docker to run without sudo
1. permanently (recommended):
1. `sudo usermod -a -G docker <your-user>`
1. you will need to reboot after this change
1. short term: `sudo chmod 666 /var/run/docker.sock`
1. Get the code: `wget https://raw.githubusercontent.com/stackforge/refstack/master/scripts/tcup.py` 1. Get the code: `wget https://raw.githubusercontent.com/stackforge/refstack/master/scripts/tcup.py`
1. note: you can also get the code by cloning the Refstack and running the code in `/scripts/tcup.py` 1. note: you can also get the code by cloning the Refstack and running the code in `/scripts/tcup.py`
@ -17,37 +23,33 @@ The following instructions are designs run Refstack/Tempest in a container with
1. Set your environment variables to access the test target cloud 1. Set your environment variables to access the test target cloud
1. generally, you will `source openrc.sh` to load the cloud credentials and URLs 1. generally, you will `source openrc.sh` to load the cloud credentials and URLs
1. Run TCUP: `sudo python tcup.py` 1. Run TCUP: `python tcup.py`
1. if you want to work on the code from Refstack, use `sudo python scripts/tcup.py' 1. if you want to work on the code from Refstack, use `scripts/tcup.py'
## Trouble Shooting TCUP ## Troubleshooting TCUP
There are several ways to trouble shoot, TCUP. There are several ways to trouble shoot, TCUP.
1. Enter your docker container using `run -i -t [image id from tcup.py] /bin/bash ` 1. Run TCUP using the debug flag: `tcup.py --debug`
1. Check your environment variables include the OS_* values using `export` 1. Attach to the container as instructed at the end of the TCUP script
1. Make sure you can access Keystone using `curl $OS_AUTH_URL` 1. Inside the container:
1. Make sure your credentials are working using `keystone catalog` 1. Check your environment variables include the OS_* values using `export`
1. `Export DEBUG=true` to turn on additional logging and force TCUP into manual run mode 1. Make sure you can access Keystone using `curl $OS_AUTH_URL`
1. Make sure your credentials are working using `keystone catalog`
## Docker Tips ## Docker Tips
1. You can run Docker without sudo!
1. `sudo usermod -a -G docker <your-user>` (to permanently run Docker
without sudo)
1. you will need to reboot after this change (but you can wait until we tell you to reboot later)
1. if you don't want this to be permanent or active before the reboot use, `sudo chmod 666 /var/run/docker.sock`
1. You can inspect which containers are running! 1. You can inspect which containers are running!
1. `sudo docker ps` shows the running containers 1. `docker ps` shows the running containers
1. `sudo docker attach` allows you to connect to a container (may have to press enter) 1. `docker attach` allows you to connect to a container (may have to press enter)
1. exit from inside the container with `Ctrl-p` + `Ctrl-q` 1. exit from inside the container with `Ctrl-p` + `Ctrl-q`
1. Orphaned Containers: Over time, you may end up with [orphaned contaniers](http://jimhoskins.com/2013/07/27/remove-untagged-docker-images.html), use the following to clean them up 1. Orphaned Containers: Over time, you may end up with [orphaned contaniers](http://jimhoskins.com/2013/07/27/remove-untagged-docker-images.html), use the following to clean them up
1. `sudo docker rm $(docker ps -a -q)` 1. `docker rm $(docker ps -a -q)`
1. `sudo docker rmi $(docker images | grep "^<none>" | awk "{print $3}")` 1. `docker rmi $(docker images | grep "^<none>" | awk "{print $3}")`
## For Developers ## For Developers
If you run TCUP in debug mode (`export DEBUG=true`) then TCUP will automatically mount your PWD as /dev. If you run TCUP in debug mode (`export DEBUG=true` or using `--debug` parameter) then TCUP will automatically mount your PWD as /dev.
If you run TCUP from your Refstack clone, then you can work directly in Refstack code from inside If you run TCUP from your Refstack clone, then you can work directly in Refstack code from inside
a TCUP container from the /dev directory. a TCUP container from the /dev directory.

View File

@ -20,6 +20,7 @@ import commands
import logging import logging
import os import os
import re import re
import sys
if __name__ == "__main__": if __name__ == "__main__":
@ -32,14 +33,19 @@ if __name__ == "__main__":
"LESSCLOSE", "SSH_CONNECTION"} "LESSCLOSE", "SSH_CONNECTION"}
REQUIRED_ENV_VARS = {'OS_PASSWORD', 'OS_USERNAME', 'OS_AUTH_URL'} REQUIRED_ENV_VARS = {'OS_PASSWORD', 'OS_USERNAME', 'OS_AUTH_URL'}
# debugging?
debug = ((len(sys.argv) > 1 and sys.argv[1] == "--debug")
or os.environ.get("DEBUG"))
# Setup the logger # Setup the logger
LOG_FORMAT = "%(asctime)s %(name)s %(levelname)s %(message)s" LOG_FORMAT = "%(asctime)s %(name)s %(levelname)s %(message)s"
logger = logging.getLogger("TCUP") logger = logging.getLogger("TCUP")
console_log_handle = logging.StreamHandler() console_log_handle = logging.StreamHandler()
console_log_handle.setFormatter(logging.Formatter(LOG_FORMAT)) console_log_handle.setFormatter(logging.Formatter(LOG_FORMAT))
logger.addHandler(console_log_handle) logger.addHandler(console_log_handle)
if os.environ.get("DEBUG"): if debug:
logger.setLevel(logging.DEBUG) logger.setLevel(logging.DEBUG)
logger.info("Starting in DEBUG mode.")
else: else:
logger.setLevel(logging.INFO) logger.setLevel(logging.INFO)
@ -84,19 +90,19 @@ if __name__ == "__main__":
docker_run = "docker run -d -i" docker_run = "docker run -d -i"
for env_var in user_env_vars: for env_var in user_env_vars:
docker_run += ' -e "%s=%s"' % (env_var, user_env_vars[env_var]) docker_run += ' -e "%s=%s"' % (env_var, user_env_vars[env_var])
if "DEBUG" in user_env_vars: if debug:
docker_run += " -v `pwd`:/dev" docker_run += " -v `pwd`:/dev"
docker_run += ' -t %s' % (image) docker_run += ' -t %s' % (image)
if "DEBUG" in user_env_vars: if debug:
docker_run += " /bin/bash" docker_run += " /bin/bash"
logger.info("""Debug mode does not start tests! logger.info("Debug mode does not start tests! \
You must run `refstack/tools/execute_test.py \ You must run `refstack/refstack/tools/execute_test.py \
--tempest-home /tempest` to complete processing""") --tempest-home /tempest` to complete processing")
else: else:
docker_run += " cd refstack; refstack/tools/execute_test.py" \ docker_run += " cd refstack; refstack/tools/execute_test.py" \
" --tempest-home /tempest" \ " --tempest-home /tempest" \
" --callback ${api_addr} ${test_id}" " --callback ${api_addr} ${test_id}"
if "DEBUG" in user_env_vars: if debug:
docker_run_log_output = docker_run docker_run_log_output = docker_run
else: else:
# normally we redact the password # normally we redact the password
@ -109,6 +115,6 @@ if __name__ == "__main__":
docker_output = commands.getoutput(docker_run) docker_output = commands.getoutput(docker_run)
logger.debug(docker_output) logger.debug(docker_output)
logger.info("""You can monitor the TCUP results using the command logger.info("""You can monitor the TCUP results using the command
'sudo docker attach %s' 'docker attach %s'
(hint: you may need to press [enter])""" (hint: you may need to press [enter])"""
% docker_output[0:12]) % docker_output[0:12])