Status: SUCCEEDED
Triggered by: -
Duration: 28 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.git",
  "revision": "09a9ec036030ac84896f5143548d05f3951d1817"
}

Incoming tags

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

Debug log (UTC)

[15:50:43.249] New invocation is queued and will start shortly
[15:50:45.125] Starting the invocation (attempt 1)
[15:50:45.222] Preparing PubSub topic for "https://cr-buildbucket.appspot.com"
[15:50:45.222] PubSub topic is "projects/luci-scheduler/topics/scheduler.buildbucket.cr-buildbucket~appspot.gserviceaccount.com"
[15:50:45.222] Buildbucket request:
{
  "bucket": "luci.boringssl.ci",
  "client_operation_id": "9066941858683674144",
  "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.git\",\"revision\":\"09a9ec036030ac84896f5143548d05f3951d1817\"},\"id\":\"https://boringssl.googlesource.com/boringssl.git/+/refs/heads/master@09a9ec036030ac84896f5143548d05f3951d1817\",\"title\":\"09a9ec036030ac84896f5143548d05f3951d1817\",\"url\":\"https://boringssl.googlesource.com/boringssl.git/+/09a9ec036030ac84896f5143548d05f3951d1817\"}]},\"branch\":\"refs/heads/master\",\"repository\":\"https://boringssl.googlesource.com/boringssl.git\",\"revision\":\"09a9ec036030ac84896f5143548d05f3951d1817\"}}",
  "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:9066941858683674144",
    "scheduler_job_id:boringssl/android_arm_armmode_rel",
    "user_agent:luci-scheduler",
    "buildset:commit/git/09a9ec036030ac84896f5143548d05f3951d1817",
    "buildset:commit/gitiles/boringssl.googlesource.com/boringssl/+/09a9ec036030ac84896f5143548d05f3951d1817",
    "gitiles_ref:refs/heads/master"
  ]
}
[15:50:46.879] Buildbucket response:
{
  "build": {
    "bucket": "luci.boringssl.ci",
    "canary_preference": "PROD",
    "created_by": "project:boringssl",
    "created_ts": "1569253845529508",
    "id": "8901511795628428400",
    "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.git\", \"revision\": \"09a9ec036030ac84896f5143548d05f3951d1817\"}, \"id\": \"https://boringssl.googlesource.com/boringssl.git/+/refs/heads/master@09a9ec036030ac84896f5143548d05f3951d1817\", \"title\": \"09a9ec036030ac84896f5143548d05f3951d1817\", \"url\": \"https://boringssl.googlesource.com/boringssl.git/+/09a9ec036030ac84896f5143548d05f3951d1817\"}]}, \"branch\": \"refs/heads/master\", \"repository\": \"https://boringssl.googlesource.com/boringssl.git\", \"revision\": \"09a9ec036030ac84896f5143548d05f3951d1817\"}}",
    "project": "boringssl",
    "result_details_json": "{\"properties\": {}}",
    "service_account": "boringssl-ci-builder@chops-service-accounts.iam.gserviceaccount.com",
    "status": "SCHEDULED",
    "status_changed_ts": "1569253846575719",
    "tags": [
      "builder:android_arm_armmode_rel",
      "buildset:commit/git/09a9ec036030ac84896f5143548d05f3951d1817",
      "buildset:commit/gitiles/boringssl.googlesource.com/boringssl/+/09a9ec036030ac84896f5143548d05f3951d1817",
      "gitiles_ref:refs/heads/master",
      "scheduler_invocation_id:9066941858683674144",
      "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/8901511795628428400/+/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": "1569253846575994",
    "url": "https://ci.chromium.org/b/8901511795628428400",
    "utcnow_ts": "1569253846855839"
  }
}
[15:50:46.879] Task URL: https://ci.chromium.org/b/8901511795628428400
[15:50:46.879] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:2:0) after 1m0s
[15:51:47.145] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:2:0)
[15:51:47.145] Timer tick, asking Buildbucket for the build status
[15:51:47.395] Build 8901511795628428400: status "SCHEDULED", result "", failure_reason "", cancelation_reason ""
[15:51:47.395] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:3:0) after 1m0s
[15:52:20.978] Received PubSub notification, asking Buildbucket for the build status
[15:52:21.624] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[15:52:47.453] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:3:0)
[15:52:47.453] Timer tick, asking Buildbucket for the build status
[15:52:48.389] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[15:52:48.389] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:5:0) after 1m0s
[15:53:48.780] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:5:0)
[15:53:48.780] Timer tick, asking Buildbucket for the build status
[15:53:49.070] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[15:53:49.070] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:6:0) after 1m0s
[15:54:49.411] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:6:0)
[15:54:49.411] Timer tick, asking Buildbucket for the build status
[15:54:49.558] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[15:54:49.558] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:7:0) after 1m0s
[15:55:50.026] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:7:0)
[15:55:50.026] Timer tick, asking Buildbucket for the build status
[15:55:50.698] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[15:55:50.699] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:8:0) after 1m0s
[15:56:50.838] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:8:0)
[15:56:50.838] Timer tick, asking Buildbucket for the build status
[15:56:51.611] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[15:56:51.611] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:9:0) after 1m0s
[15:57:51.730] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:9:0)
[15:57:51.730] Timer tick, asking Buildbucket for the build status
[15:57:56.139] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[15:57:56.140] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:10:0) after 1m0s
[15:58:56.243] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:10:0)
[15:58:56.243] Timer tick, asking Buildbucket for the build status
[15:58:56.737] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[15:58:56.738] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:11:0) after 1m0s
[15:59:57.099] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:11:0)
[15:59:57.099] Timer tick, asking Buildbucket for the build status
[15:59:57.843] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[15:59:57.843] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:12:0) after 1m0s
[16:00:58.206] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:12:0)
[16:00:58.206] Timer tick, asking Buildbucket for the build status
[16:00:58.296] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:00:58.296] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:13:0) after 1m0s
[16:01:59.226] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:13:0)
[16:01:59.226] Timer tick, asking Buildbucket for the build status
[16:01:59.420] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:01:59.420] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:14:0) after 1m0s
[16:03:00.033] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:14:0)
[16:03:00.033] Timer tick, asking Buildbucket for the build status
[16:03:00.173] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:03:00.173] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:15:0) after 1m0s
[16:04:00.604] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:15:0)
[16:04:00.604] Timer tick, asking Buildbucket for the build status
[16:04:00.679] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:04:00.679] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:16:0) after 1m0s
[16:05:01.147] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:16:0)
[16:05:01.147] Timer tick, asking Buildbucket for the build status
[16:05:01.391] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:05:01.391] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:17:0) after 1m0s
[16:06:01.622] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:17:0)
[16:06:01.622] Timer tick, asking Buildbucket for the build status
[16:06:02.049] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:06:02.049] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:18:0) after 1m0s
[16:07:02.138] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:18:0)
[16:07:02.138] Timer tick, asking Buildbucket for the build status
[16:07:03.033] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:07:03.033] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:19:0) after 1m0s
[16:08:03.293] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:19:0)
[16:08:03.293] Timer tick, asking Buildbucket for the build status
[16:08:03.471] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:08:03.471] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:20:0) after 1m0s
[16:09:03.533] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:20:0)
[16:09:03.533] Timer tick, asking Buildbucket for the build status
[16:09:09.734] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:09:09.734] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:21:0) after 1m0s
[16:10:09.850] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:21:0)
[16:10:09.850] Timer tick, asking Buildbucket for the build status
[16:10:10.101] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:10:10.101] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:22:0) after 1m0s
[16:11:10.191] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:22:0)
[16:11:10.191] Timer tick, asking Buildbucket for the build status
[16:11:10.437] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:11:10.437] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:23:0) after 1m0s
[16:12:10.470] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:23:0)
[16:12:10.470] Timer tick, asking Buildbucket for the build status
[16:12:11.065] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:12:11.065] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:24:0) after 1m0s
[16:13:11.126] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:24:0)
[16:13:11.126] Timer tick, asking Buildbucket for the build status
[16:13:11.727] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:13:11.727] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:25:0) after 1m0s
[16:14:11.795] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:25:0)
[16:14:11.795] Timer tick, asking Buildbucket for the build status
[16:14:11.927] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:14:11.927] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:26:0) after 1m0s
[16:15:12.052] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:26:0)
[16:15:12.052] Timer tick, asking Buildbucket for the build status
[16:15:12.841] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:15:12.841] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:27:0) after 1m0s
[16:16:12.941] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:27:0)
[16:16:12.941] Timer tick, asking Buildbucket for the build status
[16:16:13.199] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:16:13.199] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:28:0) after 1m0s
[16:17:13.358] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:28:0)
[16:17:13.358] Timer tick, asking Buildbucket for the build status
[16:17:13.703] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:17:13.703] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:29:0) after 1m0s
[16:18:13.788] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:29:0)
[16:18:13.788] Timer tick, asking Buildbucket for the build status
[16:18:14.986] Build 8901511795628428400: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:18:14.986] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066941858683674144:30:0) after 1m0s
[16:18:56.703] Received PubSub notification, asking Buildbucket for the build status
[16:18:56.808] Build 8901511795628428400: status "COMPLETED", result "SUCCESS", failure_reason "", cancelation_reason ""
[16:18:56.808] Buildbucket build:
{
  "build": {
    "bucket": "luci.boringssl.ci",
    "canary_preference": "PROD",
    "completed_ts": "1569255535466036",
    "created_by": "project:boringssl",
    "created_ts": "1569253845529508",
    "id": "8901511795628428400",
    "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.git\", \"revision\": \"09a9ec036030ac84896f5143548d05f3951d1817\"}, \"id\": \"https://boringssl.googlesource.com/boringssl.git/+/refs/heads/master@09a9ec036030ac84896f5143548d05f3951d1817\", \"title\": \"09a9ec036030ac84896f5143548d05f3951d1817\", \"url\": \"https://boringssl.googlesource.com/boringssl.git/+/09a9ec036030ac84896f5143548d05f3951d1817\"}]}, \"branch\": \"refs/heads/master\", \"repository\": \"https://boringssl.googlesource.com/boringssl.git\", \"revision\": \"09a9ec036030ac84896f5143548d05f3951d1817\"}}",
    "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.git\", \"revision\": \"09a9ec036030ac84896f5143548d05f3951d1817\"}, \"id\": \"https://boringssl.googlesource.com/boringssl.git/+/refs/heads/master@09a9ec036030ac84896f5143548d05f3951d1817\", \"title\": \"09a9ec036030ac84896f5143548d05f3951d1817\", \"url\": \"https://boringssl.googlesource.com/boringssl.git/+/09a9ec036030ac84896f5143548d05f3951d1817\"}]}, \"bot_id\": \"build6-b9--device2\", \"branch\": \"refs/heads/master\", \"buildername\": \"android_arm_armmode_rel\", \"got_revision\": \"09a9ec036030ac84896f5143548d05f3951d1817\", \"path_config\": \"generic\", \"recipe\": \"boringssl\", \"repository\": \"https://boringssl.googlesource.com/boringssl.git\", \"revision\": \"09a9ec036030ac84896f5143548d05f3951d1817\"}, \"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\": [\"4443-3a52fcb\"], \"temp_band\": [\"\u003c30\"], \"zone\": [\"us\", \"us-mtv\", \"us-mtv-chops\", \"us-mtv-chops-b9\"]}}}",
    "service_account": "boringssl-ci-builder@chops-service-accounts.iam.gserviceaccount.com",
    "started_ts": "1569253939976090",
    "status": "COMPLETED",
    "status_changed_ts": "1569255535902519",
    "tags": [
      "builder:android_arm_armmode_rel",
      "buildset:commit/git/09a9ec036030ac84896f5143548d05f3951d1817",
      "buildset:commit/gitiles/boringssl.googlesource.com/boringssl/+/09a9ec036030ac84896f5143548d05f3951d1817",
      "gitiles_ref:refs/heads/master",
      "scheduler_invocation_id:9066941858683674144",
      "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/8901511795628428400/+/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:4777a35e49961010",
      "user_agent:luci-scheduler"
    ],
    "updated_ts": "1569255535952803",
    "url": "https://ci.chromium.org/b/8901511795628428400",
    "utcnow_ts": "1569255536788605"
  }
}
[16:18:56.808] Invocation finished in 28m13.576812297s with status SUCCEEDED