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.git",
  "revision": "a93bebafb891227d755f5d23e7be94de7174705f"
}

Incoming tags

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

Debug log (UTC)

[21:24:48.341] New invocation is queued and will start shortly
[21:24:50.164] Starting the invocation (attempt 1)
[21:24:50.302] Preparing PubSub topic for "https://cr-buildbucket.appspot.com"
[21:24:50.302] PubSub topic is "projects/luci-scheduler/topics/scheduler.buildbucket.cr-buildbucket~appspot.gserviceaccount.com"
[21:24:50.302] Buildbucket request:
{
  "bucket": "luci.boringssl.ci",
  "client_operation_id": "9064927706622786816",
  "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\":\"a93bebafb891227d755f5d23e7be94de7174705f\"},\"id\":\"https://boringssl.googlesource.com/boringssl.git/+/refs/heads/master@a93bebafb891227d755f5d23e7be94de7174705f\",\"title\":\"a93bebafb891227d755f5d23e7be94de7174705f\",\"url\":\"https://boringssl.googlesource.com/boringssl.git/+/a93bebafb891227d755f5d23e7be94de7174705f\"}]},\"branch\":\"refs/heads/master\",\"repository\":\"https://boringssl.googlesource.com/boringssl.git\",\"revision\":\"a93bebafb891227d755f5d23e7be94de7174705f\"}}",
  "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:9064927706622786816",
    "scheduler_job_id:boringssl/android_arm_armmode_rel",
    "user_agent:luci-scheduler",
    "buildset:commit/git/a93bebafb891227d755f5d23e7be94de7174705f",
    "buildset:commit/gitiles/boringssl.googlesource.com/boringssl/+/a93bebafb891227d755f5d23e7be94de7174705f",
    "gitiles_ref:refs/heads/master"
  ]
}
[21:24:52.830] Buildbucket response:
{
  "build": {
    "bucket": "luci.boringssl.ci",
    "canary_preference": "PROD",
    "created_by": "project:boringssl",
    "created_ts": "1571174690926296",
    "id": "8899497643246260640",
    "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\": \"a93bebafb891227d755f5d23e7be94de7174705f\"}, \"id\": \"https://boringssl.googlesource.com/boringssl.git/+/refs/heads/master@a93bebafb891227d755f5d23e7be94de7174705f\", \"title\": \"a93bebafb891227d755f5d23e7be94de7174705f\", \"url\": \"https://boringssl.googlesource.com/boringssl.git/+/a93bebafb891227d755f5d23e7be94de7174705f\"}]}, \"branch\": \"refs/heads/master\", \"repository\": \"https://boringssl.googlesource.com/boringssl.git\", \"revision\": \"a93bebafb891227d755f5d23e7be94de7174705f\"}}",
    "project": "boringssl",
    "result_details_json": "{\"properties\": {}}",
    "service_account": "boringssl-ci-builder@chops-service-accounts.iam.gserviceaccount.com",
    "status": "SCHEDULED",
    "status_changed_ts": "1571174692177522",
    "tags": [
      "builder:android_arm_armmode_rel",
      "buildset:commit/git/a93bebafb891227d755f5d23e7be94de7174705f",
      "buildset:commit/gitiles/boringssl.googlesource.com/boringssl/+/a93bebafb891227d755f5d23e7be94de7174705f",
      "gitiles_ref:refs/heads/master",
      "scheduler_invocation_id:9064927706622786816",
      "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/8899497643246260640/+/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": "1571174692177691",
    "url": "https://ci.chromium.org/b/8899497643246260640",
    "utcnow_ts": "1571174692797780"
  }
}
[21:24:52.830] Task URL: https://ci.chromium.org/b/8899497643246260640
[21:24:52.830] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:2:0) after 1m0s
[21:25:52.874] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:2:0)
[21:25:52.874] Timer tick, asking Buildbucket for the build status
[21:25:54.342] Build 8899497643246260640: status "SCHEDULED", result "", failure_reason "", cancelation_reason ""
[21:25:54.342] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:3:0) after 1m0s
[21:26:03.932] Received PubSub notification, asking Buildbucket for the build status
[21:26:04.189] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:26:54.484] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:3:0)
[21:26:54.484] Timer tick, asking Buildbucket for the build status
[21:26:54.593] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:26:54.593] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:5:0) after 1m0s
[21:27:54.750] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:5:0)
[21:27:54.750] Timer tick, asking Buildbucket for the build status
[21:27:55.063] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:27:55.063] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:6:0) after 1m0s
[21:28:55.268] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:6:0)
[21:28:55.268] Timer tick, asking Buildbucket for the build status
[21:28:55.772] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:28:55.772] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:7:0) after 1m0s
[21:29:55.860] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:7:0)
[21:29:55.860] Timer tick, asking Buildbucket for the build status
[21:29:56.334] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:29:56.334] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:8:0) after 1m0s
[21:30:56.531] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:8:0)
[21:30:56.531] Timer tick, asking Buildbucket for the build status
[21:30:56.667] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:30:56.667] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:9:0) after 1m0s
[21:31:56.701] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:9:0)
[21:31:56.701] Timer tick, asking Buildbucket for the build status
[21:31:58.103] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:31:58.103] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:10:0) after 1m0s
[21:32:58.121] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:10:0)
[21:32:58.121] Timer tick, asking Buildbucket for the build status
[21:32:58.627] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:32:58.627] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:11:0) after 1m0s
[21:33:58.674] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:11:0)
[21:33:58.674] Timer tick, asking Buildbucket for the build status
[21:33:58.824] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:33:58.824] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:12:0) after 1m0s
[21:34:58.846] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:12:0)
[21:34:58.846] Timer tick, asking Buildbucket for the build status
[21:34:59.271] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:34:59.271] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:13:0) after 1m0s
[21:35:59.323] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:13:0)
[21:35:59.323] Timer tick, asking Buildbucket for the build status
[21:36:00.682] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:36:00.682] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:14:0) after 1m0s
[21:37:00.706] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:14:0)
[21:37:00.706] Timer tick, asking Buildbucket for the build status
[21:37:00.918] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:37:00.918] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:15:0) after 1m0s
[21:38:01.154] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:15:0)
[21:38:01.154] Timer tick, asking Buildbucket for the build status
[21:38:01.631] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:38:01.631] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:16:0) after 1m0s
[21:39:01.660] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:16:0)
[21:39:01.660] Timer tick, asking Buildbucket for the build status
[21:39:01.909] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:39:01.909] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:17:0) after 1m0s
[21:40:01.924] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:17:0)
[21:40:01.924] Timer tick, asking Buildbucket for the build status
[21:40:02.669] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:40:02.669] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:18:0) after 1m0s
[21:41:02.845] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:18:0)
[21:41:02.845] Timer tick, asking Buildbucket for the build status
[21:41:04.099] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:41:04.099] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:19:0) after 1m0s
[21:42:04.504] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:19:0)
[21:42:04.504] Timer tick, asking Buildbucket for the build status
[21:42:04.893] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:42:04.893] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:20:0) after 1m0s
[21:43:05.013] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:20:0)
[21:43:05.013] Timer tick, asking Buildbucket for the build status
[21:43:05.272] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:43:05.272] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:21:0) after 1m0s
[21:44:05.522] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:21:0)
[21:44:05.522] Timer tick, asking Buildbucket for the build status
[21:44:06.716] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:44:06.716] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:22:0) after 1m0s
[21:45:06.872] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:22:0)
[21:45:06.873] Timer tick, asking Buildbucket for the build status
[21:45:07.253] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:45:07.253] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:23:0) after 1m0s
[21:46:07.656] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:23:0)
[21:46:07.656] Timer tick, asking Buildbucket for the build status
[21:46:08.044] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:46:08.044] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:24:0) after 1m0s
[21:47:08.247] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:24:0)
[21:47:08.247] Timer tick, asking Buildbucket for the build status
[21:47:08.416] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:47:08.416] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:25:0) after 1m0s
[21:48:08.554] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:25:0)
[21:48:08.554] Timer tick, asking Buildbucket for the build status
[21:48:08.753] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:48:08.753] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:26:0) after 1m0s
[21:49:08.879] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:26:0)
[21:49:08.879] Timer tick, asking Buildbucket for the build status
[21:49:10.292] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:49:10.293] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:27:0) after 1m0s
[21:50:10.317] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:27:0)
[21:50:10.317] Timer tick, asking Buildbucket for the build status
[21:50:10.468] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:50:10.468] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:28:0) after 1m0s
[21:51:10.667] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:28:0)
[21:51:10.667] Timer tick, asking Buildbucket for the build status
[21:51:11.216] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:51:11.216] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:29:0) after 1m0s
[21:52:11.322] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:29:0)
[21:52:11.322] Timer tick, asking Buildbucket for the build status
[21:52:11.447] Build 8899497643246260640: status "STARTED", result "", failure_reason "", cancelation_reason ""
[21:52:11.447] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9064927706622786816:30:0) after 1m0s
[21:52:17.550] Received PubSub notification, asking Buildbucket for the build status
[21:52:18.452] Build 8899497643246260640: status "COMPLETED", result "SUCCESS", failure_reason "", cancelation_reason ""
[21:52:18.452] Buildbucket build:
{
  "build": {
    "bucket": "luci.boringssl.ci",
    "canary_preference": "PROD",
    "completed_ts": "1571176336465393",
    "created_by": "project:boringssl",
    "created_ts": "1571174690926296",
    "id": "8899497643246260640",
    "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\": \"a93bebafb891227d755f5d23e7be94de7174705f\"}, \"id\": \"https://boringssl.googlesource.com/boringssl.git/+/refs/heads/master@a93bebafb891227d755f5d23e7be94de7174705f\", \"title\": \"a93bebafb891227d755f5d23e7be94de7174705f\", \"url\": \"https://boringssl.googlesource.com/boringssl.git/+/a93bebafb891227d755f5d23e7be94de7174705f\"}]}, \"branch\": \"refs/heads/master\", \"repository\": \"https://boringssl.googlesource.com/boringssl.git\", \"revision\": \"a93bebafb891227d755f5d23e7be94de7174705f\"}}",
    "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\": \"a93bebafb891227d755f5d23e7be94de7174705f\"}, \"id\": \"https://boringssl.googlesource.com/boringssl.git/+/refs/heads/master@a93bebafb891227d755f5d23e7be94de7174705f\", \"title\": \"a93bebafb891227d755f5d23e7be94de7174705f\", \"url\": \"https://boringssl.googlesource.com/boringssl.git/+/a93bebafb891227d755f5d23e7be94de7174705f\"}]}, \"bot_id\": \"build6-b9--device3\", \"branch\": \"refs/heads/master\", \"buildername\": \"android_arm_armmode_rel\", \"got_revision\": \"a93bebafb891227d755f5d23e7be94de7174705f\", \"path_config\": \"generic\", \"recipe\": \"boringssl\", \"repository\": \"https://boringssl.googlesource.com/boringssl.git\", \"revision\": \"a93bebafb891227d755f5d23e7be94de7174705f\"}, \"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--device3\"], \"inside_docker\": [\"1\", \"stock\"], \"locale\": [\"en_US.UTF-8\"], \"os\": [\"Android\"], \"pool\": [\"luci.flex.ci\"], \"python\": [\"2.7.12\"], \"server_version\": [\"4501-487d554\"], \"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": "1571174761824860",
    "status": "COMPLETED",
    "status_changed_ts": "1571176337049502",
    "tags": [
      "builder:android_arm_armmode_rel",
      "buildset:commit/git/a93bebafb891227d755f5d23e7be94de7174705f",
      "buildset:commit/gitiles/boringssl.googlesource.com/boringssl/+/a93bebafb891227d755f5d23e7be94de7174705f",
      "gitiles_ref:refs/heads/master",
      "scheduler_invocation_id:9064927706622786816",
      "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/8899497643246260640/+/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:47ea219630b79410",
      "user_agent:luci-scheduler"
    ],
    "updated_ts": "1571176337064804",
    "url": "https://ci.chromium.org/b/8899497643246260640",
    "utcnow_ts": "1571176338409651"
  }
}
[21:52:18.452] Invocation finished in 27m30.130003228s with status SUCCEEDED