ApplicationConfig

Basically there are 2 levels of configuration:

1) application wide which is configured in config/application.yml 2) environment specific which is configured in config/environments/application-#RAILS_ENV.yml

The environment specific configs override the applicaiton wide config

Example

script/install plugin git://github.com/asynchrony/application_config.git

Then if for example in your config/application.yml you had:

mail_host: example.com

And in your config/environments/application-production.yml you had:

mail_host: production.server.com

you could in your code do:

ApplicationConfig::Base.to_s or ApplicationConfig::Base.mail_host.to_s

At the moment you really need the to_s on the end.

Also, if you want to do a nil check you need to put the applicaiton config on the LHS:

if ApplicationConfig::Base.mail_host == nil

Because of the way it’s working.

For testing, first:

require ‘application_config_test_ext’

in your test_helper

And then before any test you want to alter the config for:

ApplicationConfig::Base.add( <<EOF mail_host: test_mail_host EOF )

Which will change the config for that test and then rollback to what it was before the test. This allows you to test behavior off of the singleton config object.

Copyright © 2009 [name of plugin creator], released under the MIT license