mirror of
https://github.com/ceph/ceph
synced 2025-01-11 13:41:02 +00:00
49 lines
1.3 KiB
Python
49 lines
1.3 KiB
Python
|
import logging
|
||
|
import contextlib
|
||
|
import time
|
||
|
|
||
|
from ..orchestra import run
|
||
|
|
||
|
log = logging.getLogger(__name__)
|
||
|
|
||
|
@contextlib.contextmanager
|
||
|
def task(ctx, config):
|
||
|
"""
|
||
|
Task that just displays information when it is create and when it is
|
||
|
destroyed/cleaned up. This task was used to test parallel and
|
||
|
sequential task options.
|
||
|
|
||
|
example:
|
||
|
|
||
|
tasks:
|
||
|
- sequential:
|
||
|
- tasktest:
|
||
|
- id: 'foo'
|
||
|
- tasktest:
|
||
|
- id: 'bar'
|
||
|
- delay:5
|
||
|
- tasktest:
|
||
|
|
||
|
The above yaml will sequentially start a test task named foo and a test
|
||
|
task named bar. Bar will take 5 seconds to complete. After foo and bar
|
||
|
have finished, an unidentified tasktest task will run.
|
||
|
"""
|
||
|
try:
|
||
|
delay = config.get('delay', 0)
|
||
|
id = config.get('id', 'UNKNOWN')
|
||
|
except AttributeError:
|
||
|
delay = 0
|
||
|
id = 'UNKNOWN'
|
||
|
try:
|
||
|
log.info('**************************************************')
|
||
|
log.info('Started task test -- %s' % id)
|
||
|
log.info('**************************************************')
|
||
|
time.sleep(delay)
|
||
|
yield
|
||
|
|
||
|
finally:
|
||
|
log.info('**************************************************')
|
||
|
log.info('Task test is being cleaned up -- %s' % id)
|
||
|
log.info('**************************************************')
|
||
|
|