DEPS: depot_tools/gclient, recipe_engine/context, recipe_engine/file, recipe_engine/path, recipe_engine/step, docker, env, infra, run, vars
Build Skia for various platforms.
— def __call__(self, checkout_root, out_dir):
Compile the code.
— def copy_build_products(self, out_dir, dst):
Copy selected build products to dst.
— def DictForBuilderName(self, *args, **kwargs):
— def MakeBuilderName(self, **kwargs):
DEPS: depot_tools/bot_update, depot_tools/gclient, depot_tools/git, depot_tools/tryserver, recipe_engine/context, recipe_engine/file, recipe_engine/path, recipe_engine/properties, recipe_engine/step, run, vars
— def assert_git_is_from_cipd(self):
Fail if git is not obtained from CIPD.
— def bot_update(self, checkout_root, gclient_cache=None, skip_patch=False, override_revision=None):
Run the steps to obtain a checkout using bot_update.
Args: checkout_root: Root directory where the code will be synced. gclient_cache: Optional, directory of the gclient cache. skip_patch: Ignore changelist/patchset when syncing the Skia repo.
@property
— def default_checkout_root(self):
The default location for cached persistent checkouts.
— def git(self, checkout_root):
Run the steps to perform a pure-git checkout without DEPS.
DEPS: recipe_engine/file, recipe_engine/path, recipe_engine/raw_io, recipe_engine/step, env, run
— def mount_out(self):
— def mount_src(self):
— def run(self, name, docker_image, src_dir, out_dir, script, args=None, docker_args=None, copies=None, recursive_read=None, attempts=1, match_directory_structure=False):
DEPS: recipe_engine/context, recipe_engine/step, run
— def generate_and_upload(self, skia_dir):
DEPS: recipe_engine/context, recipe_engine/file, recipe_engine/json, recipe_engine/path, recipe_engine/platform, recipe_engine/raw_io, recipe_engine/step, env, run, vars
— def cleanup_steps(self):
— def copy_directory_contents_to_device(self, host_dir, device_dir):
— def copy_directory_contents_to_host(self, device_dir, host_dir):
— def copy_file_to_device(self, host_path, device_path):
— def create_clean_device_dir(self, path):
— def create_clean_host_dir(self, path):
— def device_path_join(self, *args):
— def get_flavor(self, vars_api, app_name):
Return a flavor utils object specific to the given builder.
— def install(self, skps=False, images=False, lotties=False, svgs=False, resources=False, mskps=False, texttraces=False):
— def read_file_on_device(self, path, **kwargs):
— def remove_file_on_device(self, path):
— def setup(self, app_name):
— def step(self, name, cmd, **kwargs):
— def env(self):
Add Git to PATH
Requires the infra/git and infra/tools/git CIPD packages to be installed in the ‘git’ relative path.
DEPS: recipe_engine/context, recipe_engine/file, recipe_engine/json, recipe_engine/platform, recipe_engine/properties, recipe_engine/step, recipe_engine/time, flavor, gsutil, run, vars
— def upload(self):
Attempt to upload files to Gold. This module assumes setup has occurred for the vars and flavor modules.
DEPS: recipe_engine/context, recipe_engine/step, run, vars
— def __call__(self, step_name, *args):
Run gsutil with the given args.
This assumes there exists an executable called gsutil on the PATH. This probably only works for Linux/Mac, but those are the only hosts that we try to upload to GCS from anyway.
— def cp(self, name, src, dst, extra_gsutil_args=None, extra_args=None, multithread=False):
Attempt to upload or download files to/from Google Cloud Storage (GCS).
Args: name: string. Will be used to fill out the step name. src: string. Absolute path for a local file or gcs file (e.g. gs://...) dst: string. Same as src. extra_gsutil_args: optional list of args to be passed to gsutil before the cp command. extra_args: optional list of args to be passed to gsutil cp. e.g. [-Z] asks all files be compressed with gzip after upload and before download. multi_thread: if the -m argument should be used to copy multiple items at once (e.g. gsutil -m cp foo* gs://bar/dir)
If the operation fails, it will be retried multiple times.
DEPS: recipe_engine/context, recipe_engine/file, recipe_engine/path, recipe_engine/raw_io, recipe_engine/step, run, vars
@property
— def go_bin(self):
@property
— def go_env(self):
@property
— def gopath(self):
@property
— def goroot(self):
DEPS: recipe_engine/file, recipe_engine/path, recipe_engine/properties, recipe_engine/step, env, vars
— def __call__(self, steptype, name, abort_on_failure=True, fail_build_on_failure=True, **kwargs):
Run a step. If it fails, keep going but mark the build status failed.
— def __init__(self, *args, **kwargs):
Initialize the recipe module.
— def asset_version(self, asset_name, skia_dir, test_data=None):
Return the contents of VERSION for the given asset as a string.
If test_data is not specified, reads the property ‘test_<asset_name>_version’ or if not present, uses TEST_DEFAULT_ASSET_VERSION.
— def check_failure(self):
Raise an exception if any step failed.
@property
— def failed_steps(self):
— def readfile(self, filename, *args, **kwargs):
Convenience function for reading files.
— def rmtree(self, path):
Wrapper around api.file.rmtree.
— def run_once(self, fn, *args, **kwargs):
— def with_retry(self, steptype, name, attempts, between_attempts_fn=None, abort_on_failure=True, fail_build_on_failure=True, **kwargs):
— def writefile(self, filename, contents):
Convenience function for writing files.
DEPS: depot_tools/bot_update, recipe_engine/context, recipe_engine/json, recipe_engine/path, recipe_engine/properties, recipe_engine/raw_io, recipe_engine/step, builder_name_schema
@property
— def is_linux(self):
— def setup(self):
Prepare the variables.
@property
— def swarming_bot_id(self):
@property
— def swarming_task_id(self):
DEPS: recipe_engine/path, recipe_engine/platform, recipe_engine/properties, recipe_engine/raw_io, build, run, vars
— def RunSteps(api):
— def RunSteps(api):
DEPS: recipe_engine/file, recipe_engine/path, recipe_engine/platform, recipe_engine/properties, checkout, run, vars
— def RunSteps(api):
DEPS: recipe_engine/context, recipe_engine/file, recipe_engine/json, recipe_engine/path, recipe_engine/platform, recipe_engine/properties, recipe_engine/step, build, checkout, run, vars
— def RunSteps(api):
DEPS: recipe_engine/context, recipe_engine/file, recipe_engine/path, recipe_engine/properties, recipe_engine/raw_io, recipe_engine/step, checkout, env, run, vars
— def RunSteps(api):
— def add_binary_size_output_property(result, source, binary_size):
— def analyze_cpp_lib(api, checkout_root, out_dir, files):
— def analyze_flutter_lib(api, checkout_root, out_dir, files):
— def analyze_wasm_file(api, checkout_root, out_dir, files):
— def analyze_web_file(api, checkout_root, out_dir, files):
— def keys_and_props(api):
— def make_treemap(api, checkout_root, out_dir, files):
DEPS: recipe_engine/context, recipe_engine/properties, recipe_engine/step, docker, vars
— def RunSteps(api):
DEPS: recipe_engine/path, recipe_engine/properties, doxygen, vars
— def RunSteps(api):
DEPS: recipe_engine/context, recipe_engine/step, env
— def RunSteps(api):
DEPS: recipe_engine/platform, recipe_engine/properties, recipe_engine/raw_io, flavor, run, vars
— def RunSteps(api):
— def test_exceptions(api):
DEPS: recipe_engine/platform, recipe_engine/step, git
— def RunSteps(api):
DEPS: recipe_engine/path, recipe_engine/platform, recipe_engine/properties, recipe_engine/step, flavor, gold_upload, run, vars
— def RunSteps(api):
DEPS: recipe_engine/path, recipe_engine/properties, recipe_engine/step, gsutil, run, vars
— def RunSteps(api):
DEPS: recipe_engine/file, recipe_engine/path, recipe_engine/properties, checkout, doxygen, run, vars
— def RunSteps(api):
DEPS: recipe_engine/context, recipe_engine/path, recipe_engine/properties, recipe_engine/step, infra, vars
— def RunSteps(api):
— def git_init(api, repo_root, env):
DEPS: recipe_engine/context, recipe_engine/file, recipe_engine/path, recipe_engine/properties, recipe_engine/step, infra, run, vars
— def RunSteps(api):
DEPS: recipe_engine/file, recipe_engine/json, recipe_engine/path, recipe_engine/platform, recipe_engine/properties, recipe_engine/raw_io, recipe_engine/step, recipe_engine/time, env, flavor, run, vars
— def RunSteps(api):
— def perf_steps(api):
Run Skia benchmarks.
DEPS: recipe_engine/file, recipe_engine/path, recipe_engine/properties, recipe_engine/step, checkout, docker, env, infra, run, vars
— def RunSteps(api):
DEPS: recipe_engine/context, recipe_engine/file, recipe_engine/json, recipe_engine/path, recipe_engine/properties, recipe_engine/raw_io, recipe_engine/step, recipe_engine/time, flavor, infra, run, vars
— def RunSteps(api):
— def get_trace_match(lottie_filename, is_android):
Returns the DM regex to match the specified lottie file name.
— def parse_trace(trace_json, lottie_filename, api):
parse_trace parses the specified trace JSON.
Parses the trace JSON and calculates the time of a single frame. Frame time is considered the same as seek time + render time. Note: The first seek is ignored because it is a constructor call.
A dictionary is returned that has the following structure: { ‘frame_max_us’: 100, ‘frame_min_us’: 90, ‘frame_avg_us’: 95, }
— def perf_steps(api):
Run DM on lottie files with tracing turned on and then parse the output.
DEPS: recipe_engine/context, recipe_engine/file, recipe_engine/json, recipe_engine/path, recipe_engine/properties, recipe_engine/step, recipe_engine/time, checkout, env, flavor, infra, run, vars
— def RunSteps(api):
— def parse_trace(trace_json, lottie_filename, api, renderer):
parse_trace parses the specified trace JSON.
Parses the trace JSON and calculates the time of a single frame. A dictionary is returned that has the following structure: { ‘frame_max_us’: 100, ‘frame_min_us’: 90, ‘frame_avg_us’: 95, }
DEPS: recipe_engine/context, recipe_engine/path, recipe_engine/platform, recipe_engine/properties, recipe_engine/step, run, vars
— def RunSteps(api):
— def myfunc(api, i):
DEPS: recipe_engine/context, recipe_engine/file, recipe_engine/path, recipe_engine/platform, recipe_engine/properties, recipe_engine/raw_io, recipe_engine/step, recipe_engine/time, flavor, run, vars
— def RunSteps(api):
— def skpbench_steps(api):
benchmark Skia using skpbench.
DEPS: depot_tools/gitiles, recipe_engine/context, recipe_engine/file, recipe_engine/json, recipe_engine/path, recipe_engine/platform, recipe_engine/properties, recipe_engine/step, build, checkout, infra, run, vars
— def RunSteps(api):
DEPS: recipe_engine/context, recipe_engine/file, recipe_engine/path, recipe_engine/platform, recipe_engine/properties, recipe_engine/raw_io, recipe_engine/step, env, flavor, gold_upload, run, vars
— def RunSteps(api):
— def test_steps(api):
Run the DM test.
DEPS: recipe_engine/file, recipe_engine/path, recipe_engine/properties, recipe_engine/step, checkout, docker, env, flavor, gold_upload, infra, run, vars
— def RunSteps(api):
DEPS: recipe_engine/file, recipe_engine/path, recipe_engine/properties, recipe_engine/step, checkout, docker, env, flavor, gold_upload, infra, run, vars
— def RunSteps(api):
DEPS: recipe_engine/file, recipe_engine/path, recipe_engine/properties, recipe_engine/step, checkout, docker, env, flavor, gold_upload, infra, run, vars
— def RunSteps(api):
DEPS: recipe_engine/context, recipe_engine/file, recipe_engine/path, recipe_engine/properties, recipe_engine/step, recipe_engine/time, vars
— def RunSteps(api):
DEPS: recipe_engine/file, recipe_engine/json, recipe_engine/path, recipe_engine/properties, recipe_engine/step, recipe_engine/time, gsutil, vars
— def RunSteps(api):
DEPS: recipe_engine/context, recipe_engine/file, recipe_engine/path, recipe_engine/properties, recipe_engine/step, recipe_engine/time, vars
— def RunSteps(api):
DEPS: recipe_engine/path, recipe_engine/platform, recipe_engine/properties, recipe_engine/step, vars
— def RunSteps(api):