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": "1f1af82f409cd05450b3491865af0c770830cd76"
}

Incoming tags

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

Debug log (UTC)

[16:49:47.486] New invocation is queued and will start shortly
[16:49:50.246] Starting the invocation (attempt 1)
[16:49:50.311] Preparing PubSub topic for "https://cr-buildbucket.appspot.com"
[16:49:50.312] PubSub topic is "projects/luci-scheduler/topics/scheduler.buildbucket.cr-buildbucket~appspot.gserviceaccount.com"
[16:49:50.312] Buildbucket request:
{
  "bucket": "luci.boringssl.ci",
  "client_operation_id": "9066847545342902912",
  "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\":\"1f1af82f409cd05450b3491865af0c770830cd76\"},\"id\":\"https://boringssl.googlesource.com/boringssl.git/+/refs/heads/master@1f1af82f409cd05450b3491865af0c770830cd76\",\"title\":\"1f1af82f409cd05450b3491865af0c770830cd76\",\"url\":\"https://boringssl.googlesource.com/boringssl.git/+/1f1af82f409cd05450b3491865af0c770830cd76\"}]},\"branch\":\"refs/heads/master\",\"repository\":\"https://boringssl.googlesource.com/boringssl.git\",\"revision\":\"1f1af82f409cd05450b3491865af0c770830cd76\"}}",
  "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:9066847545342902912",
    "scheduler_job_id:boringssl/android_arm_armmode_rel",
    "user_agent:luci-scheduler",
    "buildset:commit/git/1f1af82f409cd05450b3491865af0c770830cd76",
    "buildset:commit/gitiles/boringssl.googlesource.com/boringssl/+/1f1af82f409cd05450b3491865af0c770830cd76",
    "gitiles_ref:refs/heads/master"
  ]
}
[16:49:51.680] Buildbucket response:
{
  "build": {
    "bucket": "luci.boringssl.ci",
    "canary_preference": "PROD",
    "created_by": "project:boringssl",
    "created_ts": "1569343790520294",
    "id": "8901417481470311648",
    "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\": \"1f1af82f409cd05450b3491865af0c770830cd76\"}, \"id\": \"https://boringssl.googlesource.com/boringssl.git/+/refs/heads/master@1f1af82f409cd05450b3491865af0c770830cd76\", \"title\": \"1f1af82f409cd05450b3491865af0c770830cd76\", \"url\": \"https://boringssl.googlesource.com/boringssl.git/+/1f1af82f409cd05450b3491865af0c770830cd76\"}]}, \"branch\": \"refs/heads/master\", \"repository\": \"https://boringssl.googlesource.com/boringssl.git\", \"revision\": \"1f1af82f409cd05450b3491865af0c770830cd76\"}}",
    "project": "boringssl",
    "result_details_json": "{\"properties\": {}}",
    "service_account": "boringssl-ci-builder@chops-service-accounts.iam.gserviceaccount.com",
    "status": "SCHEDULED",
    "status_changed_ts": "1569343791365220",
    "tags": [
      "builder:android_arm_armmode_rel",
      "buildset:commit/git/1f1af82f409cd05450b3491865af0c770830cd76",
      "buildset:commit/gitiles/boringssl.googlesource.com/boringssl/+/1f1af82f409cd05450b3491865af0c770830cd76",
      "gitiles_ref:refs/heads/master",
      "scheduler_invocation_id:9066847545342902912",
      "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/8901417481470311648/+/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": "1569343791365424",
    "url": "https://ci.chromium.org/b/8901417481470311648",
    "utcnow_ts": "1569343791664892"
  }
}
[16:49:51.680] Task URL: https://ci.chromium.org/b/8901417481470311648
[16:49:51.680] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:2:0) after 1m0s
[16:50:51.746] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:2:0)
[16:50:51.746] Timer tick, asking Buildbucket for the build status
[16:50:52.881] Build 8901417481470311648: status "SCHEDULED", result "", failure_reason "", cancelation_reason ""
[16:50:52.881] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:3:0) after 1m0s
[16:51:07.887] Received PubSub notification, asking Buildbucket for the build status
[16:51:10.789] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:51:52.931] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:3:0)
[16:51:52.931] Timer tick, asking Buildbucket for the build status
[16:51:54.468] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:51:54.468] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:5:0) after 1m0s
[16:52:54.761] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:5:0)
[16:52:54.761] Timer tick, asking Buildbucket for the build status
[16:52:55.135] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:52:55.135] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:6:0) after 1m0s
[16:53:55.301] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:6:0)
[16:53:55.301] Timer tick, asking Buildbucket for the build status
[16:53:55.392] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:53:55.392] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:7:0) after 1m0s
[16:54:55.578] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:7:0)
[16:54:55.578] Timer tick, asking Buildbucket for the build status
[16:54:56.241] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:54:56.241] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:8:0) after 1m0s
[16:55:56.416] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:8:0)
[16:55:56.416] Timer tick, asking Buildbucket for the build status
[16:55:57.024] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:55:57.024] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:9:0) after 1m0s
[16:56:57.128] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:9:0)
[16:56:57.128] Timer tick, asking Buildbucket for the build status
[16:56:57.546] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:56:57.546] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:10:0) after 1m0s
[16:57:57.613] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:10:0)
[16:57:57.613] Timer tick, asking Buildbucket for the build status
[16:57:58.063] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:57:58.063] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:11:0) after 1m0s
[16:58:58.155] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:11:0)
[16:58:58.155] Timer tick, asking Buildbucket for the build status
[16:58:58.505] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:58:58.505] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:12:0) after 1m0s
[16:59:58.637] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:12:0)
[16:59:58.637] Timer tick, asking Buildbucket for the build status
[16:59:59.799] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[16:59:59.799] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:13:0) after 1m0s
[17:00:59.840] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:13:0)
[17:00:59.840] Timer tick, asking Buildbucket for the build status
[17:00:59.958] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:00:59.959] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:14:0) after 1m0s
[17:01:59.980] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:14:0)
[17:01:59.980] Timer tick, asking Buildbucket for the build status
[17:02:00.509] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:02:00.509] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:15:0) after 1m0s
[17:03:00.547] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:15:0)
[17:03:00.547] Timer tick, asking Buildbucket for the build status
[17:03:01.137] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:03:01.137] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:16:0) after 1m0s
[17:04:01.197] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:16:0)
[17:04:01.197] Timer tick, asking Buildbucket for the build status
[17:04:01.804] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:04:01.804] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:17:0) after 1m0s
[17:05:01.826] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:17:0)
[17:05:01.826] Timer tick, asking Buildbucket for the build status
[17:05:02.337] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:05:02.337] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:18:0) after 1m0s
[17:06:02.413] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:18:0)
[17:06:02.413] Timer tick, asking Buildbucket for the build status
[17:06:02.571] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:06:02.571] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:19:0) after 1m0s
[17:07:02.717] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:19:0)
[17:07:02.717] Timer tick, asking Buildbucket for the build status
[17:07:02.943] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:07:02.944] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:20:0) after 1m0s
[17:08:02.984] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:20:0)
[17:08:02.984] Timer tick, asking Buildbucket for the build status
[17:08:03.237] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:08:03.238] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:21:0) after 1m0s
[17:09:03.308] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:21:0)
[17:09:03.308] Timer tick, asking Buildbucket for the build status
[17:09:05.036] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:09:05.036] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:22:0) after 1m0s
[17:10:05.134] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:22:0)
[17:10:05.134] Timer tick, asking Buildbucket for the build status
[17:10:05.469] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:10:05.469] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:23:0) after 1m0s
[17:11:05.478] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:23:0)
[17:11:05.478] Timer tick, asking Buildbucket for the build status
[17:11:05.916] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:11:05.916] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:24:0) after 1m0s
[17:12:06.025] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:24:0)
[17:12:06.025] Timer tick, asking Buildbucket for the build status
[17:12:06.175] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:12:06.175] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:25:0) after 1m0s
[17:13:06.287] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:25:0)
[17:13:06.287] Timer tick, asking Buildbucket for the build status
[17:13:06.412] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:13:06.412] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:26:0) after 1m0s
[17:14:06.579] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:26:0)
[17:14:06.579] Timer tick, asking Buildbucket for the build status
[17:14:06.843] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:14:06.843] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:27:0) after 1m0s
[17:15:06.952] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:27:0)
[17:15:06.952] Timer tick, asking Buildbucket for the build status
[17:15:10.164] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:15:10.164] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:28:0) after 1m0s
[17:16:10.197] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:28:0)
[17:16:10.197] Timer tick, asking Buildbucket for the build status
[17:16:11.878] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:16:11.878] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:29:0) after 1m0s
[17:17:12.106] Handling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:29:0)
[17:17:12.106] Timer tick, asking Buildbucket for the build status
[17:17:14.162] Build 8901417481470311648: status "STARTED", result "", failure_reason "", cancelation_reason ""
[17:17:14.162] Scheduling timer "check-buildbucket-build-status" (boringssl/android_arm_armmode_rel:9066847545342902912:30:0) after 1m0s
[17:17:47.911] Received PubSub notification, asking Buildbucket for the build status
[17:17:48.237] Build 8901417481470311648: status "COMPLETED", result "SUCCESS", failure_reason "", cancelation_reason ""
[17:17:48.237] Buildbucket build:
{
  "build": {
    "bucket": "luci.boringssl.ci",
    "canary_preference": "PROD",
    "completed_ts": "1569345467109001",
    "created_by": "project:boringssl",
    "created_ts": "1569343790520294",
    "id": "8901417481470311648",
    "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\": \"1f1af82f409cd05450b3491865af0c770830cd76\"}, \"id\": \"https://boringssl.googlesource.com/boringssl.git/+/refs/heads/master@1f1af82f409cd05450b3491865af0c770830cd76\", \"title\": \"1f1af82f409cd05450b3491865af0c770830cd76\", \"url\": \"https://boringssl.googlesource.com/boringssl.git/+/1f1af82f409cd05450b3491865af0c770830cd76\"}]}, \"branch\": \"refs/heads/master\", \"repository\": \"https://boringssl.googlesource.com/boringssl.git\", \"revision\": \"1f1af82f409cd05450b3491865af0c770830cd76\"}}",
    "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\": \"1f1af82f409cd05450b3491865af0c770830cd76\"}, \"id\": \"https://boringssl.googlesource.com/boringssl.git/+/refs/heads/master@1f1af82f409cd05450b3491865af0c770830cd76\", \"title\": \"1f1af82f409cd05450b3491865af0c770830cd76\", \"url\": \"https://boringssl.googlesource.com/boringssl.git/+/1f1af82f409cd05450b3491865af0c770830cd76\"}]}, \"bot_id\": \"build6-b9--device2\", \"branch\": \"refs/heads/master\", \"buildername\": \"android_arm_armmode_rel\", \"got_revision\": \"1f1af82f409cd05450b3491865af0c770830cd76\", \"path_config\": \"generic\", \"recipe\": \"boringssl\", \"repository\": \"https://boringssl.googlesource.com/boringssl.git\", \"revision\": \"1f1af82f409cd05450b3491865af0c770830cd76\"}, \"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": "1569343866465285",
    "status": "COMPLETED",
    "status_changed_ts": "1569345467599491",
    "tags": [
      "builder:android_arm_armmode_rel",
      "buildset:commit/git/1f1af82f409cd05450b3491865af0c770830cd76",
      "buildset:commit/gitiles/boringssl.googlesource.com/boringssl/+/1f1af82f409cd05450b3491865af0c770830cd76",
      "gitiles_ref:refs/heads/master",
      "scheduler_invocation_id:9066847545342902912",
      "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/8901417481470311648/+/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:477d001e11327110",
      "user_agent:luci-scheduler"
    ],
    "updated_ts": "1569345467608951",
    "url": "https://ci.chromium.org/b/8901417481470311648",
    "utcnow_ts": "1569345468208191"
  }
}
[17:17:48.237] Invocation finished in 28m0.793569878s with status SUCCEEDED