[
  {
    "cmd": [
      "python",
      "-u",
      "RECIPE_MODULE[depot_tools::bot_update]/resources/bot_update.py",
      "--spec-path",
      "cache_dir = '[GIT_CACHE]'\nsolutions = [{'deps_file': 'DEPS', 'managed': True, 'name': 'src', 'url': 'https://webrtc.googlesource.com/src'}]\ntarget_os = ['android']",
      "--revision_mapping_file",
      "{\"got_revision\": \"src\"}",
      "--git-cache-dir",
      "[GIT_CACHE]",
      "--cleanup-dir",
      "[CLEANUP]/bot_update",
      "--output_json",
      "/path/to/tmp/json",
      "--revision",
      "src@aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
    ],
    "cwd": "[CACHE]/builder",
    "env_suffixes": {
      "PATH": [
        "RECIPE_PACKAGE_REPO[depot_tools]"
      ]
    },
    "infra_step": true,
    "name": "bot_update",
    "~followup_annotations": [
      "@@@STEP_TEXT@Some step text@@@",
      "@@@STEP_LOG_LINE@json.output@{@@@",
      "@@@STEP_LOG_LINE@json.output@  \"did_run\": true, @@@",
      "@@@STEP_LOG_LINE@json.output@  \"fixed_revisions\": {@@@",
      "@@@STEP_LOG_LINE@json.output@    \"src\": \"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\"@@@",
      "@@@STEP_LOG_LINE@json.output@  }, @@@",
      "@@@STEP_LOG_LINE@json.output@  \"manifest\": {@@@",
      "@@@STEP_LOG_LINE@json.output@    \"src\": {@@@",
      "@@@STEP_LOG_LINE@json.output@      \"repository\": \"https://fake.org/src.git\", @@@",
      "@@@STEP_LOG_LINE@json.output@      \"revision\": \"f27fede2220bcd326aee3e86ddfd4ebd0fe58cb9\"@@@",
      "@@@STEP_LOG_LINE@json.output@    }@@@",
      "@@@STEP_LOG_LINE@json.output@  }, @@@",
      "@@@STEP_LOG_LINE@json.output@  \"patch_failure\": false, @@@",
      "@@@STEP_LOG_LINE@json.output@  \"patch_root\": \"src\", @@@",
      "@@@STEP_LOG_LINE@json.output@  \"properties\": {@@@",
      "@@@STEP_LOG_LINE@json.output@    \"got_revision\": \"f27fede2220bcd326aee3e86ddfd4ebd0fe58cb9\", @@@",
      "@@@STEP_LOG_LINE@json.output@    \"got_revision_cp\": \"refs/heads/master@{#170242}\"@@@",
      "@@@STEP_LOG_LINE@json.output@  }, @@@",
      "@@@STEP_LOG_LINE@json.output@  \"root\": \"src\", @@@",
      "@@@STEP_LOG_LINE@json.output@  \"source_manifest\": {@@@",
      "@@@STEP_LOG_LINE@json.output@    \"directories\": {@@@",
      "@@@STEP_LOG_LINE@json.output@      \"src\": {@@@",
      "@@@STEP_LOG_LINE@json.output@        \"git_checkout\": {@@@",
      "@@@STEP_LOG_LINE@json.output@          \"repo_url\": \"https://fake.org/src.git\", @@@",
      "@@@STEP_LOG_LINE@json.output@          \"revision\": \"f27fede2220bcd326aee3e86ddfd4ebd0fe58cb9\"@@@",
      "@@@STEP_LOG_LINE@json.output@        }@@@",
      "@@@STEP_LOG_LINE@json.output@      }@@@",
      "@@@STEP_LOG_LINE@json.output@    }, @@@",
      "@@@STEP_LOG_LINE@json.output@    \"version\": 0@@@",
      "@@@STEP_LOG_LINE@json.output@  }, @@@",
      "@@@STEP_LOG_LINE@json.output@  \"step_text\": \"Some step text\"@@@",
      "@@@STEP_LOG_LINE@json.output@}@@@",
      "@@@STEP_LOG_END@json.output@@@",
      "@@@SET_BUILD_PROPERTY@got_revision@\"f27fede2220bcd326aee3e86ddfd4ebd0fe58cb9\"@@@",
      "@@@SET_BUILD_PROPERTY@got_revision_cp@\"refs/heads/master@{#170242}\"@@@"
    ]
  },
  {
    "cmd": [
      "python",
      "-u",
      "RECIPE_MODULE[build::webrtc]/resources/cleanup_files.py",
      "[CACHE]/builder/src/out"
    ],
    "infra_step": true,
    "name": "clean test output files"
  },
  {
    "cmd": [
      "python",
      "-u",
      "\nimport shutil, sys, os\nshutil.rmtree(sys.argv[1], True)\nshutil.rmtree(sys.argv[2], True)\ntry:\n  os.remove(sys.argv[3])\nexcept OSError:\n  pass\n",
      "[CACHE]/builder/src/out/Release/debug_info_dumps",
      "[CACHE]/builder/src/out/Release/test_logs",
      "[CACHE]/builder/src/out/build_product.zip",
      "[CACHE]/builder/src"
    ],
    "infra_step": true,
    "name": "clean local files",
    "~followup_annotations": [
      "@@@STEP_LOG_LINE@python.inline@@@@",
      "@@@STEP_LOG_LINE@python.inline@import shutil, sys, os@@@",
      "@@@STEP_LOG_LINE@python.inline@shutil.rmtree(sys.argv[1], True)@@@",
      "@@@STEP_LOG_LINE@python.inline@shutil.rmtree(sys.argv[2], True)@@@",
      "@@@STEP_LOG_LINE@python.inline@try:@@@",
      "@@@STEP_LOG_LINE@python.inline@  os.remove(sys.argv[3])@@@",
      "@@@STEP_LOG_LINE@python.inline@except OSError:@@@",
      "@@@STEP_LOG_LINE@python.inline@  pass@@@",
      "@@@STEP_LOG_END@python.inline@@@"
    ]
  },
  {
    "cmd": [
      "python",
      "-u",
      "RECIPE_MODULE[build::isolate]/resources/find_isolated_tests.py",
      "--build-dir",
      "[CACHE]/builder/src/out/Release",
      "--clean-isolated-files"
    ],
    "name": "clean isolated files"
  },
  {
    "cmd": [
      "python",
      "-u",
      "[CACHE]/builder/src/tools/swarming_client/swarming.py",
      "--version"
    ],
    "name": "swarming.py --version",
    "stdout": "/path/to/tmp/",
    "~followup_annotations": [
      "@@@STEP_TEXT@0.8.6@@@"
    ]
  },
  {
    "cmd": [
      "python",
      "-u",
      "RECIPE_MODULE[build::isolate]/resources/find_isolated_tests.py",
      "--build-dir",
      "[CACHE]/builder/src/out/Release",
      "--output-json",
      "/path/to/tmp/json"
    ],
    "name": "find isolated tests",
    "~followup_annotations": [
      "@@@STEP_LOG_LINE@json.output@{@@@",
      "@@@STEP_LOG_LINE@json.output@  \"low_bandwidth_audio_perf_test\": \"[dummy hash for low_bandwidth_audio_perf_test]\", @@@",
      "@@@STEP_LOG_LINE@json.output@  \"video_quality_loopback_test\": \"[dummy hash for video_quality_loopback_test]\", @@@",
      "@@@STEP_LOG_LINE@json.output@  \"webrtc_perf_tests\": \"[dummy hash for webrtc_perf_tests]\"@@@",
      "@@@STEP_LOG_LINE@json.output@}@@@",
      "@@@STEP_LOG_END@json.output@@@",
      "@@@SET_BUILD_PROPERTY@swarm_hashes@{\"low_bandwidth_audio_perf_test\": \"[dummy hash for low_bandwidth_audio_perf_test]\", \"video_quality_loopback_test\": \"[dummy hash for video_quality_loopback_test]\", \"webrtc_perf_tests\": \"[dummy hash for webrtc_perf_tests]\"}@@@"
    ]
  },
  {
    "cmd": [
      "python",
      "-u",
      "[CACHE]/builder/src/tools/swarming_client/swarming.py",
      "trigger",
      "--swarming",
      "https://chromium-swarm.appspot.com",
      "--isolate-server",
      "https://isolateserver.appspot.com",
      "--priority",
      "40",
      "--shards",
      "1",
      "--task-name",
      "low_bandwidth_audio_perf_test/Android/[dummy has/Perf Android32 (L Nexus5)/1337",
      "--dump-json",
      "/path/to/tmp/json",
      "--expiration",
      "3600",
      "--io-timeout",
      "1200",
      "--hard-timeout",
      "3600",
      "--dimension",
      "android_devices",
      "1",
      "--dimension",
      "device_os",
      "L",
      "--dimension",
      "device_type",
      "hammerhead",
      "--dimension",
      "os",
      "Android",
      "--dimension",
      "pool",
      "WebRTC-perf",
      "--named-cache",
      "swarming_module_cache_vpython",
      ".swarming_module_cache/vpython",
      "--tag",
      "build_is_experimental:true",
      "--tag",
      "buildername:Perf Android32 (L Nexus5)",
      "--tag",
      "buildnumber:1337",
      "--tag",
      "data:[dummy hash for low_bandwidth_audio_perf_test]",
      "--tag",
      "master:client.webrtc.perf",
      "--tag",
      "name:low_bandwidth_audio_perf_test",
      "--tag",
      "project:webrtc",
      "--tag",
      "purpose:CI",
      "--tag",
      "purpose:luci",
      "--tag",
      "purpose:post-commit",
      "--tag",
      "slavename:bot_id",
      "--tag",
      "spec_name:webrtc.perf:Perf Android32 (L Nexus5)",
      "--tag",
      "stepname:low_bandwidth_audio_perf_test on Android",
      "--idempotent",
      "--cipd-package",
      "bin:infra/tools/luci/logdog/butler/${platform}:git_revision:ff387eadf445b24c935f1cf7d6ddd279f8a6b04c",
      "--cipd-package",
      ".swarming_module:infra/python/cpython/${platform}:TEST_VERSION",
      "--cipd-package",
      ".swarming_module:infra/tools/luci/logdog/butler/${platform}:TEST_VERSION",
      "--cipd-package",
      ".swarming_module:infra/tools/luci/vpython-native/${platform}:TEST_VERSION",
      "--cipd-package",
      ".swarming_module:infra/tools/luci/vpython/${platform}:TEST_VERSION",
      "--env-prefix",
      "PATH",
      ".swarming_module",
      "--env-prefix",
      "PATH",
      ".swarming_module/bin",
      "--env-prefix",
      "VPYTHON_VIRTUALENV_ROOT",
      ".swarming_module_cache/vpython",
      "--isolated",
      "[dummy hash for low_bandwidth_audio_perf_test]",
      "--",
      "--android",
      "--isolated-script-test-perf-output",
      "${ISOLATED_OUTDIR}/perftest-output.json",
      "--adb-path",
      "../../third_party/android_tools/sdk/platform-tools/adb"
    ],
    "cwd": "[CACHE]/builder",
    "infra_step": true,
    "name": "[trigger] low_bandwidth_audio_perf_test on Android",
    "~followup_annotations": [
      "@@@STEP_TEXT@Run on OS: 'Android'@@@",
      "@@@STEP_LOG_LINE@json.output@{@@@",
      "@@@STEP_LOG_LINE@json.output@  \"base_task_name\": \"low_bandwidth_audio_perf_test/Android/[dummy has/Perf Android32 (L Nexus5)/1337\", @@@",
      "@@@STEP_LOG_LINE@json.output@  \"tasks\": {@@@",
      "@@@STEP_LOG_LINE@json.output@    \"low_bandwidth_audio_perf_test/Android/[dummy has/Perf Android32 (L Nexus5)/1337\": {@@@",
      "@@@STEP_LOG_LINE@json.output@      \"shard_index\": 0, @@@",
      "@@@STEP_LOG_LINE@json.output@      \"task_id\": \"10000\", @@@",
      "@@@STEP_LOG_LINE@json.output@      \"view_url\": \"https://chromium-swarm.appspot.com/user/task/10000\"@@@",
      "@@@STEP_LOG_LINE@json.output@    }@@@",
      "@@@STEP_LOG_LINE@json.output@  }@@@",
      "@@@STEP_LOG_LINE@json.output@}@@@",
      "@@@STEP_LOG_END@json.output@@@",
      "@@@STEP_LINK@shard #0@https://chromium-swarm.appspot.com/user/task/10000@@@"
    ]
  },
  {
    "cmd": [
      "python",
      "-u",
      "[CACHE]/builder/src/tools/swarming_client/swarming.py",
      "trigger",
      "--swarming",
      "https://chromium-swarm.appspot.com",
      "--isolate-server",
      "https://isolateserver.appspot.com",
      "--priority",
      "40",
      "--shards",
      "1",
      "--task-name",
      "video_quality_loopback_test/Android/[dummy has/Perf Android32 (L Nexus5)/1337",
      "--dump-json",
      "/path/to/tmp/json",
      "--expiration",
      "3600",
      "--io-timeout",
      "1200",
      "--hard-timeout",
      "3600",
      "--dimension",
      "android_devices",
      "1",
      "--dimension",
      "device_os",
      "L",
      "--dimension",
      "device_type",
      "hammerhead",
      "--dimension",
      "os",
      "Android",
      "--dimension",
      "pool",
      "WebRTC-perf",
      "--named-cache",
      "swarming_module_cache_vpython",
      ".swarming_module_cache/vpython",
      "--tag",
      "build_is_experimental:true",
      "--tag",
      "buildername:Perf Android32 (L Nexus5)",
      "--tag",
      "buildnumber:1337",
      "--tag",
      "data:[dummy hash for video_quality_loopback_test]",
      "--tag",
      "master:client.webrtc.perf",
      "--tag",
      "name:video_quality_loopback_test",
      "--tag",
      "project:webrtc",
      "--tag",
      "purpose:CI",
      "--tag",
      "purpose:luci",
      "--tag",
      "purpose:post-commit",
      "--tag",
      "slavename:bot_id",
      "--tag",
      "spec_name:webrtc.perf:Perf Android32 (L Nexus5)",
      "--tag",
      "stepname:video_quality_loopback_test on Android",
      "--idempotent",
      "--cipd-package",
      "bin:infra/tools/luci/logdog/butler/${platform}:git_revision:ff387eadf445b24c935f1cf7d6ddd279f8a6b04c",
      "--cipd-package",
      ".swarming_module:infra/python/cpython/${platform}:TEST_VERSION",
      "--cipd-package",
      ".swarming_module:infra/tools/luci/logdog/butler/${platform}:TEST_VERSION",
      "--cipd-package",
      ".swarming_module:infra/tools/luci/vpython-native/${platform}:TEST_VERSION",
      "--cipd-package",
      ".swarming_module:infra/tools/luci/vpython/${platform}:TEST_VERSION",
      "--env-prefix",
      "PATH",
      ".swarming_module",
      "--env-prefix",
      "PATH",
      ".swarming_module/bin",
      "--env-prefix",
      "VPYTHON_VIRTUALENV_ROOT",
      ".swarming_module_cache/vpython",
      "--isolated",
      "[dummy hash for video_quality_loopback_test]",
      "--",
      "--isolated-script-test-perf-output",
      "${ISOLATED_OUTDIR}/perftest-output.json",
      "--adb-path",
      "../../third_party/android_tools/sdk/platform-tools/adb"
    ],
    "cwd": "[CACHE]/builder",
    "infra_step": true,
    "name": "[trigger] video_quality_loopback_test on Android",
    "~followup_annotations": [
      "@@@STEP_TEXT@Run on OS: 'Android'@@@",
      "@@@STEP_LOG_LINE@json.output@{@@@",
      "@@@STEP_LOG_LINE@json.output@  \"base_task_name\": \"video_quality_loopback_test/Android/[dummy has/Perf Android32 (L Nexus5)/1337\", @@@",
      "@@@STEP_LOG_LINE@json.output@  \"tasks\": {@@@",
      "@@@STEP_LOG_LINE@json.output@    \"video_quality_loopback_test/Android/[dummy has/Perf Android32 (L Nexus5)/1337\": {@@@",
      "@@@STEP_LOG_LINE@json.output@      \"shard_index\": 0, @@@",
      "@@@STEP_LOG_LINE@json.output@      \"task_id\": \"110000\", @@@",
      "@@@STEP_LOG_LINE@json.output@      \"view_url\": \"https://chromium-swarm.appspot.com/user/task/110000\"@@@",
      "@@@STEP_LOG_LINE@json.output@    }@@@",
      "@@@STEP_LOG_LINE@json.output@  }@@@",
      "@@@STEP_LOG_LINE@json.output@}@@@",
      "@@@STEP_LOG_END@json.output@@@",
      "@@@STEP_LINK@shard #0@https://chromium-swarm.appspot.com/user/task/110000@@@"
    ]
  },
  {
    "cmd": [
      "python",
      "-u",
      "[CACHE]/builder/src/tools/swarming_client/swarming.py",
      "trigger",
      "--swarming",
      "https://chromium-swarm.appspot.com",
      "--isolate-server",
      "https://isolateserver.appspot.com",
      "--priority",
      "40",
      "--shards",
      "1",
      "--task-name",
      "webrtc_perf_tests/Android/[dummy has/Perf Android32 (L Nexus5)/1337",
      "--dump-json",
      "/path/to/tmp/json",
      "--expiration",
      "3600",
      "--io-timeout",
      "1200",
      "--hard-timeout",
      "3600",
      "--dimension",
      "android_devices",
      "1",
      "--dimension",
      "device_os",
      "L",
      "--dimension",
      "device_type",
      "hammerhead",
      "--dimension",
      "os",
      "Android",
      "--dimension",
      "pool",
      "WebRTC-perf",
      "--named-cache",
      "swarming_module_cache_vpython",
      ".swarming_module_cache/vpython",
      "--tag",
      "build_is_experimental:true",
      "--tag",
      "buildername:Perf Android32 (L Nexus5)",
      "--tag",
      "buildnumber:1337",
      "--tag",
      "data:[dummy hash for webrtc_perf_tests]",
      "--tag",
      "master:client.webrtc.perf",
      "--tag",
      "name:webrtc_perf_tests",
      "--tag",
      "project:webrtc",
      "--tag",
      "purpose:CI",
      "--tag",
      "purpose:luci",
      "--tag",
      "purpose:post-commit",
      "--tag",
      "slavename:bot_id",
      "--tag",
      "spec_name:webrtc.perf:Perf Android32 (L Nexus5)",
      "--tag",
      "stepname:webrtc_perf_tests on Android",
      "--idempotent",
      "--cipd-package",
      "bin:infra/tools/luci/logdog/butler/${platform}:git_revision:ff387eadf445b24c935f1cf7d6ddd279f8a6b04c",
      "--cipd-package",
      ".swarming_module:infra/python/cpython/${platform}:TEST_VERSION",
      "--cipd-package",
      ".swarming_module:infra/tools/luci/logdog/butler/${platform}:TEST_VERSION",
      "--cipd-package",
      ".swarming_module:infra/tools/luci/vpython-native/${platform}:TEST_VERSION",
      "--cipd-package",
      ".swarming_module:infra/tools/luci/vpython/${platform}:TEST_VERSION",
      "--env-prefix",
      "PATH",
      ".swarming_module",
      "--env-prefix",
      "PATH",
      ".swarming_module/bin",
      "--env-prefix",
      "VPYTHON_VIRTUALENV_ROOT",
      ".swarming_module_cache/vpython",
      "--isolated",
      "[dummy hash for webrtc_perf_tests]",
      "--",
      "--save_worst_frame",
      "--isolated-script-test-perf-output",
      "${ISOLATED_OUTDIR}/perftest-output.json"
    ],
    "cwd": "[CACHE]/builder",
    "infra_step": true,
    "name": "[trigger] webrtc_perf_tests on Android",
    "~followup_annotations": [
      "@@@STEP_TEXT@Run on OS: 'Android'@@@",
      "@@@STEP_LOG_LINE@json.output@{@@@",
      "@@@STEP_LOG_LINE@json.output@  \"base_task_name\": \"webrtc_perf_tests/Android/[dummy has/Perf Android32 (L Nexus5)/1337\", @@@",
      "@@@STEP_LOG_LINE@json.output@  \"tasks\": {@@@",
      "@@@STEP_LOG_LINE@json.output@    \"webrtc_perf_tests/Android/[dummy has/Perf Android32 (L Nexus5)/1337\": {@@@",
      "@@@STEP_LOG_LINE@json.output@      \"shard_index\": 0, @@@",
      "@@@STEP_LOG_LINE@json.output@      \"task_id\": \"120000\", @@@",
      "@@@STEP_LOG_LINE@json.output@      \"view_url\": \"https://chromium-swarm.appspot.com/user/task/120000\"@@@",
      "@@@STEP_LOG_LINE@json.output@    }@@@",
      "@@@STEP_LOG_LINE@json.output@  }@@@",
      "@@@STEP_LOG_LINE@json.output@}@@@",
      "@@@STEP_LOG_END@json.output@@@",
      "@@@STEP_LINK@shard #0@https://chromium-swarm.appspot.com/user/task/120000@@@"
    ]
  },
  {
    "cmd": [
      "python",
      "-u",
      "RECIPE_PACKAGE_REPO[build]/scripts/tools/runit.py",
      "--show-path",
      "--with-third-party-lib",
      "--",
      "python",
      "RECIPE_MODULE[build::swarming]/resources/collect_task.py",
      "-o",
      "/path/to/tmp/json",
      "--task-output-dir",
      "/path/to/tmp/",
      "--merge-script",
      "RECIPE_MODULE[build::swarming]/resources/noop_merge.py",
      "--merge-script-stdout-file",
      "/path/to/tmp/merge_script_log",
      "--merge-additional-args",
      "[]",
      "--summary-json-file",
      "/path/to/tmp/json",
      "--",
      "[CACHE]/builder/src/tools/luci-go/swarming",
      "collect",
      "-server",
      "https://chromium-swarm.appspot.com",
      "-worker",
      "100",
      "-task-summary-python",
      "-task-output-stdout",
      "json",
      "-requests-json",
      "{\"tasks\": [{\"task_id\": \"10000\"}]}"
    ],
    "name": "low_bandwidth_audio_perf_test on Android",
    "~followup_annotations": [
      "@@@STEP_TEXT@Run on OS: 'Android'<br>Pending time: 0:01:11<br>Shard duration: 0:01:00@@@",
      "@@@STEP_LOG_LINE@json.output@{}@@@",
      "@@@STEP_LOG_END@json.output@@@",
      "@@@STEP_LOG_LINE@swarming.summary@{@@@",
      "@@@STEP_LOG_LINE@swarming.summary@  \"shards\": [@@@",
      "@@@STEP_LOG_LINE@swarming.summary@    {@@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"abandoned_ts\": null, @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"bot_id\": \"vm30\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"completed_ts\": \"2014-09-25T01:43:11.123\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"created_ts\": \"2014-09-25T01:41:00.123\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"duration\": 31.5, @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"exit_code\": \"0\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"failure\": false, @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"internal_failure\": false, @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"modified_ts\": \"2014-09-25 01:42:00\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"name\": \"heartbeat-canary-2014-09-25_01:41:55-os=Windows\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"output\": \"Heart beat succeeded on win32.\\nFoo\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"outputs_ref\": {@@@",
      "@@@STEP_LOG_LINE@swarming.summary@        \"isolated\": \"abc123\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@        \"isolatedserver\": \"https://isolateserver.appspot.com\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@        \"namespace\": \"default-gzip\"@@@",
      "@@@STEP_LOG_LINE@swarming.summary@      }, @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"started_ts\": \"2014-09-25T01:42:11.123\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"state\": \"COMPLETED\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"task_id\": \"148aa78d7aa0000\"@@@",
      "@@@STEP_LOG_LINE@swarming.summary@    }@@@",
      "@@@STEP_LOG_LINE@swarming.summary@  ]@@@",
      "@@@STEP_LOG_LINE@swarming.summary@}@@@",
      "@@@STEP_LOG_END@swarming.summary@@@",
      "@@@STEP_LOG_LINE@Merge script log@Successfully merged all data@@@",
      "@@@STEP_LOG_END@Merge script log@@@",
      "@@@STEP_LOG_LINE@step_metadata@{@@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"canonical_step_name\": \"low_bandwidth_audio_perf_test\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"dimensions\": {@@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"android_devices\": \"1\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"device_os\": \"L\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"device_type\": \"hammerhead\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"os\": \"Android\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"pool\": \"WebRTC-perf\"@@@",
      "@@@STEP_LOG_LINE@step_metadata@  }, @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"full_step_name\": \"low_bandwidth_audio_perf_test on Android\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"isolate_target_name\": \"low_bandwidth_audio_perf_test\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"patched\": false, @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"swarm_task_ids\": [@@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"10000\"@@@",
      "@@@STEP_LOG_LINE@step_metadata@  ], @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"waterfall_buildername\": null, @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"waterfall_mastername\": null@@@",
      "@@@STEP_LOG_LINE@step_metadata@}@@@",
      "@@@STEP_LOG_END@step_metadata@@@",
      "@@@STEP_LOG_END@logcats@@@",
      "@@@STEP_LINK@shard #0 isolated out@https://isolateserver.appspot.com/browse?namespace=default-gzip&hash=abc123@@@",
      "@@@STEP_LINK@shard #0 (31.5 sec)@https://chromium-swarm.appspot.com/user/task/10000@@@"
    ]
  },
  {
    "cmd": [
      "python",
      "-u",
      "RECIPE_PACKAGE_REPO[build]/scripts/tools/runit.py",
      "--show-path",
      "--with-third-party-lib",
      "--",
      "python",
      "RECIPE_PACKAGE_REPO[build]/scripts/slave/upload_perf_dashboard_results.py",
      "--build-dir",
      "[CACHE]/builder/src/out",
      "--buildername",
      "Perf Android32 (L Nexus5)",
      "--buildnumber",
      "0",
      "--name",
      "low_bandwidth_audio_perf_test",
      "--perf-id",
      "webrtc-android-tests-nexus5",
      "--output-json-file",
      "/path/to/tmp/json",
      "--results-file",
      "{\"benchmark_name\": \"low_bandwidth_audio_perf_test\", \"charts\": {\"html_size\": {\"http://www.google.com/\": {\"type\": \"scalar\", \"units\": \"bytes\", \"value\": 13579}}, \"load_times\": {\"http://www.google.com/\": {\"std\": 1.25, \"type\": \"list_of_scalar_values\", \"units\": \"sec\", \"value\": [4.2]}}, \"warm_times\": {\"http://www.google.com/\": {\"type\": \"list_of_scalar_values\", \"units\": \"sec\", \"values\": [9, 9, 8, 9]}}}, \"format_version\": \"1.0\"}",
      "--results-url",
      "https://chromeperf.appspot.com",
      "--got-webrtc-revision",
      "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
      "--is-luci-builder",
      "--perf-dashboard-machine-group",
      "ExperimentalWebRTCPerf",
      "--output-json-dashboard-url",
      "/path/to/tmp/json"
    ],
    "cwd": "[CACHE]/builder",
    "name": "low_bandwidth_audio_perf_test Dashboard Upload",
    "~followup_annotations": [
      "@@@STEP_LOG_LINE@json.output@{}@@@",
      "@@@STEP_LOG_END@json.output@@@",
      "@@@STEP_LINK@Results Dashboard@chromeperf.appspot.com@@@"
    ]
  },
  {
    "cmd": [
      "python",
      "-u",
      "RECIPE_PACKAGE_REPO[build]/scripts/tools/runit.py",
      "--show-path",
      "--with-third-party-lib",
      "--",
      "python",
      "RECIPE_MODULE[build::swarming]/resources/collect_task.py",
      "-o",
      "/path/to/tmp/json",
      "--task-output-dir",
      "/path/to/tmp/",
      "--merge-script",
      "RECIPE_MODULE[build::swarming]/resources/noop_merge.py",
      "--merge-script-stdout-file",
      "/path/to/tmp/merge_script_log",
      "--merge-additional-args",
      "[]",
      "--summary-json-file",
      "/path/to/tmp/json",
      "--",
      "[CACHE]/builder/src/tools/luci-go/swarming",
      "collect",
      "-server",
      "https://chromium-swarm.appspot.com",
      "-worker",
      "100",
      "-task-summary-python",
      "-task-output-stdout",
      "json",
      "-requests-json",
      "{\"tasks\": [{\"task_id\": \"110000\"}]}"
    ],
    "name": "video_quality_loopback_test on Android",
    "~followup_annotations": [
      "@@@STEP_TEXT@Run on OS: 'Android'<br>Pending time: 0:01:11<br>Shard duration: 0:01:00@@@",
      "@@@STEP_LOG_LINE@json.output@{}@@@",
      "@@@STEP_LOG_END@json.output@@@",
      "@@@STEP_LOG_LINE@swarming.summary@{@@@",
      "@@@STEP_LOG_LINE@swarming.summary@  \"shards\": [@@@",
      "@@@STEP_LOG_LINE@swarming.summary@    {@@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"abandoned_ts\": null, @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"bot_id\": \"vm30\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"completed_ts\": \"2014-09-25T01:43:11.123\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"created_ts\": \"2014-09-25T01:41:00.123\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"duration\": 31.5, @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"exit_code\": \"0\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"failure\": false, @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"internal_failure\": false, @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"modified_ts\": \"2014-09-25 01:42:00\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"name\": \"heartbeat-canary-2014-09-25_01:41:55-os=Windows\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"output\": \"Heart beat succeeded on win32.\\nFoo\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"outputs_ref\": {@@@",
      "@@@STEP_LOG_LINE@swarming.summary@        \"isolated\": \"abc123\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@        \"isolatedserver\": \"https://isolateserver.appspot.com\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@        \"namespace\": \"default-gzip\"@@@",
      "@@@STEP_LOG_LINE@swarming.summary@      }, @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"started_ts\": \"2014-09-25T01:42:11.123\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"state\": \"COMPLETED\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"task_id\": \"148aa78d7aa0000\"@@@",
      "@@@STEP_LOG_LINE@swarming.summary@    }@@@",
      "@@@STEP_LOG_LINE@swarming.summary@  ]@@@",
      "@@@STEP_LOG_LINE@swarming.summary@}@@@",
      "@@@STEP_LOG_END@swarming.summary@@@",
      "@@@STEP_LOG_LINE@Merge script log@Successfully merged all data@@@",
      "@@@STEP_LOG_END@Merge script log@@@",
      "@@@STEP_LOG_LINE@step_metadata@{@@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"canonical_step_name\": \"video_quality_loopback_test\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"dimensions\": {@@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"android_devices\": \"1\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"device_os\": \"L\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"device_type\": \"hammerhead\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"os\": \"Android\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"pool\": \"WebRTC-perf\"@@@",
      "@@@STEP_LOG_LINE@step_metadata@  }, @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"full_step_name\": \"video_quality_loopback_test on Android\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"isolate_target_name\": \"video_quality_loopback_test\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"patched\": false, @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"swarm_task_ids\": [@@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"110000\"@@@",
      "@@@STEP_LOG_LINE@step_metadata@  ], @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"waterfall_buildername\": null, @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"waterfall_mastername\": null@@@",
      "@@@STEP_LOG_LINE@step_metadata@}@@@",
      "@@@STEP_LOG_END@step_metadata@@@",
      "@@@STEP_LOG_END@logcats@@@",
      "@@@STEP_LINK@shard #0 isolated out@https://isolateserver.appspot.com/browse?namespace=default-gzip&hash=abc123@@@",
      "@@@STEP_LINK@shard #0 (31.5 sec)@https://chromium-swarm.appspot.com/user/task/110000@@@"
    ]
  },
  {
    "cmd": [
      "python",
      "-u",
      "RECIPE_PACKAGE_REPO[build]/scripts/tools/runit.py",
      "--show-path",
      "--with-third-party-lib",
      "--",
      "python",
      "RECIPE_PACKAGE_REPO[build]/scripts/slave/upload_perf_dashboard_results.py",
      "--build-dir",
      "[CACHE]/builder/src/out",
      "--buildername",
      "Perf Android32 (L Nexus5)",
      "--buildnumber",
      "0",
      "--name",
      "video_quality_loopback_test",
      "--perf-id",
      "webrtc-android-tests-nexus5",
      "--output-json-file",
      "/path/to/tmp/json",
      "--results-file",
      "{\"benchmark_name\": \"video_quality_loopback_test\", \"charts\": {\"html_size\": {\"http://www.google.com/\": {\"type\": \"scalar\", \"units\": \"bytes\", \"value\": 13579}}, \"load_times\": {\"http://www.google.com/\": {\"std\": 1.25, \"type\": \"list_of_scalar_values\", \"units\": \"sec\", \"value\": [4.2]}}, \"warm_times\": {\"http://www.google.com/\": {\"type\": \"list_of_scalar_values\", \"units\": \"sec\", \"values\": [9, 9, 8, 9]}}}, \"format_version\": \"1.0\"}",
      "--results-url",
      "https://chromeperf.appspot.com",
      "--got-webrtc-revision",
      "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
      "--is-luci-builder",
      "--perf-dashboard-machine-group",
      "ExperimentalWebRTCPerf",
      "--output-json-dashboard-url",
      "/path/to/tmp/json"
    ],
    "cwd": "[CACHE]/builder",
    "name": "video_quality_loopback_test Dashboard Upload",
    "~followup_annotations": [
      "@@@STEP_LOG_LINE@json.output@{}@@@",
      "@@@STEP_LOG_END@json.output@@@",
      "@@@STEP_LINK@Results Dashboard@chromeperf.appspot.com@@@"
    ]
  },
  {
    "cmd": [
      "python",
      "-u",
      "RECIPE_PACKAGE_REPO[build]/scripts/tools/runit.py",
      "--show-path",
      "--with-third-party-lib",
      "--",
      "python",
      "RECIPE_MODULE[build::swarming]/resources/collect_task.py",
      "-o",
      "/path/to/tmp/json",
      "--task-output-dir",
      "/path/to/tmp/",
      "--merge-script",
      "RECIPE_MODULE[build::swarming]/resources/noop_merge.py",
      "--merge-script-stdout-file",
      "/path/to/tmp/merge_script_log",
      "--merge-additional-args",
      "[]",
      "--summary-json-file",
      "/path/to/tmp/json",
      "--",
      "[CACHE]/builder/src/tools/luci-go/swarming",
      "collect",
      "-server",
      "https://chromium-swarm.appspot.com",
      "-worker",
      "100",
      "-task-summary-python",
      "-task-output-stdout",
      "json",
      "-requests-json",
      "{\"tasks\": [{\"task_id\": \"120000\"}]}"
    ],
    "name": "webrtc_perf_tests on Android",
    "~followup_annotations": [
      "@@@STEP_TEXT@Run on OS: 'Android'<br>Pending time: 0:01:11<br>Shard duration: 0:01:00@@@",
      "@@@STEP_LOG_LINE@json.output@{}@@@",
      "@@@STEP_LOG_END@json.output@@@",
      "@@@STEP_LOG_LINE@swarming.summary@{@@@",
      "@@@STEP_LOG_LINE@swarming.summary@  \"shards\": [@@@",
      "@@@STEP_LOG_LINE@swarming.summary@    {@@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"abandoned_ts\": null, @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"bot_id\": \"vm30\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"completed_ts\": \"2014-09-25T01:43:11.123\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"created_ts\": \"2014-09-25T01:41:00.123\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"duration\": 31.5, @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"exit_code\": \"0\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"failure\": false, @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"internal_failure\": false, @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"modified_ts\": \"2014-09-25 01:42:00\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"name\": \"heartbeat-canary-2014-09-25_01:41:55-os=Windows\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"output\": \"Heart beat succeeded on win32.\\nFoo\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"outputs_ref\": {@@@",
      "@@@STEP_LOG_LINE@swarming.summary@        \"isolated\": \"abc123\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@        \"isolatedserver\": \"https://isolateserver.appspot.com\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@        \"namespace\": \"default-gzip\"@@@",
      "@@@STEP_LOG_LINE@swarming.summary@      }, @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"started_ts\": \"2014-09-25T01:42:11.123\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"state\": \"COMPLETED\", @@@",
      "@@@STEP_LOG_LINE@swarming.summary@      \"task_id\": \"148aa78d7aa0000\"@@@",
      "@@@STEP_LOG_LINE@swarming.summary@    }@@@",
      "@@@STEP_LOG_LINE@swarming.summary@  ]@@@",
      "@@@STEP_LOG_LINE@swarming.summary@}@@@",
      "@@@STEP_LOG_END@swarming.summary@@@",
      "@@@STEP_LOG_LINE@Merge script log@Successfully merged all data@@@",
      "@@@STEP_LOG_END@Merge script log@@@",
      "@@@STEP_LOG_LINE@step_metadata@{@@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"canonical_step_name\": \"webrtc_perf_tests\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"dimensions\": {@@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"android_devices\": \"1\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"device_os\": \"L\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"device_type\": \"hammerhead\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"os\": \"Android\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"pool\": \"WebRTC-perf\"@@@",
      "@@@STEP_LOG_LINE@step_metadata@  }, @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"full_step_name\": \"webrtc_perf_tests on Android\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"isolate_target_name\": \"webrtc_perf_tests\", @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"patched\": false, @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"swarm_task_ids\": [@@@",
      "@@@STEP_LOG_LINE@step_metadata@    \"120000\"@@@",
      "@@@STEP_LOG_LINE@step_metadata@  ], @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"waterfall_buildername\": null, @@@",
      "@@@STEP_LOG_LINE@step_metadata@  \"waterfall_mastername\": null@@@",
      "@@@STEP_LOG_LINE@step_metadata@}@@@",
      "@@@STEP_LOG_END@step_metadata@@@",
      "@@@STEP_LOG_END@logcats@@@",
      "@@@STEP_LINK@shard #0 isolated out@https://isolateserver.appspot.com/browse?namespace=default-gzip&hash=abc123@@@",
      "@@@STEP_LINK@shard #0 (31.5 sec)@https://chromium-swarm.appspot.com/user/task/120000@@@"
    ]
  },
  {
    "cmd": [
      "python",
      "-u",
      "RECIPE_PACKAGE_REPO[build]/scripts/tools/runit.py",
      "--show-path",
      "--with-third-party-lib",
      "--",
      "python",
      "RECIPE_PACKAGE_REPO[build]/scripts/slave/upload_perf_dashboard_results.py",
      "--build-dir",
      "[CACHE]/builder/src/out",
      "--buildername",
      "Perf Android32 (L Nexus5)",
      "--buildnumber",
      "0",
      "--name",
      "webrtc_perf_tests",
      "--perf-id",
      "webrtc-android-tests-nexus5",
      "--output-json-file",
      "/path/to/tmp/json",
      "--results-file",
      "{\"benchmark_name\": \"webrtc_perf_tests\", \"charts\": {\"html_size\": {\"http://www.google.com/\": {\"type\": \"scalar\", \"units\": \"bytes\", \"value\": 13579}}, \"load_times\": {\"http://www.google.com/\": {\"std\": 1.25, \"type\": \"list_of_scalar_values\", \"units\": \"sec\", \"value\": [4.2]}}, \"warm_times\": {\"http://www.google.com/\": {\"type\": \"list_of_scalar_values\", \"units\": \"sec\", \"values\": [9, 9, 8, 9]}}}, \"format_version\": \"1.0\"}",
      "--results-url",
      "https://chromeperf.appspot.com",
      "--got-webrtc-revision",
      "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
      "--is-luci-builder",
      "--perf-dashboard-machine-group",
      "ExperimentalWebRTCPerf",
      "--output-json-dashboard-url",
      "/path/to/tmp/json"
    ],
    "cwd": "[CACHE]/builder",
    "name": "webrtc_perf_tests Dashboard Upload",
    "~followup_annotations": [
      "@@@STEP_LOG_LINE@json.output@{}@@@",
      "@@@STEP_LOG_END@json.output@@@",
      "@@@STEP_LINK@Results Dashboard@chromeperf.appspot.com@@@"
    ]
  },
  {
    "jsonResult": null,
    "name": "$result"
  }
]