FEATURE: blank global settings should not shadow

Due to https://github.com/docker/docker/issues/9298 it is a huge pain
to remove ENV vars when composing images, allow us to simply treat "blank"
as a ENV var that is not being shadowed. In general we always supply a
value to ENV vars we are shadowing.
This commit is contained in:
Sam Saffron 2016-02-10 11:54:40 +11:00
parent 8944d62aa6
commit d0dd517f27
2 changed files with 17 additions and 3 deletions

View File

@ -121,9 +121,11 @@ module SiteSettingExtension
# exists it will be used instead of the setting and the setting will be hidden. # exists it will be used instead of the setting and the setting will be hidden.
# Useful for things like API keys on multisite. # Useful for things like API keys on multisite.
if opts[:shadowed_by_global] && GlobalSetting.respond_to?(name) if opts[:shadowed_by_global] && GlobalSetting.respond_to?(name)
if (val = GlobalSetting.send(name)).present?
hidden_settings << name hidden_settings << name
shadowed_settings << name shadowed_settings << name
current_value = GlobalSetting.send(name) current_value = val
end
end end
if opts[:refresh] if opts[:refresh]

View File

@ -447,6 +447,18 @@ describe SiteSettingExtension do
end end
end end
context "with blank global setting" do
before do
GlobalSetting.stubs(:nada).returns('')
settings.setting(:nada, 'nothing', shadowed_by_global: true)
settings.refresh!
end
it "should return default cause nothing is set" do
expect(settings.nada).to eq('nothing')
end
end
context "with global setting" do context "with global setting" do
before do before do
GlobalSetting.stubs(:trout_api_key).returns('purringcat') GlobalSetting.stubs(:trout_api_key).returns('purringcat')