mirror of
https://github.com/ceph/ceph
synced 2025-01-28 05:53:37 +00:00
158f9ba1ff
This reverts commit d693b3f895
.
50 lines
1.3 KiB
Python
50 lines
1.3 KiB
Python
"""
|
|
Exececute custom commands
|
|
"""
|
|
import logging
|
|
|
|
from teuthology import misc as teuthology
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
def task(ctx, config):
|
|
"""
|
|
Execute commands on a given role
|
|
|
|
tasks:
|
|
- ceph:
|
|
- kclient: [client.a]
|
|
- exec:
|
|
client.a:
|
|
- echo 'module libceph +p' > /sys/kernel/debug/dynamic_debug/control
|
|
- echo 'module ceph +p' > /sys/kernel/debug/dynamic_debug/control
|
|
- interactive:
|
|
|
|
:param ctx: Context
|
|
:param config: Configuration
|
|
"""
|
|
log.info('Executing custom commands...')
|
|
assert isinstance(config, dict), "task exec got invalid config"
|
|
|
|
testdir = teuthology.get_testdir(ctx)
|
|
|
|
if 'all' in config and len(config) == 1:
|
|
a = config['all']
|
|
roles = teuthology.all_roles(ctx.cluster)
|
|
config = dict((id_, a) for id_ in roles)
|
|
|
|
for role, ls in config.iteritems():
|
|
(remote,) = ctx.cluster.only(role).remotes.iterkeys()
|
|
log.info('Running commands on role %s host %s', role, remote.name)
|
|
for c in ls:
|
|
c.replace('$TESTDIR', testdir)
|
|
remote.run(
|
|
args=[
|
|
'sudo',
|
|
'TESTDIR={tdir}'.format(tdir=testdir),
|
|
'bash',
|
|
'-c',
|
|
c],
|
|
)
|
|
|