summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--config/initializers/1_settings.rb2
-rw-r--r--spec/controllers/health_check_controller_spec.rb15
-rw-r--r--spec/controllers/health_controller_spec.rb6
3 files changed, 20 insertions, 3 deletions
diff --git a/config/initializers/1_settings.rb b/config/initializers/1_settings.rb
index 31c6bea9ed5..56869f9b934 100644
--- a/config/initializers/1_settings.rb
+++ b/config/initializers/1_settings.rb
@@ -498,7 +498,7 @@ Settings.webpack.dev_server['port'] ||= 3808
# Monitoring settings
#
Settings['monitoring'] ||= Settingslogic.new({})
-Settings.monitoring['ip_whitelist'] ||= %w{127.0.0.1/8}
+Settings.monitoring['ip_whitelist'] ||= ['127.0.0.1/8']
#
# Prometheus metrics settings
diff --git a/spec/controllers/health_check_controller_spec.rb b/spec/controllers/health_check_controller_spec.rb
index 6c545169450..e7abe1ba78d 100644
--- a/spec/controllers/health_check_controller_spec.rb
+++ b/spec/controllers/health_check_controller_spec.rb
@@ -10,7 +10,7 @@ describe HealthCheckController do
let(:not_whitelisted_ip) { '127.0.0.2' }
before do
- allow(Settings.monitoring).to receive(:ip_whitelist).and_return([IPAddr.new(whitelisted_ip)])
+ allow(Settings.monitoring).to receive(:ip_whitelist).and_return([whitelisted_ip])
stub_env('IN_MEMORY_APPLICATION_SETTINGS', 'false')
end
@@ -22,19 +22,23 @@ describe HealthCheckController do
it 'returns a not found page' do
get :index
+
expect(response).to be_not_found
end
context 'when services are accessed with token' do
it 'supports passing the token in the header' do
request.headers['TOKEN'] = token
+
get :index
+
expect(response).to be_success
expect(response.content_type).to eq 'text/plain'
end
it 'supports successful plaintest response' do
get :index, token: token
+
expect(response).to be_success
expect(response.content_type).to eq 'text/plain'
end
@@ -50,12 +54,14 @@ describe HealthCheckController do
it 'supports successful plaintest response' do
get :index
+
expect(response).to be_success
expect(response.content_type).to eq 'text/plain'
end
it 'supports successful json response' do
get :index, format: :json
+
expect(response).to be_success
expect(response.content_type).to eq 'application/json'
expect(json_response['healthy']).to be true
@@ -63,6 +69,7 @@ describe HealthCheckController do
it 'supports successful xml response' do
get :index, format: :xml
+
expect(response).to be_success
expect(response.content_type).to eq 'application/xml'
expect(xml_response['healthy']).to be true
@@ -70,6 +77,7 @@ describe HealthCheckController do
it 'supports successful responses for specific checks' do
get :index, checks: 'email', format: :json
+
expect(response).to be_success
expect(response.content_type).to eq 'application/json'
expect(json_response['healthy']).to be true
@@ -79,6 +87,7 @@ describe HealthCheckController do
context 'when a service is down but NO access token' do
it 'returns a not found page' do
get :index
+
expect(response).to be_not_found
end
end
@@ -92,6 +101,7 @@ describe HealthCheckController do
it 'supports failure plaintest response' do
get :index
+
expect(response).to have_http_status(500)
expect(response.content_type).to eq 'text/plain'
expect(response.body).to include('The server is on fire')
@@ -99,6 +109,7 @@ describe HealthCheckController do
it 'supports failure json response' do
get :index, format: :json
+
expect(response).to have_http_status(500)
expect(response.content_type).to eq 'application/json'
expect(json_response['healthy']).to be false
@@ -107,6 +118,7 @@ describe HealthCheckController do
it 'supports failure xml response' do
get :index, format: :xml
+
expect(response).to have_http_status(500)
expect(response.content_type).to eq 'application/xml'
expect(xml_response['healthy']).to be false
@@ -115,6 +127,7 @@ describe HealthCheckController do
it 'supports failure responses for specific checks' do
get :index, checks: 'email', format: :json
+
expect(response).to have_http_status(500)
expect(response.content_type).to eq 'application/json'
expect(json_response['healthy']).to be false
diff --git a/spec/controllers/health_controller_spec.rb b/spec/controllers/health_controller_spec.rb
index 3e4370652d0..4b22155a431 100644
--- a/spec/controllers/health_controller_spec.rb
+++ b/spec/controllers/health_controller_spec.rb
@@ -8,7 +8,7 @@ describe HealthController do
let(:not_whitelisted_ip) { '127.0.0.2' }
before do
- allow(Settings.monitoring).to receive(:ip_whitelist).and_return([IPAddr.new(whitelisted_ip)])
+ allow(Settings.monitoring).to receive(:ip_whitelist).and_return([whitelisted_ip])
stub_env('IN_MEMORY_APPLICATION_SETTINGS', 'false')
end
@@ -20,6 +20,7 @@ describe HealthController do
it 'returns proper response' do
get :readiness
+
expect(json_response['db_check']['status']).to eq('ok')
expect(json_response['redis_check']['status']).to eq('ok')
expect(json_response['fs_shards_check']['status']).to eq('ok')
@@ -34,6 +35,7 @@ describe HealthController do
it 'returns proper response' do
get :readiness
+
expect(response.status).to eq(404)
end
end
@@ -47,6 +49,7 @@ describe HealthController do
it 'returns proper response' do
get :liveness
+
expect(json_response['db_check']['status']).to eq('ok')
expect(json_response['redis_check']['status']).to eq('ok')
expect(json_response['fs_shards_check']['status']).to eq('ok')
@@ -60,6 +63,7 @@ describe HealthController do
it 'returns proper response' do
get :liveness
+
expect(response.status).to eq(404)
end
end