capistrano 3.0.1 → 3.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (54) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +1 -0
  3. data/.travis.yml +5 -2
  4. data/CHANGELOG.md +36 -3
  5. data/CONTRIBUTING.md +91 -0
  6. data/Gemfile +9 -0
  7. data/README.md +9 -11
  8. data/capistrano.gemspec +5 -8
  9. data/features/configuration.feature +15 -0
  10. data/features/deploy.feature +1 -0
  11. data/features/deploy_failure.feature +17 -0
  12. data/features/step_definitions/assertions.rb +19 -0
  13. data/features/step_definitions/cap_commands.rb +5 -1
  14. data/features/step_definitions/setup.rb +13 -0
  15. data/features/support/remote_command_helpers.rb +4 -0
  16. data/lib/capistrano/application.rb +41 -3
  17. data/lib/capistrano/configuration.rb +8 -0
  18. data/lib/capistrano/configuration/server.rb +28 -5
  19. data/lib/capistrano/configuration/servers.rb +3 -6
  20. data/lib/capistrano/configuration/servers/host_filter.rb +82 -0
  21. data/lib/capistrano/dsl.rb +16 -1
  22. data/lib/capistrano/dsl/env.rb +11 -1
  23. data/lib/capistrano/dsl/paths.rb +8 -0
  24. data/lib/capistrano/dsl/stages.rb +8 -1
  25. data/lib/capistrano/dsl/task_enhancements.rb +13 -2
  26. data/lib/capistrano/git.rb +35 -0
  27. data/lib/capistrano/hg.rb +32 -0
  28. data/lib/capistrano/i18n.rb +6 -2
  29. data/lib/capistrano/scm.rb +116 -0
  30. data/lib/capistrano/setup.rb +4 -3
  31. data/lib/capistrano/tasks/console.rake +9 -1
  32. data/lib/capistrano/tasks/deploy.rake +17 -15
  33. data/lib/capistrano/tasks/framework.rake +1 -0
  34. data/lib/capistrano/tasks/git.rake +16 -10
  35. data/lib/capistrano/tasks/hg.rake +13 -9
  36. data/lib/capistrano/templates/Capfile +1 -2
  37. data/lib/capistrano/templates/deploy.rb.erb +20 -2
  38. data/lib/capistrano/templates/stage.rb.erb +1 -4
  39. data/lib/capistrano/version.rb +1 -1
  40. data/spec/integration/dsl_spec.rb +147 -2
  41. data/spec/lib/capistrano/application_spec.rb +2 -5
  42. data/spec/lib/capistrano/configuration/server_spec.rb +40 -4
  43. data/spec/lib/capistrano/configuration/servers/host_filter_spec.rb +84 -0
  44. data/spec/lib/capistrano/configuration/servers_spec.rb +35 -0
  45. data/spec/lib/capistrano/configuration_spec.rb +8 -0
  46. data/spec/lib/capistrano/dsl_spec.rb +0 -11
  47. data/spec/lib/capistrano/git_spec.rb +70 -0
  48. data/spec/lib/capistrano/hg_spec.rb +70 -0
  49. data/spec/lib/capistrano/scm_spec.rb +104 -0
  50. data/spec/support/tasks/fail.cap +7 -0
  51. data/spec/support/tasks/failed.cap +5 -0
  52. data/spec/support/test_app.rb +33 -3
  53. metadata +29 -52
  54. data/spec/lib/capistrano/dsl/env_spec.rb +0 -10
@@ -8,11 +8,12 @@ end
8
8
 
9
9
  stages.each do |stage|
10
10
  Rake::Task.define_task(stage) do
11
+ set(:stage, stage.to_sym)
12
+
11
13
  invoke 'load:defaults'
12
- load 'config/deploy.rb'
13
- load "config/deploy/#{stage}.rb"
14
+ load deploy_config_path
15
+ load stage_config_path.join("#{stage}.rb")
14
16
  load "capistrano/#{fetch(:scm)}.rb"
15
- set(:stage, stage.to_sym)
16
17
  I18n.locale = fetch(:locale, :en)
17
18
  configure_backend
18
19
  end
@@ -4,7 +4,15 @@ task :console do
4
4
  puts I18n.t('console.welcome', scope: :capistrano, stage: stage)
5
5
  loop do
6
6
  print "#{stage}> "
7
- command = $stdin.gets.chomp
7
+
8
+ if input = $stdin.gets
9
+ command = input.chomp
10
+ else
11
+ command = 'exit'
12
+ end
13
+
14
+ next if command.empty?
15
+
8
16
  if %w{quit exit q}.include? command
