skia2/infra/bots/recipe_modules
Eric Boren 1f218ee143 [recipes] Port to Python 3
Lots of potentially messy changes.

Also includes a major recipe roll.

Bug: chromium:1256037
Change-Id: Id05779802c5ca05921d93fa73c21930723793585
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/467980
Reviewed-by: Ravi Mistry <rmistry@google.com>
Commit-Queue: Eric Boren <borenet@google.com>
2021-11-10 20:17:28 +00:00
..
build [recipes] Port to Python 3 2021-11-10 20:17:28 +00:00
builder_name_schema [recipes] Port to Python 3 2021-11-10 20:17:28 +00:00
checkout [recipes] Port to Python 3 2021-11-10 20:17:28 +00:00
docker [recipes] Port to Python 3 2021-11-10 20:17:28 +00:00
doxygen [recipes] Port to Python 3 2021-11-10 20:17:28 +00:00
env [recipes] Port to Python 3 2021-11-10 20:17:28 +00:00
flavor [recipes] Port to Python 3 2021-11-10 20:17:28 +00:00
git [recipes] Port to Python 3 2021-11-10 20:17:28 +00:00
gold_upload [recipes] Port to Python 3 2021-11-10 20:17:28 +00:00
gsutil [recipes] Port to Python 3 2021-11-10 20:17:28 +00:00
infra [recipes] Port to Python 3 2021-11-10 20:17:28 +00:00
run [recipes] Port to Python 3 2021-11-10 20:17:28 +00:00
vars [recipes] Port to Python 3 2021-11-10 20:17:28 +00:00
README.md Increase ClangTidy code coverage by enabling features. 2020-08-03 15:37:30 +00:00

Skia Recipe Modules

This directory contains recipe modules designed to be used by recipes (see infra/bots/recipes). They are all Skia-specific and some are interrelated:

  • builder_name_schema - Helps to derive expected behavior from task (formerly builder) names.
  • core - Use as a starting point for most recipes: runs setup and sync steps.
  • ct - Shared Cluster Telemetry utilities.
  • flavor - Allows the caller to specify a high-level command to run, leaving the platform-specific details to be handled by the specific flavor module.
  • infra - Shared infrastructure-related utilities.
  • run - Utilities for running commands.
  • swarming - Utilities for running Swarming tasks.
  • vars - Common global variables used by Skia recipes/modules.

When you change a recipe module, you generally need to re-train the simulation test:

$ python infra/bots/infra_tests.py --train

Or:

$ cd infra/bots; make train

Each recipe module contains a few files:

  • api.py - This is the meat of the module.
  • __init__.py - Contains a single DEPS variable, indicating the other recipe modules on which this module depends.
  • example.py - Optional, this file contains examples which demonstrate how to use the module and should contain enough tests to achieve 100% coverage for the module. The tests are run using the recipes test command above.