kosiakkatrina
12 months ago
committed by
GitHub
19 changed files with 48 additions and 281 deletions
@ -1,5 +0,0 @@
|
||||
module PlatformHelper |
||||
def self.is_paas? |
||||
!ENV["VCAP_SERVICES"].nil? |
||||
end |
||||
end |
@ -1,23 +0,0 @@
|
||||
module Configuration |
||||
class PaasConfigurationService < ConfigurationService |
||||
private |
||||
|
||||
def config_present? |
||||
!ENV["VCAP_SERVICES"].nil? |
||||
end |
||||
|
||||
def read_config |
||||
unless config_present? |
||||
@logger.warn("Could not find VCAP_SERVICES in the environment variables!") |
||||
return {} |
||||
end |
||||
|
||||
begin |
||||
JSON.parse(ENV["VCAP_SERVICES"], { symbolize_names: true }) |
||||
rescue StandardError |
||||
@logger.warn("Could not parse VCAP_SERVICES!") |
||||
{} |
||||
end |
||||
end |
||||
end |
||||
end |
@ -1,15 +0,0 @@
|
||||
require "rails_helper" |
||||
|
||||
RSpec.describe PlatformHelper do |
||||
describe "is_paas?" do |
||||
it "returns true if the VCAP_SERVICES environment variable exists" do |
||||
allow(ENV).to receive(:[]).with("VCAP_SERVICES").and_return("dummy") |
||||
expect(described_class.is_paas?).to eq(true) |
||||
end |
||||
|
||||
it "returns false if the VCAP_SERVICES environment variable doesn't exist" do |
||||
allow(ENV).to receive(:[]).with("VCAP_SERVICES") |
||||
expect(described_class.is_paas?).to eq(false) |
||||
end |
||||
end |
||||
end |
@ -1,149 +0,0 @@
|
||||
require "rails_helper" |
||||
|
||||
RSpec.describe Configuration::PaasConfigurationService do |
||||
subject(:config_service) { described_class.new(logger) } |
||||
|
||||
let(:logger) { instance_double(ActiveSupport::LogSubscriber) } |
||||
|
||||
context "when the paas configuration is unavailable" do |
||||
before { allow(logger).to receive(:warn) } |
||||
|
||||
it "returns the S3 configuration as not present" do |
||||
expect(config_service.s3_config_present?).to be(false) |
||||
end |
||||
|
||||
it "returns the redis configuration as not present" do |
||||
expect(config_service.redis_config_present?).to be(false) |
||||
end |
||||
|
||||
it "does not retrieve any S3 bucket configuration" do |
||||
expect(config_service.s3_buckets).to be_a(Hash) |
||||
expect(config_service.s3_buckets).to be_empty |
||||
end |
||||
|
||||
it "does not retrieve any redis configuration" do |
||||
expect(config_service.redis_uris).to be_a(Hash) |
||||
expect(config_service.redis_uris).to be_empty |
||||
end |
||||
end |
||||
|
||||
context "when the paas configuration is present but empty" do |
||||
before do |
||||
allow(ENV).to receive(:[]).with("VCAP_SERVICES").and_return("{}") |
||||
end |
||||
|
||||
it "returns the S3 configuration as not present" do |
||||
expect(config_service.s3_config_present?).to be(false) |
||||
end |
||||
|
||||
it "returns the redis configuration as not present" do |
||||
expect(config_service.redis_config_present?).to be(false) |
||||
end |
||||
|
||||
it "does not retrieve any S3 bucket configuration" do |
||||
expect(config_service.s3_buckets).to be_a(Hash) |
||||
expect(config_service.s3_buckets).to be_empty |
||||
end |
||||
|
||||
it "does not retrieve any redis configuration" do |
||||
expect(config_service.redis_uris).to be_a(Hash) |
||||
expect(config_service.redis_uris).to be_empty |
||||
end |
||||
end |
||||
|
||||
context "when the paas configuration is present but invalid" do |
||||
let(:vcap_services) { "random text" } |
||||
|
||||
before do |
||||
allow(ENV).to receive(:[]).with("VCAP_SERVICES").and_return(vcap_services) |
||||
allow(logger).to receive(:warn) |
||||
end |
||||
|
||||
it "logs an error when checking if the S3 config is present" do |
||||
expect(logger).to receive(:warn).with("Could not parse VCAP_SERVICES!") |
||||
config_service.s3_config_present? |
||||
end |
||||
|
||||
it "logs an error when checking if the Redis config is present" do |
||||
expect(logger).to receive(:warn).with("Could not parse VCAP_SERVICES!") |
||||
config_service.redis_config_present? |
||||
end |
||||
end |
||||
|
||||
context "when the paas configuration is present with S3 configured" do |
||||
let(:vcap_services) do |
||||
<<~JSON |
||||
{"aws-s3-bucket": |
||||
[{ |
||||
"instance_name": "bucket_1", |
||||
"credentials": { |
||||
"aws_access_key_id": "123", |
||||
"aws_secret_access_key": "456", |
||||
"aws_region": "eu-west-1", |
||||
"bucket_name": "my-bucket" |
||||
} |
||||
}, |
||||
{ |
||||
"instance_name": "bucket_2", |
||||
"credentials": { |
||||
"aws_access_key_id": "789", |
||||
"aws_secret_access_key": "012", |
||||
"aws_region": "eu-west-2", |
||||
"bucket_name": "my-bucket2" |
||||
} |
||||
}] |
||||
} |
||||
JSON |
||||
end |
||||
|
||||
before do |
||||
allow(ENV).to receive(:[]).with("VCAP_SERVICES").and_return(vcap_services) |
||||
end |
||||
|
||||
it "returns the S3 configuration as present" do |
||||
expect(config_service.s3_config_present?).to be(true) |
||||
end |
||||
|
||||
it "returns the redis configuration as not present" do |
||||
expect(config_service.redis_config_present?).to be(false) |
||||
end |
||||
|
||||
it "does retrieve the S3 bucket configurations" do |
||||
s3_buckets = config_service.s3_buckets |
||||
|
||||
expect(s3_buckets).not_to be_empty |
||||
expect(s3_buckets.count).to be(2) |
||||
expect(s3_buckets).to have_key(:bucket_1) |
||||
expect(s3_buckets).to have_key(:bucket_2) |
||||
end |
||||
end |
||||
|
||||
context "when the paas configuration is present with redis configured" do |
||||
let(:vcap_services) do |
||||
<<-JSON |
||||
{"redis": [{"instance_name": "redis_1", "credentials": {"uri": "redis_uri" }}]} |
||||
JSON |
||||
end |
||||
|
||||
before do |
||||
allow(ENV).to receive(:[]).with("VCAP_SERVICES").and_return(vcap_services) |
||||
end |
||||
|
||||
it "returns the redis configuration as present" do |
||||
expect(config_service.redis_config_present?).to be(true) |
||||
end |
||||
|
||||
it "returns the S3 configuration as not present" do |
||||
expect(config_service.s3_config_present?).to be(false) |
||||
end |
||||
|
||||
it "does retrieve the redis configurations" do |
||||
redis_uris = config_service.redis_uris |
||||
|
||||
expect(redis_uris).not_to be_empty |
||||
expect(redis_uris.count).to be(1) |
||||
expect(redis_uris).to have_key(:redis_1) |
||||
expect(redis_uris[:redis_1]).to eq("redis_uri") |
||||
end |
||||
end |
||||
end |
Loading…
Reference in new issue