From 59914b6de93245a43fd86a45201fe5a8981ab83c Mon Sep 17 00:00:00 2001 From: callumknights Date: Thu, 7 Jan 2021 11:41:14 +0000 Subject: [PATCH] Add Redis healthcheck This was done in response to the work to enable continuous deployment for local-links-manager. Given local-links-manager uses Redis on it's own, without sidekiq, similarly to email-alert-frontend, it made sense to move the recently written healthcheck by @1pretz1 to govuk-app-config so it could be used by both applications. Co-authored-by: Peter Hartshorn Trello: https://trello.com/c/uAx6eKAQ/2276-activate-continuous-deployment-for-local-links-manager --- CHANGELOG.md | 4 +++ lib/govuk_app_config/govuk_healthcheck.rb | 1 + .../govuk_healthcheck/redis_connection.rb | 21 +++++++++++++ .../redis_connection_spec.rb | 30 +++++++++++++++++++ 4 files changed, 56 insertions(+) create mode 100644 lib/govuk_app_config/govuk_healthcheck/redis_connection.rb create mode 100644 spec/lib/govuk_healthcheck/redis_connection_spec.rb diff --git a/CHANGELOG.md b/CHANGELOG.md index 8fb24225..f3fd68d4 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,7 @@ +# Unreleased + +* Add new Redis healthcheck and relevant tests (https://github.com/alphagov/govuk_app_config/pull/183) + # 2.8.1 * Add `GdsApi::ContentStore::ItemNotFound` to `data_sync_excluded_exceptions` (https://github.com/alphagov/govuk_app_config/pull/178) diff --git a/lib/govuk_app_config/govuk_healthcheck.rb b/lib/govuk_app_config/govuk_healthcheck.rb index 0244e6be..b519ae74 100644 --- a/lib/govuk_app_config/govuk_healthcheck.rb +++ b/lib/govuk_app_config/govuk_healthcheck.rb @@ -2,6 +2,7 @@ require "govuk_app_config/govuk_healthcheck/active_record" require "govuk_app_config/govuk_healthcheck/mongoid" require "govuk_app_config/govuk_healthcheck/rails_cache" +require "govuk_app_config/govuk_healthcheck/redis_connection" require "govuk_app_config/govuk_healthcheck/sidekiq_redis" require "govuk_app_config/govuk_healthcheck/threshold_check" require "govuk_app_config/govuk_healthcheck/sidekiq_queue_check" diff --git a/lib/govuk_app_config/govuk_healthcheck/redis_connection.rb b/lib/govuk_app_config/govuk_healthcheck/redis_connection.rb new file mode 100644 index 00000000..3d3cef80 --- /dev/null +++ b/lib/govuk_app_config/govuk_healthcheck/redis_connection.rb @@ -0,0 +1,21 @@ +module GovukHealthcheck + class RedisConnection + def name + :redis_connection + end + + def status + client = Redis.new + + client.set("healthcheck", "val") + client.get("healthcheck") + client.del("healthcheck") + + client.close + + GovukHealthcheck::OK + rescue StandardError + GovukHealthcheck::CRITICAL + end + end +end diff --git a/spec/lib/govuk_healthcheck/redis_connection_spec.rb b/spec/lib/govuk_healthcheck/redis_connection_spec.rb new file mode 100644 index 00000000..0c5acdb1 --- /dev/null +++ b/spec/lib/govuk_healthcheck/redis_connection_spec.rb @@ -0,0 +1,30 @@ +require "spec_helper" +require "govuk_app_config/govuk_healthcheck" +require_relative "shared_interface" + +RSpec.describe GovukHealthcheck::RedisConnection do + let(:redis) { double(:redis) } + let(:redis_client) { double(:redis_client, set: "OK", get: "val", del: 1, close: nil) } + + before do + stub_const("Redis", redis) + allow(redis).to receive(:new).and_return(redis_client) + end + + context "when the database is connected" do + before { allow(redis_client).to receive(:set) } + it_behaves_like "a healthcheck" + it "returns OK" do + expect(redis_client).to receive(:set).with(anything, anything) + expect(subject.status).to eq(GovukHealthcheck::OK) + end + end + + context "when the database is not connected" do + before { allow(redis_client).to receive(:set).with(anything, anything).and_raise("error") } + it_behaves_like "a healthcheck" + it "returns CRITICAL" do + expect(subject.status).to eq(GovukHealthcheck::CRITICAL) + end + end +end