2013-10-12 08:28:27 +00:00
|
|
|
"""
|
|
|
|
Drop into a python shell
|
|
|
|
"""
|
2011-06-02 22:04:01 +00:00
|
|
|
import code
|
|
|
|
import readline
|
|
|
|
import rlcompleter
|
|
|
|
rlcompleter.__name__ # silence pyflakes
|
2014-01-30 05:48:31 +00:00
|
|
|
import pprint
|
2011-06-02 22:04:01 +00:00
|
|
|
|
|
|
|
readline.parse_and_bind('tab: complete')
|
|
|
|
|
|
|
|
def task(ctx, config):
|
2011-06-06 21:22:49 +00:00
|
|
|
"""
|
|
|
|
Run an interactive Python shell, with the cluster accessible via
|
|
|
|
the ``ctx`` variable.
|
|
|
|
|
|
|
|
Hit ``control-D`` to continue.
|
|
|
|
|
|
|
|
This is also useful to pause the execution of the test between two
|
|
|
|
tasks, either to perform ad hoc operations, or to examine the
|
|
|
|
state of the cluster. You can also use it to easily bring up a
|
|
|
|
Ceph cluster for ad hoc testing.
|
|
|
|
|
|
|
|
For example::
|
|
|
|
|
|
|
|
tasks:
|
|
|
|
- ceph:
|
|
|
|
- interactive:
|
|
|
|
"""
|
2014-01-30 05:48:31 +00:00
|
|
|
pp = pprint.PrettyPrinter().pprint
|
2011-06-02 22:04:01 +00:00
|
|
|
code.interact(
|
|
|
|
banner='Ceph test interactive mode, use ctx to interact with the cluster, press control-D to exit...',
|
|
|
|
# TODO simplify this
|
|
|
|
local=dict(
|
|
|
|
ctx=ctx,
|
|
|
|
config=config,
|
2014-01-30 05:48:31 +00:00
|
|
|
pp=pp,
|
2011-06-02 22:04:01 +00:00
|
|
|
),
|
|
|
|
)
|