9
17
  puts t('console.bye')
10
18
  break
@@ -15,7 +15,6 @@ namespace :deploy do
15
15
 
16
16
  task :publishing do
17
17
  invoke 'deploy:symlink:release'
18
- invoke 'deploy:restart'
19
18
  end
20
19
 
21
20
  task :finishing do
@@ -42,7 +41,7 @@ namespace :deploy do
42
41
  namespace :check do
43
42
  desc 'Check shared and release directories exist'
44
43
  task :directories do
45
- on roles :all do
44
+ on release_roles :all do
46
45
  execute :mkdir, '-pv', shared_path, releases_path
47
46
  end
48
47
  end
@@ -50,15 +49,15 @@ namespace :deploy do
50
49
  desc 'Check directories to be linked exist in shared'
51
50
  task :linked_dirs do
52
51
  next unless any? :linked_dirs
53
- on roles :app do
52
+ on release_roles :all do
54
53
  execute :mkdir, '-pv', linked_dirs(shared_path)
55
54
  end
56
55
  end
57
-
56
+
58
57
  desc 'Check directories of files to be linked exist in shared'
59
58
  task :make_linked_dirs do
60
59
  next unless any? :linked_files
61
- on roles :app do |host|
60
+ on release_roles :all do |host|
62
61
  execute :mkdir, '-pv', linked_file_dirs(shared_path)
63
62
  end
64
63
  end
@@ -66,7 +65,7 @@ namespace :deploy do
66
65
  desc 'Check files to be linked exist in shared'
67
66
  task :linked_files do
68
67
  next unless any? :linked_files
69
- on roles :app do |host|
68
+ on release_roles :all do |host|
70
69
  linked_files(shared_path).each do |file|
71
70
  unless test "[ -f #{file} ]"
72
71
  error t(:linked_file_does_not_exist, file: file, host: host)
@@ -80,7 +79,7 @@ namespace :deploy do
80
79
  namespace :symlink do
81
80
  desc 'Symlink release to current'
82
81
  task :release do
83
- on roles :all do
82
+ on release_roles :all do
84
83
  execute :rm, '-rf', current_path
85
84
  execute :ln, '-s', release_path, current_path
86
85
  end
@@ -95,7 +94,7 @@ namespace :deploy do
95
94
  desc 'Symlink linked directories'
96
95
  task :linked_dirs do
97
96
  next unless any? :linked_dirs
98
- on roles :app do
97
+ on release_roles :all do
99
98
  execute :mkdir, '-pv', linked_dir_parents(release_path)
100
99
 
101
100
  fetch(:linked_dirs).each do |dir|
@@ -114,7 +113,7 @@ namespace :deploy do
114
113
  desc 'Symlink linked files'
115
114
  task :linked_files do
116
115
  next unless any? :linked_files
117
- on roles :app do
116
+ on release_roles :all do
118
117
  execute :mkdir, '-pv', linked_file_dirs(release_path)
119
118
 
120
119
  fetch(:linked_files).each do |file|
@@ -133,7 +132,7 @@ namespace :deploy do
133
132
 
134
133
  desc 'Clean up old releases'
135
134
  task :cleanup do
136
- on roles :all do |host|
135
+ on release_roles :all do |host|
137
136
  releases = capture(:ls, '-x', releases_path).split
138
137
  if releases.count >= fetch(:keep_releases)
139
138
  info t(:keeping_releases, host: host.to_s, keep_releases: fetch(:keep_releases), releases: releases.count)
@@ -152,7 +151,7 @@ namespace :deploy do
152
151
 
153
152
  desc 'Remove and archive rolled-back release.'
154
153
  task :cleanup_rollback do
155
- on roles(:all) do
154
+ on release_roles(:all) do
156
155
  last_release = capture(:ls, '-xr', releases_path).split.first
157
156
  last_release_path = releases_path.join(last_release)
158
157
  if test "[ `readlink #{current_path}` != #{last_release_path} ]"
@@ -168,7 +167,7 @@ namespace :deploy do
168
167
 
169
168
  desc 'Log details of the deploy'
170
169
  task :log_revision do
171
- on roles(:all) do
170
+ on release_roles(:all) do
172
171
  within releases_path do
