commit | 4466e142c82f6dd56d79262269fe949ca5af7d00 | [log] [tgz] |
---|---|---|
author | William Hesse <whesse@google.com> | Mon Mar 23 08:32:42 2020 +0000 |
committer | William Hesse <whesse@google.com> | Mon Mar 23 08:32:42 2020 +0000 |
tree | 0b32b72398e9bc1e85485fcadc4ee1e389a0896f | |
parent | f8122b57493e47111551f0838202fe8d306f781b [diff] |
[cloud functions] Handle race condition when deleting active configurations When the last two active configurations are deleted, one call can check for empty and delete, before the other call checks for empty. Change-Id: Ib03dc12635630b558419ed4747fcde70d6969602 Reviewed-on: https://dart-review.googlesource.com/c/dart_ci/+/139340 Reviewed-by: Alexander Thomas <athom@google.com>
The repository is based at dart.googlesource.com/dart_ci. It is mirrored to github.com/dart-lang/dart_ci. Do not land pull requests on Github.
The results feed is an angular Dart application that displays changed results from the CI and from CQ runs (tryjobs). The code is in the results_feed directory. It is deployed to ci.dart.dev, using Firebase hosting.
The automated testing of Dart on the CI and CQ publishes results to Cloud Pubsub, and cloud functions triggered by those Pubsub messages process the data and store it in Firestore. These functions are located in the functions directory, and are deployed on the dart-ci Google Cloud project.
Internal users get automatic notifications of new GitHub issues created in certain repositories, by subscribing to issue labels on those repositories. This tool provides a UI for internal users to subscribe to their chosen issue labels. That UI is hosted at dart-github-label-notifier.firebaseapp.com. It also defines cloud functions that are triggered by GitHub webhooks and use the issue label subscriptions to send email notifications using SendGrid.