From 133b815f2be59f40ff0b5aa674e6cae70f678672 Mon Sep 17 00:00:00 2001 From: Keith Lawrence Date: Mon, 2 Oct 2023 15:00:48 +0100 Subject: [PATCH 1/2] Add prometheus collector for oldest OS Places postcode --- config/initializers/prometheus.rb | 4 ++- lib/collectors/global_prometheus_collector.rb | 28 +++++++++++++++++++ .../global_prometheus_collector_spec.rb | 26 +++++++++++++++++ 3 files changed, 57 insertions(+), 1 deletion(-) create mode 100644 lib/collectors/global_prometheus_collector.rb create mode 100644 spec/lib/collectors/global_prometheus_collector_spec.rb diff --git a/config/initializers/prometheus.rb b/config/initializers/prometheus.rb index 4b842d84..7c2d4274 100644 --- a/config/initializers/prometheus.rb +++ b/config/initializers/prometheus.rb @@ -1,2 +1,4 @@ require "govuk_app_config/govuk_prometheus_exporter" -GovukPrometheusExporter.configure +require "collectors/global_prometheus_collector" + +GovukPrometheusExporter.configure(collectors: [Collectors::GlobalPrometheusCollector]) diff --git a/lib/collectors/global_prometheus_collector.rb b/lib/collectors/global_prometheus_collector.rb new file mode 100644 index 00000000..0a763db0 --- /dev/null +++ b/lib/collectors/global_prometheus_collector.rb @@ -0,0 +1,28 @@ +require "prometheus_exporter" +require "prometheus_exporter/server" + +module Collectors + class GlobalPrometheusCollector < PrometheusExporter::Server::TypeCollector + SECONDS_PER_DAY = 86_400 + + def type + "locations_api_global" + end + + def metrics + oldest_os_places_postcode = PrometheusExporter::Metric::Gauge.new("locations_api_oldest_os_places_postcode_age_days", "Days since oldest postcode was last updated via OS Places API (Expected in prod: ~7)") + oldest_os_places_postcode.observe(get_oldest_postcode / SECONDS_PER_DAY) + + [oldest_os_places_postcode] + end + + private + + def get_oldest_postcode + # Cache metric to prevent needless expensive calls to the database + Rails.cache.fetch("metrics:oldest_postcode", expires_in: 1.hour) do + (Time.zone.now.to_i - Postcode.os_places.order(updated_at: :asc).first.updated_at.to_i) + end + end + end +end diff --git a/spec/lib/collectors/global_prometheus_collector_spec.rb b/spec/lib/collectors/global_prometheus_collector_spec.rb new file mode 100644 index 00000000..279c5e6c --- /dev/null +++ b/spec/lib/collectors/global_prometheus_collector_spec.rb @@ -0,0 +1,26 @@ +require "spec_helper" + +RSpec.describe Collectors::GlobalPrometheusCollector do + before do + @collector = Collectors::GlobalPrometheusCollector.new + Rails.cache.delete("metrics:oldest_postcode") + end + + describe "#type" do + it "has the correct value" do + expect(@collector.type).to eq("locations_api_global") + end + end + + describe "#metrics" do + before do + @postcode = Postcode.create!(postcode: "E18QS", updated_at: Time.zone.now - 2.days) + end + + it "records the time in days since the oldest postcode's update timestamp" do + metrics = @collector.metrics + + expect(metrics.first.data.first.last).to eq(2) + end + end +end From b06fe4dabb3525e37e1788049570c264b441f2f3 Mon Sep 17 00:00:00 2001 From: Keith Lawrence Date: Mon, 2 Oct 2023 16:22:30 +0100 Subject: [PATCH 2/2] Fix set_up/tear_down order --- spec/service_consumer/pact_helper.rb | 3 +++ 1 file changed, 3 insertions(+) diff --git a/spec/service_consumer/pact_helper.rb b/spec/service_consumer/pact_helper.rb index 2bedf8f3..8e81069c 100644 --- a/spec/service_consumer/pact_helper.rb +++ b/spec/service_consumer/pact_helper.rb @@ -36,6 +36,9 @@ def url_encode(str) set_up do ENV["OS_PLACES_API_KEY"] = "some_key" ENV["OS_PLACES_API_SECRET"] = "some_secret" + end + + tear_down do postcode = Postcode.find_by(postcode: "SW1A1AA") postcode.destroy unless postcode.nil? end