165 lines
5.4 KiB
Ruby
165 lines
5.4 KiB
Ruby
require 'spec_helper'
|
|
require 'active_support/core_ext/hash/slice'
|
|
|
|
describe Travis::Config do
|
|
let(:config) { Travis::Config.load(:files, :env, :heroku, :docker) }
|
|
|
|
describe 'endpoints' do
|
|
it 'returns an object even without endpoints entry' do
|
|
config.endpoints.foo.should be_nil
|
|
end
|
|
|
|
it 'returns endpoints if it is set' do
|
|
ENV['travis_config'] = YAML.dump('endpoints' => { 'ssh_key' => true })
|
|
config.endpoints.ssh_key.should be_truthy
|
|
end
|
|
|
|
it 'allows to set keys on enpoints when it is nil' do
|
|
config.endpoints.foo.should be_nil
|
|
|
|
config.endpoints.foo = true
|
|
|
|
config.endpoints.foo.should be_truthy
|
|
end
|
|
end
|
|
|
|
describe 'defaults' do
|
|
it 'notifications defaults to []' do
|
|
config.notifications.should == []
|
|
end
|
|
|
|
it 'notifications.email defaults to {}' do
|
|
config.email.should == {}
|
|
end
|
|
|
|
it 'queues defaults to []' do
|
|
config.queues.should == []
|
|
end
|
|
|
|
it 'ampq.host defaults to "localhost"' do
|
|
config.amqp.host.should == 'localhost'
|
|
end
|
|
|
|
it 'ampq.prefetch defaults to 1' do
|
|
config.amqp.prefetch.should == 1
|
|
end
|
|
|
|
it 'queue.limit.by_owner defaults to {}' do
|
|
config.queue.limit.by_owner.should == {}
|
|
end
|
|
|
|
it 'queue.limit.default defaults to 5' do
|
|
config.queue.limit.default.should == 5
|
|
end
|
|
|
|
it 'queue.interval defaults to 3' do
|
|
config.queue.interval.should == 3
|
|
end
|
|
|
|
it 'queue.interval defaults to 3' do
|
|
config.queue.interval.should == 3
|
|
end
|
|
|
|
it 'logs.shards defaults to 1' do
|
|
config.logs.shards.should == 1
|
|
end
|
|
|
|
it 'database' do
|
|
config.database.should == {
|
|
:adapter => 'postgresql',
|
|
:database => 'travis_test',
|
|
:encoding => 'unicode',
|
|
:host => 'localhost',
|
|
:min_messages => 'warning',
|
|
:variables => { :statement_timeout => 10000 }
|
|
}
|
|
end
|
|
end
|
|
|
|
describe 'resource urls' do
|
|
describe 'with a TRAVIS_DATABASE_URL set' do
|
|
before { ENV['TRAVIS_DATABASE_URL'] = 'postgres://username:password@host:1234/database' }
|
|
after { ENV.delete('TRAVIS_DATABASE_URL') }
|
|
|
|
it { config.database.username.should == 'username' }
|
|
it { config.database.password.should == 'password' }
|
|
it { config.database.host.should == 'host' }
|
|
it { config.database.port.should == 1234 }
|
|
it { config.database.database.should == 'database' }
|
|
it { config.database.encoding.should == 'unicode' }
|
|
end
|
|
|
|
describe 'with a DATABASE_URL set' do
|
|
before { ENV['DATABASE_URL'] = 'postgres://username:password@host:1234/database' }
|
|
after { ENV.delete('DATABASE_URL') }
|
|
|
|
it { config.database.username.should == 'username' }
|
|
it { config.database.password.should == 'password' }
|
|
it { config.database.host.should == 'host' }
|
|
it { config.database.port.should == 1234 }
|
|
it { config.database.database.should == 'database' }
|
|
it { config.database.encoding.should == 'unicode' }
|
|
end
|
|
|
|
describe 'with a TRAVIS_LOGS_DATABASE_URL set' do
|
|
before { ENV['TRAVIS_LOGS_DATABASE_URL'] = 'postgres://username:password@host:1234/database' }
|
|
after { ENV.delete('TRAVIS_LOGS_DATABASE_URL') }
|
|
|
|
it { config.logs_database.username.should == 'username' }
|
|
it { config.logs_database.password.should == 'password' }
|
|
it { config.logs_database.host.should == 'host' }
|
|
it { config.logs_database.port.should == 1234 }
|
|
it { config.logs_database.database.should == 'database' }
|
|
it { config.logs_database.encoding.should == 'unicode' }
|
|
end
|
|
|
|
describe 'with a LOGS_DATABASE_URL set' do
|
|
before { ENV['LOGS_DATABASE_URL'] = 'postgres://username:password@host:1234/database' }
|
|
after { ENV.delete('LOGS_DATABASE_URL') }
|
|
|
|
it { config.logs_database.username.should == 'username' }
|
|
it { config.logs_database.password.should == 'password' }
|
|
it { config.logs_database.host.should == 'host' }
|
|
it { config.logs_database.port.should == 1234 }
|
|
it { config.logs_database.database.should == 'database' }
|
|
it { config.logs_database.encoding.should == 'unicode' }
|
|
end
|
|
|
|
describe 'with a TRAVIS_RABBITMQ_URL set' do
|
|
before { ENV['TRAVIS_RABBITMQ_URL'] = 'amqp://username:password@host:1234/vhost' }
|
|
after { ENV.delete('TRAVIS_RABBITMQ_URL') }
|
|
|
|
it { config.amqp.username.should == 'username' }
|
|
it { config.amqp.password.should == 'password' }
|
|
it { config.amqp.host.should == 'host' }
|
|
it { config.amqp.port.should == 1234 }
|
|
it { config.amqp.vhost.should == 'vhost' }
|
|
end
|
|
|
|
describe 'with a RABBITMQ_URL set' do
|
|
before { ENV['RABBITMQ_URL'] = 'amqp://username:password@host:1234/vhost' }
|
|
after { ENV.delete('RABBITMQ_URL') }
|
|
|
|
it { config.amqp.username.should == 'username' }
|
|
it { config.amqp.password.should == 'password' }
|
|
it { config.amqp.host.should == 'host' }
|
|
it { config.amqp.port.should == 1234 }
|
|
it { config.amqp.vhost.should == 'vhost' }
|
|
end
|
|
|
|
describe 'with a TRAVIS_REDIS_URL set' do
|
|
before { ENV['TRAVIS_REDIS_URL'] = 'redis://username:password@host:1234' }
|
|
after { ENV.delete('TRAVIS_REDIS_URL') }
|
|
|
|
it { config.redis.url.should == 'redis://username:password@host:1234' }
|
|
end
|
|
|
|
describe 'with a REDIS_URL set' do
|
|
before { ENV['REDIS_URL'] = 'redis://username:password@host:1234' }
|
|
after { ENV.delete('REDIS_URL') }
|
|
|
|
it { config.redis.url.should == 'redis://username:password@host:1234' }
|
|
end
|
|
end
|
|
end
|