Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(131)

Side by Side Diff: recipe_modules/context/examples/full.py

Issue 2925453002: [context] Add path prefix/suffix manipulation. (Closed)
Patch Set: advise Created 3 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 # Copyright 2017 The LUCI Authors. All rights reserved. 1 # Copyright 2017 The LUCI Authors. All rights reserved.
2 # Use of this source code is governed under the Apache License, Version 2.0 2 # Use of this source code is governed under the Apache License, Version 2.0
3 # that can be found in the LICENSE file. 3 # that can be found in the LICENSE file.
4 4
5 from recipe_engine import recipe_api, config 5 from recipe_engine import recipe_api, config
6 6
7 DEPS = [ 7 DEPS = [
8 'context', 8 'context',
9 'path', 9 'path',
10 'step', 10 'step',
11 ] 11 ]
12 12
13 13
14 def RunSteps(api): 14 def RunSteps(api):
15 api.step('default step', ['bash', '-c', 'echo default!']) 15 api.step('default step', ['bash', '-c', 'echo default!'])
16 16
17 noop_context = {} 17 noop_context = {}
18 with api.context(**noop_context): 18 with api.context(**noop_context):
19 # nothing happens! this is exactly the same as above, but this optimization 19 # nothing happens! this is exactly the same as above, but this optimization
20 # is helpful when recipes need to calculate contextual values. 20 # is helpful when recipes need to calculate contextual values.
21 api.step('default step', ['bash', '-c', 'echo default!']) 21 api.step('default step', ['bash', '-c', 'echo default!'])
22 22
23 # can change cwd 23 # can change cwd
24 api.step('mk subdir', ['mkdir', 'subdir']) 24 api.step('mk subdir', ['mkdir', '-p', 'subdir'])
25 with api.context(cwd=api.path['start_dir'].join('subdir')): 25 with api.context(cwd=api.path['start_dir'].join('subdir')):
26 api.step('subdir step', ['bash', '-c', 'pwd']) 26 api.step('subdir step', ['bash', '-c', 'pwd'])
27 api.step('other subdir step', ['bash', '-c', 'echo hi again!']) 27 api.step('other subdir step', ['bash', '-c', 'echo hi again!'])
28 28
29 # can set envvars 29 # can set envvars, and path prefix/suffix.
30 with api.context(env={'HELLO': 'WORLD', 'HOME': None}): 30 with api.context(env={'FOO': 'bar'}):
31 api.step('env step', ['bash', '-c', 'echo $HELLO; echo $HOME']) 31 api.step('env step', ['bash', '-c', 'echo $FOO'])
32
33 pants = api.path['start_dir'].join('pants')
34 shirt = api.path['start_dir'].join('shirt')
35 with api.context.path_prefix('FOO', pants, shirt):
36 api.step('env step with prefix and suffix',
37 ['bash', '-c', 'echo $FOO'])
38
39 with api.context.path_remove('FOO', shirt):
40 api.step('env with path removal',
41 ['bash', '-c', 'echo $FOO'])
32 42
33 # %-formats are errors (for now). Double-% escape them. 43 # %-formats are errors (for now). Double-% escape them.
34 bad_examples = ['%format', '%s'] 44 bad_examples = ['%format', '%s']
35 for example in bad_examples: 45 for example in bad_examples:
36 try: 46 try:
37 with api.context(env={'BAD': example}): 47 with api.context(env={'BAD': example}):
38 assert False # pragma: no cover 48 assert False # pragma: no cover
39 except ValueError: 49 except ValueError:
40 pass 50 pass
41 51
42 # this is fine though: 52 # this is fine though:
43 with api.context(env={'FINE': '%%format'}): 53 with api.context(env={'FINE': '%%format'}):
44 pass 54 pass
45 55
46 # can increment nest level... note that this is a low level api, prefer 56 # can increment nest level... note that this is a low level api, prefer
47 # api.step.nest instead: 57 # api.step.nest instead:
48 # YES: 58 # YES:
49 with api.step.nest('nested'): 59 with api.step.nest('nested'):
50 api.step('properly indented', ['bash', '-c', 'echo yay!']) 60 api.step('properly indented', ['bash', '-c', 'echo yay!'])
51 # AVOID: 61 # AVOID:
52 with api.context(increment_nest_level=True): 62 with api.context(increment_nest_level=True):
53 api.step('indented with wrong name', ['bash', '-c', 'echo indent?']) 63 api.step('indented with wrong name', ['bash', '-c', 'echo indent?'])
54 64
55 65
56 def GenTests(api): 66 def GenTests(api):
57 yield api.test('basic') 67 yield api.test('basic')
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698