| Index: recipe_modules/bot_update/test_api.py | 
| diff --git a/recipe_modules/bot_update/test_api.py b/recipe_modules/bot_update/test_api.py | 
| index 64eab8ab1ee2b4bc175dfe5fb45607f2d2be6047..97fac0852210786670a68a143a01296af3354f7e 100644 | 
| --- a/recipe_modules/bot_update/test_api.py | 
| +++ b/recipe_modules/bot_update/test_api.py | 
| @@ -14,73 +14,61 @@ import bot_update | 
|  | 
|  | 
| class BotUpdateTestApi(recipe_test_api.RecipeTestApi): | 
| -  def output_json(self, master, builder, slave, root, first_sln, | 
| -                  revision_mapping, git_mode, force=False, fail_patch=False, | 
| +  def output_json(self, root, first_sln, revision_mapping, fail_patch=False, | 
| output_manifest=False, fixed_revisions=None): | 
| """Deterministically synthesize json.output test data for gclient's | 
| --output-json option. | 
| """ | 
| -    active = bot_update.check_valid_host(master, builder, slave) or force | 
|  | 
| output = { | 
| -        'did_run': active, | 
| +        'did_run': True, | 
| 'patch_failure': False | 
| } | 
|  | 
| -    # Add in extra json output if active. | 
| -    if active: | 
| -      properties = { | 
| -          property_name: self.gen_revision(project_name, git_mode) | 
| -          for project_name, property_name in revision_mapping.iteritems() | 
| -      } | 
| -      properties.update({ | 
| -          '%s_cp' % property_name: ('refs/heads/master@{#%s}' % | 
| -                                    self.gen_revision(project_name, False)) | 
| -          for project_name, property_name in revision_mapping.iteritems() | 
| -      }) | 
| +    properties = { | 
| +        property_name: self.gen_revision(project_name, True) | 
| +        for project_name, property_name in revision_mapping.iteritems() | 
| +    } | 
| +    properties.update({ | 
| +        '%s_cp' % property_name: ('refs/heads/master@{#%s}' % | 
| +                                  self.gen_revision(project_name, False)) | 
| +        for project_name, property_name in revision_mapping.iteritems() | 
| +    }) | 
|  | 
| -      # We also want to simulate outputting "got_revision_git": ... | 
| -      # when git mode is off to match what bot_update.py does. | 
| -      if not git_mode: | 
| -        properties.update({ | 
| -            '%s_git' % property_name: self.gen_revision(project_name, True) | 
| -            for project_name, property_name in revision_mapping.iteritems() | 
| -        }) | 
| +    output.update({ | 
| +        'patch_root': root or first_sln, | 
| +        'root': first_sln, | 
| +        'properties': properties, | 
| +        'step_text': 'Some step text' | 
| +    }) | 
|  | 
| +    if output_manifest: | 
| output.update({ | 
| -          'patch_root': root or first_sln, | 
| -          'root': first_sln, | 
| -          'properties': properties, | 
| -          'step_text': 'Some step text' | 
| -      }) | 
| - | 
| -      if output_manifest: | 
| -        output.update({ | 
| -          'manifest': { | 
| -            project_name: { | 
| -              'repository': 'https://fake.org/%s.git' % project_name, | 
| -              'revision': self.gen_revision(project_name, git_mode), | 
| -            } | 
| -            for project_name in revision_mapping | 
| +        'manifest': { | 
| +          project_name: { | 
| +            'repository': 'https://fake.org/%s.git' % project_name, | 
| +            'revision': self.gen_revision(project_name, True), | 
| } | 
| -        }) | 
| +          for project_name in revision_mapping | 
| +        } | 
| +      }) | 
|  | 
| -      if fixed_revisions: | 
| -        output['fixed_revisions'] = fixed_revisions | 
| +    if fixed_revisions: | 
| +      output['fixed_revisions'] = fixed_revisions | 
|  | 
| -      if fail_patch: | 
| -        output['log_lines'] = [('patch error', 'Patch failed to apply'),] | 
| -        output['patch_failure'] = True | 
| -        output['patch_apply_return_code'] = 1 | 
| -        if fail_patch == 'download': | 
| -          output['patch_apply_return_code'] = 3 | 
| +    if fail_patch: | 
| +      output['log_lines'] = [('patch error', 'Patch failed to apply'),] | 
| +      output['patch_failure'] = True | 
| +      output['patch_apply_return_code'] = 1 | 
| +      if fail_patch == 'download': | 
| +        output['patch_apply_return_code'] = 3 | 
| return self.m.json.output(output) | 
|  | 
| @staticmethod | 
| -  def gen_revision(project, GIT_MODE): | 
| +  def gen_revision(project, git_mode): | 
| """Hash project to bogus deterministic revision values.""" | 
| h = hashlib.sha1(project) | 
| -    if GIT_MODE: | 
| +    if git_mode: | 
| return h.hexdigest() | 
| else: | 
| return struct.unpack('!I', h.digest()[:4])[0] % 300000 | 
|  |