173
172
  execute %{echo "#{revision_log_message}" >> #{revision_log}}
174
173
  end
@@ -177,7 +176,7 @@ namespace :deploy do
177
176
 
178
177
  desc 'Revert to previous release timestamp'
179
178
  task :revert_release => :rollback_release_path do
180
- on roles(:all) do
179
+ on release_roles(:all) do
181
180
  set(:revision_log_message, rollback_log_message)
182
181
  end
183
182
  end
@@ -187,18 +186,21 @@ namespace :deploy do
187
186
  end
188
187
 
189
188
  task :last_release_path do
190
- on roles(:all) do
189
+ on release_roles(:all) do
191
190
  last_release = capture(:ls, '-xr', releases_path).split[1]
192
191
  set_release_path(last_release)
193
192
  end
194
193
  end
195
194
 
196
195
  task :rollback_release_path do
197
- on roles(:all) do
196
+ on release_roles(:all) do
198
197
  last_release = capture(:ls, '-xr', releases_path).split[1]
199
198
  set_release_path(last_release)
200
199
  set(:rollback_timestamp, last_release)
201
200
  end
202
201
  end
203
202
 
203
+ task :restart
204
+ task :failed
205
+
204
206
  end
@@ -57,6 +57,7 @@ end
57
57
 
58
58
  desc 'Deploy a new release.'
59
59
  task :deploy do
60
+ set(:deploying, true)
60
61
  %w{ starting started
61
62
  updating updated
62
63
  publishing published
@@ -1,5 +1,9 @@
1
1
  namespace :git do
2
2
 
3
+ def strategy
4
+ @strategy ||= Capistrano::Git.new(self, fetch(:git_strategy, Capistrano::Git::DefaultStrategy))
5
+ end
6
+
3
7
  set :git_environmental_variables, ->() {
4
8
  {
5
9
  git_askpass: "/bin/echo",
@@ -9,7 +13,7 @@ namespace :git do
9
13
 
10
14
  desc 'Upload the git wrapper script, this script guarantees that we can script git without getting an interactive prompt'
11
15
  task :wrapper do
12
- on roles :all do
16
+ on release_roles :all do
13
17
  execute :mkdir, "-p", "#{fetch(:tmp_dir)}/#{fetch(:application)}/"
14
18
  upload! StringIO.new("#!/bin/sh -e\nexec /usr/bin/ssh -o PasswordAuthentication=no -o StrictHostKeyChecking=no \"$@\"\n"), "#{fetch(:tmp_dir)}/#{fetch(:application)}/git-ssh.sh"
15
19
  execute :chmod, "+x", "#{fetch(:tmp_dir)}/#{fetch(:application)}/git-ssh.sh"
@@ -19,22 +23,22 @@ namespace :git do
19
23
  desc 'Check that the repository is reachable'
20
24
  task check: :'git:wrapper' do
21
25
  fetch(:branch)
22
- on roles :all do
26
+ on release_roles :all do
23
27
  with fetch(:git_environmental_variables) do
24
- exit 1 unless test :git, :'ls-remote', repo_url
28
+ exit 1 unless strategy.check
25
29
  end
26
30
  end
27
31
  end
28
32
 
29
33
  desc 'Clone the repo to the cache'
30
34
  task clone: :'git:wrapper' do
31
- on roles :all do
32
- if test " [ -f #{repo_path}/HEAD ] "
35
+ on release_roles :all do
36
+ if strategy.test
33
37
  info t(:mirror_exists, at: repo_path)
34
38
  else
35
39
  within deploy_path do
36
40
  with fetch(:git_environmental_variables) do
37
- execute :git, :clone, '--mirror', repo_url, repo_path
41
+ strategy.clone
38
42
  end
39
43
  end
40
44
  end
@@ -43,20 +47,22 @@ namespace :git do
43
47
 
44
48
  desc 'Update the repo mirror to reflect the origin state'
45
49
  task update: :'git:clone' do
46
- on roles :all do
50
+ on release_roles :all do
47
51
  within repo_path do
48
- execute :git, :remote, :update
52
+ capturing_revisions do
53
+ strategy.update
54
+ end
49
55
  end
50
56
  end
51
57
  end
52
58
 
53
59
  desc 'Copy repo to releases'
54
60
  task create_release: :'git:update' do
55
- on roles :all do
61
+ on release_roles :all do
56
62
  with fetch(:git_environmental_variables) do
57
63
  within repo_path do
58
64
  execute :mkdir, '-p', release_path
59
- execute :git, :archive, fetch(:branch), '| tar -x -C', release_path
65
+ strategy.release
60
66
  end
61
67
  end
62
68
  end
@@ -1,19 +1,23 @@
1
1
  namespace :hg do
2
+ def strategy
3
+ @strategy ||= Capistrano::Hg.new(self, fetch(:hg_strategy, Capistrano::Hg::DefaultStrategy))
4
+ end
5
+
2
6
  desc 'Check that the repo is reachable'
3
7
  task :check do
4
- on roles :all do
5
- execute "hg", "id", repo_url
8
+ on release_roles :all do
9
+ strategy.check
6
10
  end
7
11
  end
8
12
 
9
13
  desc 'Clone the repo to the cache'
10
14
  task :clone do
11
- on roles :all do
12
- if test " [ -d #{repo_path}/.hg ] "
15
+ on release_roles :all do
16
+ if strategy.test
13
17
  info t(:mirror_exists, at: repo_path)
14
18
  else
15
19
  within deploy_path do
16
- execute "hg", "clone", "--noupdate", repo_url, repo_path
20
+ strategy.clone
17
21
  end
18
22
  end
19
23
  end
@@ -21,18 +25,18 @@ namespace :hg do
21
25
 
22
26
  desc 'Pull changes from the remote repo'
23
27
  task :update => :'hg:clone' do
24
- on roles :all do
28
+ on release_roles :all do
25
29
  within repo_path do
26
- execute "hg", "pull"
30
+ strategy.update
27
31
  end
28
32
  end
29
33
  end
30
34
 
31
35
  desc 'Copy repo to releases'
32
36
  task :create_release => :'hg:update' do
33
- on roles :all do
37
+ on release_roles :all do
34
38
  within repo_path do
35
- execute "hg", "archive", release_path, "--rev", fetch(:branch)
39
+ strategy.release
36
40
  end
37
41
  end
38
42
  end
@@ -12,8 +12,7 @@ require 'capistrano/deploy'
12
12
  # https://github.com/capistrano/rbenv
13
13
  # https://github.com/capistrano/chruby
14
14
  # https://github.com/capistrano/bundler
15
- # https://github.com/capistrano/rails/tree/master/assets
16
- # https://github.com/capistrano/rails/tree/master/migrations
15
+ # https://github.com/capistrano/rails
17
16
  #
18
17
  # require 'capistrano/rvm'
19
18
  # require 'capistrano/rbenv'
@@ -1,19 +1,37 @@
1
+ # config valid only for Capistrano 3.1
2
+ lock '<%= Capistrano::VERSION %>'
3
+
1
4
  set :application, 'my_app_name'
2
5
  set :repo_url, 'git@example.com:me/my_repo.git'
3
6
 
7
+ # Default branch is :master
4
8
  # ask :branch, proc { `git rev-parse --abbrev-ref HEAD`.chomp }
5
9
 
10
+ # Default deploy_to directory is /var/www/my_app
6
11
  # set :deploy_to, '/var/www/my_app'
12
+
13
+ # Default value for :scm is :git
7
14
  # set :scm, :git
8
15
 
16
+ # Default value for :format is :pretty
9
17
  # set :format, :pretty
18
+
19
+ # Default value for :log_level is :debug
10
20
  # set :log_level, :debug
21
+
22
+ # Default value for :pty is false
11
23
  # set :pty, true
12
24
 
25
+ # Default value for :linked_files is []
13
26
  # set :linked_files, %w{config/database.yml}
27
+
28
+ # Default value for linked_dirs is []
14
29
  # set :linked_dirs, %w{bin log tmp/pids tmp/cache tmp/sockets vendor/bundle public/system}
15
30
 
31
+ # Default value for default_env is {}
16
32
  # set :default_env, { path: "/opt/ruby/bin:$PATH" }
33
+
34
+ # Default value for keep_releases is 5
17
35
  # set :keep_releases, 5
18
36
 
19
37
  namespace :deploy do
@@ -26,6 +44,8 @@ namespace :deploy do
26
44
  end
27
45
  end
28
46
 
47
+ after :publishing, :restart
48
+
29
49
  after :restart, :clear_cache do
30
50
  on roles(:web), in: :groups, limit: 3, wait: 10 do
31
51
  # Here we can do anything such as:
@@ -35,6 +55,4 @@ namespace :deploy do
35
55
  end
36
56
  end
37
57
 
38
- after :finishing, 'deploy:cleanup'
39
-
40
58
  end
@@ -1,10 +1,9 @@
1
- set :stage, :<%= stage %>
2
-
3
1
  # Simple Role Syntax
4
2
  # ==================
5
3
  # Supports bulk-adding hosts to roles, the primary
6
4
  # server in each group is considered to be the first
7
5
  # unless any hosts have the primary property set.
6
+ # Don't declare `role :all`, it's a meta role
8
7
  role :app, %w{deploy@example.com}
9
8
  role :web, %w{deploy@example.com}
10
9
  role :db, %w{deploy@example.com}
@@ -38,5 +37,3 @@ server 'example.com', user: 'deploy', roles: %w{web app}, my_property: :my_value
38
37
  # # password: 'please use keys'
39
38
  # }
40
39
  # setting per server overrides global ssh_options
41
-
42
- # fetch(:default_env).merge!(rails_env: :<%= stage %>)
@@ -1,3 +1,3 @@
1
1
  module Capistrano
2
- VERSION = "3.0.1"
2
+ VERSION = "3.1.0"
3
3
  end
@@ -4,6 +4,10 @@ describe Capistrano::DSL do
4
4
 
5
5
  let(:dsl) { Class.new.extend Capistrano::DSL }
6
6
 
7
+ before do
8
+ Capistrano::Configuration.reset!
9
+ end
10
+
7
11
  describe 'setting and fetching hosts' do
8
12
  describe 'when defining a host using the `server` syntax' do
9
13
  before do
@@ -11,13 +15,33 @@ describe Capistrano::DSL do
11
15
  dsl.server 'example2.com', roles: %w{web}
12
16
  dsl.server 'example3.com', roles: %w{app web}, active: true
13
17
  dsl.server 'example4.com', roles: %w{app}, primary: true
18
+ dsl.server 'example5.com', roles: %w{db}, no_release: true
14
19
  end
15
20
 
16
21
  describe 'fetching all servers' do
17
22
  subject { dsl.roles(:all) }
18
23
 
19
24
  it 'returns all servers' do
20
- expect(subject.map(&:hostname)).to eq %w{example1.com example2.com example3.com example4.com}
25
+ expect(subject.map(&:hostname)).to eq %w{example1.com example2.com example3.com example4.com example5.com}
26
+ end
27
+ end
28
+
29
+ describe 'fetching all release servers' do
30
+
31
+ context 'with no additional options' do
32
+ subject { dsl.release_roles(:all) }
33
+
34
+ it 'returns all release servers' do
35
+ expect(subject.map(&:hostname)).to eq %w{example1.com example2.com example3.com example4.com}
36
+ end
37
+ end
38
+
39
+ context 'with filter options' do
40
+ subject { dsl.release_roles(:all, filter: :active) }
41
+
42
+ it 'returns all release servers that match the filter' do
43
+ expect(subject.map(&:hostname)).to eq %w{example1.com example3.com}
44
+ end
21
45
  end
22
46
  end
23
47
 
@@ -36,6 +60,14 @@ describe Capistrano::DSL do
36
60
  end
37
61
  end
38
62
 
63
+ describe 'fetching servers by an array of roles' do
64
+ subject { dsl.roles([:app]) }
65
+
66
+ it 'returns the servers' do
67
+ expect(subject.map(&:hostname)).to eq %w{example3.com example4.com}
68
+ end
69
+ end
70
+
39
71
  describe 'fetching filtered servers by role' do
40
72
  subject { dsl.roles(:app, filter: :active) }
41
73
 
@@ -70,6 +102,14 @@ describe Capistrano::DSL do
70
102
 
71
103
  end
72
104
 
105
+ describe 'when defining role with reserved name' do
106
+ it 'fails with ArgumentError' do
107
+ expect {
108
+ dsl.role :all, %w{example1.com}
109
+ }.to raise_error(ArgumentError, "all reserved name for role. Please choose another name")
110
+ end
111
+ end
112
+
73
113
  describe 'when defining hosts using the `role` syntax' do
74
114
  before do
75
115
  dsl.role :web, %w{example1.com example2.com example3.com}
@@ -77,16 +117,37 @@ describe Capistrano::DSL do
77
117
  dsl.role :app, %w{example3.com example4.com}
78
118
  dsl.role :app, %w{example3.com}, active: true
79
119
  dsl.role :app, %w{example4.com}, primary: true
120
+ dsl.role :db, %w{example5.com}, no_release: true
80
121
  end
81
122
 
82
123
  describe 'fetching all servers' do
83
124
  subject { dsl.roles(:all) }
84
125
 
85
126
  it 'returns all servers' do
86
- expect(subject.map(&:hostname)).to eq %w{example1.com example2.com example3.com example4.com}
127
+ expect(subject.map(&:hostname)).to eq %w{example1.com example2.com example3.com example4.com example5.com}
87
128
  end
88
129
  end
89
130
 
131
+ describe 'fetching all release servers' do
132
+
133
+ context 'with no additional options' do
134
+ subject { dsl.release_roles(:all) }
135
+
136
+ it 'returns all release servers' do
137
+ expect(subject.map(&:hostname)).to eq %w{example1.com example2.com example3.com example4.com}
138
+ end
139
+ end
140
+
141
+ context 'with filter options' do
142
+ subject { dsl.release_roles(:all, filter: :active) }
143
+
144
+ it 'returns all release servers that match the filter' do
145
+ expect(subject.map(&:hostname)).to eq %w{example1.com example3.com}
146
+ end
147
+ end
148
+ end
149
+
150
+
90
151
  describe 'fetching servers by role' do
91
152
  subject { dsl.roles(:app) }
92
153
 
@@ -95,6 +156,14 @@ describe Capistrano::DSL do
95
156
  end
96
157
  end
97
158
 
159
+ describe 'fetching servers by an array of roles' do
160
+ subject { dsl.roles([:app]) }
161
+
162
+ it 'returns the servers' do
163
+ expect(subject.map(&:hostname)).to eq %w{example3.com example4.com}
164
+ end
165
+ end
166
+
98
167
  describe 'fetching filtered servers by role' do
99
168
  subject { dsl.roles(:app, filter: :active) }
100
169
 
@@ -129,6 +198,34 @@ describe Capistrano::DSL do
129
198
 
130
199
  end
131
200
 
201
+ describe 'when defining a host using a combination of the `server` and `role` syntax' do
202
+
203
+ before do
204
+ dsl.server 'example1.com:1234', roles: %w{web}, active: true
205
+ dsl.server 'example1.com:5678', roles: %w{web}, active: true
206
+ dsl.role :app, %w{example1.com:5678}
207
+ end
208
+
209
+ describe 'fetching all servers' do
210
+ subject { dsl.roles(:all).map { |server| "#{server.hostname}:#{server.port}" } }
211
+
212
+ it 'creates a server instance for each unique host:port combination' do
213
+ expect(subject).to eq %w{example1.com:1234 example1.com:5678}
214
+ end
215
+ end
216
+
217
+ describe 'fetching servers for a role' do
218
+ it 'roles defined using the `server` syntax are included' do
219
+ expect(dsl.roles(:web)).to have(2).items
220
+ end
221
+
222
+ it 'roles defined using the `role` syntax are included' do
223
+ expect(dsl.roles(:app)).to have(1).items
224
+ end
225
+ end
226
+
227
+ end
228
+
132
229
  end
133
230
 
134
231
  describe 'setting and fetching variables' do
@@ -340,5 +437,53 @@ describe Capistrano::DSL do
340
437
  end
341
438
  end
342
439
 
440
+ describe 'setting deploy configuration path' do
441
+ subject { dsl.deploy_config_path.to_s }
442
+
443
+ context 'where no config path is set' do
444
+ before do
445
+ dsl.delete(:deploy_config_path)
446
+ end
447
+
448
+ it 'returns "config/deploy.rb"' do
449
+ expect(subject).to eq 'config/deploy.rb'
450
+ end
451
+ end
452
+
453
+ context 'where a custom path is set' do
454
+ before do
455
+ dsl.set(:deploy_config_path, 'my/custom/path.rb')
456
+ end
457
+
458
+ it 'returns the custom path' do
459
+ expect(subject).to eq 'my/custom/path.rb'
460
+ end
461
+ end
462
+ end
463
+
464
+ describe 'setting stage configuration path' do
465
+ subject { dsl.stage_config_path.to_s }
466
+
467
+ context 'where no config path is set' do
468
+
469
+ before do
470
+ dsl.delete(:stage_config_path)
471
+ end
472
+
473
+ it 'returns "config/deploy"' do
474
+ expect(subject).to eq 'config/deploy'
475
+ end
476
+ end
477
+
478
+ context 'where a custom path is set' do
479
+ before do
480
+ dsl.set(:stage_config_path, 'my/custom/path')
481
+ end
482
+
483
+ it 'returns the custom path' do
484
+ expect(subject).to eq 'my/custom/path'
485
+ end
486
+ end
487
+ end
343
488
  end
344
489
  end