mirror of
https://github.com/capistrano/capistrano
synced 2023-03-27 23:21:18 -04:00
7eb7ca0124
`release_path` will now return the value of `current_path` by default. Tasks that create a new release (i.e. `deploy`) now explicitly over-ride this default with a new release path. This change allows tasks that run in both deploy and non-deploy contexts to use `release_path` to target the latest release when run in isolation, and the new release (before it is `current`) when run as part of a deploy.
344 lines
8.9 KiB
Ruby
344 lines
8.9 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe Capistrano::DSL do
|
|
|
|
let(:dsl) { Class.new.extend Capistrano::DSL }
|
|
|
|
describe 'setting and fetching hosts' do
|
|
describe 'when defining a host using the `server` syntax' do
|
|
before do
|
|
dsl.server 'example1.com', roles: %w{web}, active: true
|
|
dsl.server 'example2.com', roles: %w{web}
|
|
dsl.server 'example3.com', roles: %w{app web}, active: true
|
|
dsl.server 'example4.com', roles: %w{app}, primary: true
|
|
end
|
|
|
|
describe 'fetching all servers' do
|
|
subject { dsl.roles(:all) }
|
|
|
|
it 'returns all servers' do
|
|
expect(subject.map(&:hostname)).to eq %w{example1.com example2.com example3.com example4.com}
|
|
end
|
|
end
|
|
|
|
describe 'fetching servers by multiple roles' do
|
|
it "does not confuse the last role with options" do
|
|
expect(dsl.roles(:app, :web).count).to eq 4
|
|
expect(dsl.roles(:app, :web, filter: :active).count).to eq 2
|
|
end
|
|
end
|
|
|
|
describe 'fetching servers by role' do
|
|
subject { dsl.roles(:app) }
|
|
|
|
it 'returns the servers' do
|
|
expect(subject.map(&:hostname)).to eq %w{example3.com example4.com}
|
|
end
|
|
end
|
|
|
|
describe 'fetching filtered servers by role' do
|
|
subject { dsl.roles(:app, filter: :active) }
|
|
|
|
it 'returns the servers' do
|
|
expect(subject.map(&:hostname)).to eq %w{example3.com}
|
|
end
|
|
end
|
|
|
|
describe 'fetching selected servers by role' do
|
|
subject { dsl.roles(:app, select: :active) }
|
|
|
|
it 'returns the servers' do
|
|
expect(subject.map(&:hostname)).to eq %w{example3.com}
|
|
end
|
|
end
|
|
|
|
describe 'fetching the primary server by role' do
|
|
context 'when inferring primary status based on order' do
|
|
subject { dsl.primary(:web) }
|
|
it 'returns the servers' do
|
|
expect(subject.hostname).to eq 'example1.com'
|
|
end
|
|
end
|
|
|
|
context 'when the attribute `primary` is explicity set' do
|
|
subject { dsl.primary(:app) }
|
|
it 'returns the servers' do
|
|
expect(subject.hostname).to eq 'example4.com'
|
|
end
|
|
end
|
|
end
|
|
|
|
end
|
|
|
|
describe 'when defining hosts using the `role` syntax' do
|
|
before do
|
|
dsl.role :web, %w{example1.com example2.com example3.com}
|
|
dsl.role :web, %w{example1.com}, active: true
|
|
dsl.role :app, %w{example3.com example4.com}
|
|
dsl.role :app, %w{example3.com}, active: true
|
|
dsl.role :app, %w{example4.com}, primary: true
|
|
end
|
|
|
|
describe 'fetching all servers' do
|
|
subject { dsl.roles(:all) }
|
|
|
|
it 'returns all servers' do
|
|
expect(subject.map(&:hostname)).to eq %w{example1.com example2.com example3.com example4.com}
|
|
end
|
|
end
|
|
|
|
describe 'fetching servers by role' do
|
|
subject { dsl.roles(:app) }
|
|
|
|
it 'returns the servers' do
|
|
expect(subject.map(&:hostname)).to eq %w{example3.com example4.com}
|
|
end
|
|
end
|
|
|
|
describe 'fetching filtered servers by role' do
|
|
subject { dsl.roles(:app, filter: :active) }
|
|
|
|
it 'returns the servers' do
|
|
expect(subject.map(&:hostname)).to eq %w{example3.com}
|
|
end
|
|
end
|
|
|
|
describe 'fetching selected servers by role' do
|
|
subject { dsl.roles(:app, select: :active) }
|
|
|
|
it 'returns the servers' do
|
|
expect(subject.map(&:hostname)).to eq %w{example3.com}
|
|
end
|
|
end
|
|
|
|
describe 'fetching the primary server by role' do
|
|
context 'when inferring primary status based on order' do
|
|
subject { dsl.primary(:web) }
|
|
it 'returns the servers' do
|
|
expect(subject.hostname).to eq 'example1.com'
|
|
end
|
|
end
|
|
|
|
context 'when the attribute `primary` is explicity set' do
|
|
subject { dsl.primary(:app) }
|
|
it 'returns the servers' do
|
|
expect(subject.hostname).to eq 'example4.com'
|
|
end
|
|
end
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
describe 'setting and fetching variables' do
|
|
|
|
before do
|
|
dsl.set :scm, :git
|
|
end
|
|
|
|
context 'without a default' do
|
|
context 'when the variables is defined' do
|
|
it 'returns the variable' do
|
|
expect(dsl.fetch(:scm)).to eq :git
|
|
end
|
|
end
|
|
|
|
context 'when the variables is undefined' do
|
|
it 'returns nil' do
|
|
expect(dsl.fetch(:source_control)).to be_nil
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with a default' do
|
|
context 'when the variables is defined' do
|
|
it 'returns the variable' do
|
|
expect(dsl.fetch(:scm, :svn)).to eq :git
|
|
end
|
|
end
|
|
|
|
context 'when the variables is undefined' do
|
|
it 'returns the default' do
|
|
expect(dsl.fetch(:source_control, :svn)).to eq :svn
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with a block' do
|
|
context 'when the variables is defined' do
|
|
it 'returns the variable' do
|
|
expect(dsl.fetch(:scm) { :svn }).to eq :git
|
|
end
|
|
end
|
|
|
|
context 'when the variables is undefined' do
|
|
it 'calls the block' do
|
|
expect(dsl.fetch(:source_control) { :svn }).to eq :svn
|
|
end
|
|
end
|
|
end
|
|
|
|
end
|
|
|
|
describe 'asking for a variable' do
|
|
before do
|
|
dsl.ask(:scm, :svn)
|
|
$stdout.stubs(:puts)
|
|
end
|
|
|
|
context 'variable is provided' do
|
|
before do
|
|
$stdin.expects(:gets).returns('git')
|
|
end
|
|
|
|
it 'sets the input as the variable' do
|
|
expect(dsl.fetch(:scm)).to eq 'git'
|
|
end
|
|
end
|
|
|
|
context 'variable is not provided' do
|
|
before do
|
|
$stdin.expects(:gets).returns('')
|
|
end
|
|
|
|
it 'sets the variable as the default' do
|
|
expect(dsl.fetch(:scm)).to eq :svn
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'checking for presence' do
|
|
subject { dsl.any? :linked_files }
|
|
|
|
before do
|
|
dsl.set(:linked_files, linked_files)
|
|
end
|
|
|
|
context 'variable is an non-empty array' do
|
|
let(:linked_files) { %w{1} }
|
|
|
|
it { should be_true }
|
|
end
|
|
|
|
context 'variable is an empty array' do
|
|
let(:linked_files) { [] }
|
|
it { should be_false }
|
|
end
|
|
|
|
context 'variable exists, is not an array' do
|
|
let(:linked_files) { stub }
|
|
it { should be_true }
|
|
end
|
|
|
|
context 'variable is nil' do
|
|
let(:linked_files) { nil }
|
|
it { should be_false }
|
|
end
|
|
end
|
|
|
|
describe 'configuration SSHKit' do
|
|
let(:config) { SSHKit.config }
|
|
let(:backend) { SSHKit.config.backend.config }
|
|
let(:default_env) { { rails_env: :production } }
|
|
|
|
before do
|
|
dsl.set(:format, :dot)
|
|
dsl.set(:log_level, :debug)
|
|
dsl.set(:default_env, default_env)
|
|
dsl.set(:pty, true)
|
|
dsl.set(:connection_timeout, 10)
|
|
dsl.set(:ssh_options, {
|
|
keys: %w(/home/user/.ssh/id_rsa),
|
|
forward_agent: false,
|
|
auth_methods: %w(publickey password)
|
|
})
|
|
dsl.configure_backend
|
|
end
|
|
|
|
it 'sets the output' do
|
|
expect(config.output).to be_a SSHKit::Formatter::Dot
|
|
end
|
|
|
|
it 'sets the output verbosity' do
|
|
expect(config.output_verbosity).to eq 0
|
|
end
|
|
|
|
it 'sets the default env' do
|
|
expect(config.default_env).to eq default_env
|
|
end
|
|
|
|
it 'sets the backend pty' do
|
|
expect(backend.pty).to be_true
|
|
end
|
|
|
|
it 'sets the backend connection timeout' do
|
|
expect(backend.connection_timeout).to eq 10
|
|
end
|
|
|
|
it 'sets the backend ssh_options' do
|
|
expect(backend.ssh_options[:keys]).to eq %w(/home/user/.ssh/id_rsa)
|
|
expect(backend.ssh_options[:forward_agent]).to eq false
|
|
expect(backend.ssh_options[:auth_methods]).to eq %w(publickey password)
|
|
end
|
|
|
|
end
|
|
|
|
describe 'release path' do
|
|
|
|
before do
|
|
dsl.set(:deploy_to, '/var/www')
|
|
end
|
|
|
|
describe 'fetching release path' do
|
|
subject { dsl.release_path }
|
|
|
|
context 'where no release path has been set' do
|
|
before do
|
|
dsl.delete(:release_path)
|
|
end
|
|
|
|
it 'returns the `current_path` value' do
|
|
expect(subject.to_s).to eq '/var/www/current'
|
|
end
|
|
end
|
|
|
|
context 'where the release path has been set' do
|
|
before do
|
|
dsl.set(:release_path, '/var/www/release_path')
|
|
end
|
|
|
|
it 'returns the set `release_path` value' do
|
|
expect(subject.to_s).to eq '/var/www/release_path'
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'setting release path' do
|
|
let(:now) { Time.parse("Oct 21 16:29:00 2015") }
|
|
subject { dsl.release_path }
|
|
|
|
context 'without a timestamp' do
|
|
before do
|
|
dsl.env.expects(:timestamp).returns(now)
|
|
dsl.set_release_path
|
|
end
|
|
|
|
it 'returns the release path with the current env timestamp' do
|
|
expect(subject.to_s).to eq '/var/www/releases/20151021162900'
|
|
end
|
|
end
|
|
|
|
context 'with a timestamp' do
|
|
before do
|
|
dsl.set_release_path('timestamp')
|
|
end
|
|
|
|
it 'returns the release path with the timestamp' do
|
|
expect(subject.to_s).to eq '/var/www/releases/timestamp'
|
|
end
|
|
end
|
|
end
|
|
|
|
end
|
|
end
|