Status: SUCCEEDED
Triggered by: -
Duration: 27 minutes
Actions:

Definition (rev 3f447d8894f8b11c5eef0218727450ea4b2742f1)

buildbucket: <
  server: "cr-buildbucket.appspot.com"
  bucket: "luci.boringssl.ci"
  builder: "android_arm_armmode_rel"
>

Incoming triggers

Incoming properties

{
  "branch": "refs/heads/master",
  "repository": "https://boringssl.googlesource.com/boringssl",
  "revision": "8f3019e849afe428d0e29f34294a6328c8105b83"
}

Incoming tags

  • buildset:commit/git/8f3019e849afe428d0e29f34294a6328c8105b83
  • buildset:commit/gitiles/boringssl.googlesource.com/boringssl/+/8f3019e849afe428d0e29f34294a6328c8105b83
  • gitiles_ref:refs/heads/master

Debug log (UTC)

[17:11:23.506] New invocation is queued and will start shortly
[17:11:24.650] Starting the invocation (attempt 1)
[17:11:24.697] Preparing PubSub topic for "https://cr-buildbucket.appspot.com"
[17:11:24.698] PubSub topic is "projects/luci-scheduler/topics/scheduler.buildbucket.cr-buildbucket~appspot.gserviceaccount.com"
[17:11:24.698] Buildbucket request:
{
  "bucket": "luci.boringssl.ci",
  "client_operation_id": "9048183211261461744",
  "parameters_json": "{\"builder_name\":\"android_arm_armmode_rel\",\"properties\":{\"$recipe_engine/scheduler\":{\"hostname\":\"luci-scheduler.appspot.com\",\"triggers\":[{\"gitiles\":{\"ref\":\"refs/heads/master\",\"repo\":\"https://boringssl.googlesource.com/boringssl\",\"revision\":\"8f3019e849afe428d0e29f34294a6328c8105b83\"},\"id\":\"https://boringssl.googlesource.com/boringssl/+/refs/heads/master@8f3019e849afe428d0e29f34294a6328c8105b83\",\"title\":\"8f3019e849afe428d0e29f34294a6328c8105b83\",\"url\":\"https://boringssl.googlesource.com/boringssl/+/8f3019e849afe428d0e29f34294a6328c8105b83\"}]},\"branch\":\"refs/heads/master\",\"repository\":\"https://boringssl.googlesource.com/boringssl\",\"revision\":\"8f3019e849afe428d0e29f34294a6328c8105b83\"}}",
  "pubsub_callback": {
    "auth_token": "...",
    "topic": "projects/luci-scheduler/topics/scheduler.buildbucket.cr-buildbucket~appspot.gserviceaccount.com"
  },
  "tags": [
    "builder:android_arm_armmode_rel",
    "scheduler_invocation_id:9048183211261461744",
    "scheduler_job_id:boringssl/android_arm_armmode_rel",
    "user_agent:luci-scheduler",
    "buildset:commit/git/8f3019e849afe428d0e29f34294a6328c8105b83",
    "buildset:commit/gitiles/boringssl.googlesource.com/boringssl/+/8f3019e849afe428d0e29f34294a6328c8105b83",
    "gitiles_ref:refs/heads/master"
  ]
}
[17:11:26.114] Buildbucket response:
{
  "build": {
    "bucket": "luci.boringssl.ci",
    "canary_preference": "PROD",
    "created_by": "project:boringssl",
    "created_ts": "1587143484820587",
    "id": "8882753149219985744",
    "parameters_json": "{\"builder_name\": \"android_arm_armmode_rel\", \"properties\": {\"$recipe_engine/scheduler\": {\"hostname\": \"luci-scheduler.appspot.com\", \"triggers\": [{\"gitiles\": {\"ref\": \"refs/heads/master\", \"repo\": \"https://boringssl.googlesource.com/boringssl\", \"revision\": \"8f3019e849afe428d0e29f34294a6328c8105b83\"}, \"id\": \"https://boringssl.googlesource.com/boringssl/+/refs/heads/master@8f3019e849afe428d0e29f34294a6328c8105b83\", \"title\": \"8f3019e849afe428d0e29f34294a6328c8105b83\", \"url\": \"https://boringssl.googlesource.com/boringssl/+/8f3019e849afe428d0e29f34294a6328c8105b83\"}]}, \"branch\": \"refs/heads/master\", \"repository\": \"https://boringssl.googlesource.com/boringssl\", \"revision\": \"8f3019e849afe428d0e29f34294a6328c8105b83\"}}",
    "project": "boringssl",
    "result_details_json": "{\"properties\": {}}",
    "service_account": "boringssl-ci-builder@chops-service-accounts.iam.gserviceaccount.com",
    "status": "SCHEDULED",
    "status_changed_ts": "1587143485685579",
    "tags": [
      "builder:android_arm_armmode_rel",
      "buildset:commit/git/8f3019e849afe428d0e29f34294a6328c8105b83",
      "buildset:commit/gitiles/boringssl.googlesource.com/boringssl/+/8f3019e849afe428d0e29f34294a6328c8105b83",
      "gitiles_ref:refs/heads/master",
      "scheduler_invocation_id:9048183211261461744",
      "scheduler_job_id:boringssl/android_arm_armmode_rel",
      "swarming_hostname:chromium-swarm.appspot.com",
      "swarming_tag:log_location:logdog://logs.chromium.org/boringssl/buildbucket/cr-buildbucket.appspot.com/8882753149219985744/+/annotations",
      "swarming_tag:luci_project:boringssl",
      "swarming_tag:recipe_name:boringssl",
      "swarming_tag:recipe_package:infra/recipe_bundles/chromium.googlesource.com/chromium/tools/build",
      "swarming_task_id:",
      "user_agent:luci-scheduler"
    ],
    "updated_ts": "1587143485685771",
    "url": "https://ci.chromium.org/b/8882753149219985744",
    "utcnow_ts": "1587143486089780"
  }
}
[17:11:26.114] Task URL: https://ci.chromium.org/b/8882753149219985744
[17:11:26.114] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:2:0) after 1m0s
[17:12:03.695] Received PubSub notification, asking Buildbucket for the build status
[17:12:03.920] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:12:26.286] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:2:0)
[17:12:26.286] Timer tick, asking Buildbucket for the build status
[17:12:26.401] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:12:26.401] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:4:0) after 1m0s
[17:13:26.518] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:4:0)
[17:13:26.518] Timer tick, asking Buildbucket for the build status
[17:13:26.685] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:13:26.685] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:5:0) after 1m0s
[17:14:26.736] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:5:0)
[17:14:26.736] Timer tick, asking Buildbucket for the build status
[17:14:27.461] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:14:27.461] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:6:0) after 1m0s
[17:15:27.835] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:6:0)
[17:15:27.835] Timer tick, asking Buildbucket for the build status
[17:15:28.054] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:15:28.054] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:7:0) after 1m0s
[17:16:28.311] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:7:0)
[17:16:28.311] Timer tick, asking Buildbucket for the build status
[17:16:28.755] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:16:28.755] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:8:0) after 1m0s
[17:17:28.879] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:8:0)
[17:17:28.879] Timer tick, asking Buildbucket for the build status
[17:17:29.216] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:17:29.216] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:9:0) after 1m0s
[17:18:29.642] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:9:0)
[17:18:29.642] Timer tick, asking Buildbucket for the build status
[17:18:29.764] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:18:29.764] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:10:0) after 1m0s
[17:19:29.981] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:10:0)
[17:19:29.981] Timer tick, asking Buildbucket for the build status
[17:19:30.169] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:19:30.169] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:11:0) after 1m0s
[17:20:30.325] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:11:0)
[17:20:30.325] Timer tick, asking Buildbucket for the build status
[17:20:30.426] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:20:30.427] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:12:0) after 1m0s
[17:21:30.500] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:12:0)
[17:21:30.500] Timer tick, asking Buildbucket for the build status
[17:21:30.717] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:21:30.717] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:13:0) after 1m0s
[17:22:30.717] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:13:0)
[17:22:30.717] Timer tick, asking Buildbucket for the build status
[17:22:31.173] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:22:31.173] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:14:0) after 1m0s
[17:23:31.292] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:14:0)
[17:23:31.292] Timer tick, asking Buildbucket for the build status
[17:23:31.445] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:23:31.445] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:15:0) after 1m0s
[17:24:31.593] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:15:0)
[17:24:31.593] Timer tick, asking Buildbucket for the build status
[17:24:31.983] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:24:31.983] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:16:0) after 1m0s
[17:25:32.166] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:16:0)
[17:25:32.166] Timer tick, asking Buildbucket for the build status
[17:25:32.330] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:25:32.330] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:17:0) after 1m0s
[17:26:32.461] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:17:0)
[17:26:32.461] Timer tick, asking Buildbucket for the build status
[17:26:32.655] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:26:32.655] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:18:0) after 1m0s
[17:27:32.707] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:18:0)
[17:27:32.707] Timer tick, asking Buildbucket for the build status
[17:27:32.879] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:27:32.879] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:19:0) after 1m0s
[17:28:33.141] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:19:0)
[17:28:33.141] Timer tick, asking Buildbucket for the build status
[17:28:33.314] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:28:33.314] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:20:0) after 1m0s
[17:29:33.547] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:20:0)
[17:29:33.547] Timer tick, asking Buildbucket for the build status
[17:29:34.428] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:29:34.428] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:21:0) after 1m0s
[17:30:34.599] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:21:0)
[17:30:34.599] Timer tick, asking Buildbucket for the build status
[17:30:35.006] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:30:35.006] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:22:0) after 1m0s
[17:31:35.329] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:22:0)
[17:31:35.329] Timer tick, asking Buildbucket for the build status
[17:31:39.328] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:31:39.329] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:23:0) after 1m0s
[17:32:39.595] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:23:0)
[17:32:39.595] Timer tick, asking Buildbucket for the build status
[17:32:39.765] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:32:39.765] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:24:0) after 1m0s
[17:33:40.051] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:24:0)
[17:33:40.051] Timer tick, asking Buildbucket for the build status
[17:33:40.200] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:33:40.200] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:25:0) after 1m0s
[17:34:40.296] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:25:0)
[17:34:40.296] Timer tick, asking Buildbucket for the build status
[17:34:41.004] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:34:41.004] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:26:0) after 1m0s
[17:35:41.078] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:26:0)
[17:35:41.078] Timer tick, asking Buildbucket for the build status
[17:35:41.252] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:35:41.252] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:27:0) after 1m0s
[17:36:41.304] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:27:0)
[17:36:41.304] Timer tick, asking Buildbucket for the build status
[17:36:41.505] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:36:41.505] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:28:0) after 1m0s
[17:37:41.537] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:28:0)
[17:37:41.537] Timer tick, asking Buildbucket for the build status
[17:37:41.613] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:37:41.613] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:29:0) after 1m0s
[17:38:41.677] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:29:0)
[17:38:41.677] Timer tick, asking Buildbucket for the build status
[17:38:41.884] Build 8882753149219985744: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:38:41.884] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9048183211261461744:30:0) after 1m0s
[17:39:22.245] Received PubSub notification, asking Buildbucket for the build status
[17:39:23.117] Build 8882753149219985744: status "COMPLETED", result "SUCCESS", failure_reason "", cancelation_reason ""
[17:39:23.117] Buildbucket build:
{
  "build": {
    "bucket": "luci.boringssl.ci",
    "canary_preference": "PROD",
    "completed_ts": "1587145161407956",
    "created_by": "project:boringssl",
    "created_ts": "1587143484820587",
    "id": "8882753149219985744",
    "parameters_json": "{\"builder_name\": \"android_arm_armmode_rel\", \"properties\": {\"$recipe_engine/scheduler\": {\"hostname\": \"luci-scheduler.appspot.com\", \"triggers\": [{\"gitiles\": {\"ref\": \"refs/heads/master\", \"repo\": \"https://boringssl.googlesource.com/boringssl\", \"revision\": \"8f3019e849afe428d0e29f34294a6328c8105b83\"}, \"id\": \"https://boringssl.googlesource.com/boringssl/+/refs/heads/master@8f3019e849afe428d0e29f34294a6328c8105b83\", \"title\": \"8f3019e849afe428d0e29f34294a6328c8105b83\", \"url\": \"https://boringssl.googlesource.com/boringssl/+/8f3019e849afe428d0e29f34294a6328c8105b83\"}]}, \"branch\": \"refs/heads/master\", \"repository\": \"https://boringssl.googlesource.com/boringssl\", \"revision\": \"8f3019e849afe428d0e29f34294a6328c8105b83\"}}",
    "project": "boringssl",
    "result": "SUCCESS",
    "result_details_json": "{\"properties\": {\"$gatekeeper\": {\"group\": \"client.boringssl\"}, \"$recipe_engine/path\": {\"cache_dir\": \"/b/swarming/w/ir/cache\", \"temp_dir\": \"/b/swarming/w/ir/tmp/rt\"}, \"$recipe_engine/runtime\": {\"is_experimental\": false, \"is_luci\": true}, \"$recipe_engine/scheduler\": {\"hostname\": \"luci-scheduler.appspot.com\", \"triggers\": [{\"gitiles\": {\"ref\": \"refs/heads/master\", \"repo\": \"https://boringssl.googlesource.com/boringssl\", \"revision\": \"8f3019e849afe428d0e29f34294a6328c8105b83\"}, \"id\": \"https://boringssl.googlesource.com/boringssl/+/refs/heads/master@8f3019e849afe428d0e29f34294a6328c8105b83\", \"title\": \"8f3019e849afe428d0e29f34294a6328c8105b83\", \"url\": \"https://boringssl.googlesource.com/boringssl/+/8f3019e849afe428d0e29f34294a6328c8105b83\"}]}, \"bot_id\": \"build6-b9--device2\", \"branch\": \"refs/heads/master\", \"buildername\": \"android_arm_armmode_rel\", \"got_revision\": \"8f3019e849afe428d0e29f34294a6328c8105b83\", \"path_config\": \"generic\", \"recipe\": \"boringssl\", \"repository\": \"https://boringssl.googlesource.com/boringssl\", \"revision\": \"8f3019e849afe428d0e29f34294a6328c8105b83\"}, \"swarming\": {\"bot_dimensions\": {\"android_devices\": [\"1\"], \"caches\": [\"git\", \"vpython\"], \"device_gms_core_version\": [\"8.1.86\"], \"device_os\": [\"M\", \"MMB29Q\"], \"device_os_flavor\": [\"google\"], \"device_os_type\": [\"userdebug\"], \"device_playstore_version\": [\"5.12.7\"], \"device_type\": [\"bullhead\"], \"gce\": [\"0\"], \"id\": [\"build6-b9--device2\"], \"inside_docker\": [\"1\", \"stock\"], \"locale\": [\"en_US.UTF-8\"], \"os\": [\"Android\"], \"pool\": [\"luci.flex.ci\"], \"python\": [\"2.7.12\"], \"server_version\": [\"4985-2a273fe\"], \"temp_band\": [\"\u003e=30\"], \"zone\": [\"us\", \"us-mtv\", \"us-mtv-chops\", \"us-mtv-chops-b9\"]}}}",
    "service_account": "boringssl-ci-builder@chops-service-accounts.iam.gserviceaccount.com",
    "started_ts": "1587143522444232",
    "status": "COMPLETED",
    "status_changed_ts": "1587145161859150",
    "tags": [
      "builder:android_arm_armmode_rel",
      "buildset:commit/git/8f3019e849afe428d0e29f34294a6328c8105b83",
      "buildset:commit/gitiles/boringssl.googlesource.com/boringssl/+/8f3019e849afe428d0e29f34294a6328c8105b83",
      "gitiles_ref:refs/heads/master",
      "scheduler_invocation_id:9048183211261461744",
      "scheduler_job_id:boringssl/android_arm_armmode_rel",
      "swarming_hostname:chromium-swarm.appspot.com",
      "swarming_tag:log_location:logdog://logs.chromium.org/boringssl/buildbucket/cr-buildbucket.appspot.com/8882753149219985744/+/annotations",
      "swarming_tag:luci_project:boringssl",
      "swarming_tag:os:Android",
      "swarming_tag:recipe_name:boringssl",
      "swarming_tag:recipe_package:infra/recipe_bundles/chromium.googlesource.com/chromium/tools/build",
      "swarming_task_id:4ba1f14ad8faa410",
      "user_agent:luci-scheduler"
    ],
    "updated_ts": "1587145161874277",
    "url": "https://ci.chromium.org/b/8882753149219985744",
    "utcnow_ts": "1587145163056781"
  }
}
[17:39:23.118] Invocation finished in 27m59.628885724s with status SUCCEEDED