1# Copyright 2016 The Chromium Authors. All rights reserved. 2# Use of this source code is governed by a BSD-style license that can be 3# found in the LICENSE file. 4 5 6# pylint: disable=W0201 7 8 9from recipe_engine import recipe_api 10 11 12CONFIG_DEBUG = 'Debug' 13CONFIG_RELEASE = 'Release' 14 15 16class SkiaVarsApi(recipe_api.RecipeApi): 17 18 def setup(self): 19 """Prepare the variables.""" 20 # Setup 21 self.builder_name = self.m.properties['buildername'] 22 23 self.slave_dir = self.m.path['start_dir'] 24 25 # Special input/output directories. 26 self.build_dir = self.slave_dir.join('build') 27 28 self.default_env = self.m.context.env 29 self.default_env['CHROME_HEADLESS'] = '1' 30 self.default_env['PATH'] = self.m.path.pathsep.join([ 31 self.default_env.get('PATH', '%(PATH)s'), 32 str(self.m.bot_update.repo_resource()), 33 ]) 34 self.cache_dir = self.slave_dir.join('cache') 35 36 self.swarming_out_dir = self.slave_dir.join( 37 self.m.properties['swarm_out_dir']) 38 39 self.tmp_dir = self.m.path['start_dir'].join('tmp') 40 41 self.builder_cfg = self.m.builder_name_schema.DictForBuilderName( 42 self.builder_name) 43 self.role = self.builder_cfg['role'] 44 if self.role in [self.m.builder_name_schema.BUILDER_ROLE_HOUSEKEEPER, 45 self.m.builder_name_schema.BUILDER_ROLE_CALMBENCH]: 46 self.configuration = CONFIG_RELEASE 47 else: 48 self.configuration = self.builder_cfg.get('configuration', CONFIG_DEBUG) 49 arch = (self.builder_cfg.get('arch') or self.builder_cfg.get('target_arch')) 50 if ('Win' in self.builder_cfg.get('os', '') and arch == 'x86_64'): 51 self.configuration += '_x64' 52 53 self.extra_tokens = [] 54 if len(self.builder_cfg.get('extra_config', '')) > 0: 55 if self.builder_cfg['extra_config'].startswith('SK'): 56 assert self.builder_cfg['extra_config'].isupper() 57 self.extra_tokens = [self.builder_cfg['extra_config']] 58 else: 59 self.extra_tokens = self.builder_cfg['extra_config'].split('_') 60 61 self.patch_storage = self.m.properties.get('patch_storage', 'gerrit') 62 self.issue = None 63 self.patchset = None 64 self.is_trybot = False 65 if (self.m.properties.get('patch_issue', '') and 66 self.m.properties.get('patch_set', '') and 67 self.m.properties.get('patch_ref', '')): 68 self.is_trybot = True 69 self.issue = self.m.properties['patch_issue'] 70 self.patchset = self.m.properties['patch_set'] 71 72 self._swarming_bot_id = None 73 self._swarming_task_id = None 74 75 # Internal bot support. 76 self.internal_hardware_label = ( 77 self.m.properties.get('internal_hardware_label')) 78 self.is_internal_bot = self.internal_hardware_label is not None 79 80 @property 81 def is_linux(self): 82 return 'Ubuntu' in self.builder_name or 'Debian' in self.builder_name 83 84 @property 85 def swarming_bot_id(self): 86 if not self._swarming_bot_id: 87 self._swarming_bot_id = self.m.python.inline( 88 name='get swarming bot id', 89 program='''import os 90print os.environ.get('SWARMING_BOT_ID', '') 91''', 92 stdout=self.m.raw_io.output()).stdout.rstrip() 93 return self._swarming_bot_id 94 95 @property 96 def swarming_task_id(self): 97 if not self._swarming_task_id: 98 self._swarming_task_id = self.m.python.inline( 99 name='get swarming task id', 100 program='''import os 101print os.environ.get('SWARMING_TASK_ID', '') 102''', 103 stdout=self.m.raw_io.output()).stdout.rstrip() 104 return self._swarming_task_id 105