capistrano 2.3.0 → 2.4.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (35) hide show
  1. data/CHANGELOG +50 -2
  2. data/lib/capistrano/cli/execute.rb +1 -0
  3. data/lib/capistrano/cli/options.rb +4 -0
  4. data/lib/capistrano/cli/ui.rb +13 -0
  5. data/lib/capistrano/command.rb +2 -2
  6. data/lib/capistrano/configuration.rb +2 -1
  7. data/lib/capistrano/configuration/actions/file_transfer.rb +5 -1
  8. data/lib/capistrano/configuration/actions/invocation.rb +45 -18
  9. data/lib/capistrano/configuration/callbacks.rb +3 -3
  10. data/lib/capistrano/configuration/execution.rb +8 -3
  11. data/lib/capistrano/configuration/loading.rb +20 -21
  12. data/lib/capistrano/recipes/deploy.rb +56 -27
  13. data/lib/capistrano/recipes/deploy/local_dependency.rb +6 -2
  14. data/lib/capistrano/recipes/deploy/remote_dependency.rb +2 -0
  15. data/lib/capistrano/recipes/deploy/scm/git.rb +21 -12
  16. data/lib/capistrano/recipes/deploy/scm/mercurial.rb +2 -1
  17. data/lib/capistrano/recipes/deploy/scm/subversion.rb +2 -1
  18. data/lib/capistrano/recipes/deploy/strategy/copy.rb +22 -34
  19. data/lib/capistrano/recipes/deploy/strategy/remote.rb +1 -1
  20. data/lib/capistrano/version.rb +1 -14
  21. data/test/cli/execute_test.rb +1 -1
  22. data/test/cli/options_test.rb +7 -1
  23. data/test/configuration/actions/file_transfer_test.rb +20 -1
  24. data/test/configuration/actions/invocation_test.rb +16 -10
  25. data/test/configuration/callbacks_test.rb +16 -2
  26. data/test/configuration/loading_test.rb +6 -1
  27. data/test/deploy/local_dependency_test.rb +73 -0
  28. data/test/deploy/remote_dependency_test.rb +114 -0
  29. data/test/deploy/scm/git_test.rb +22 -8
  30. data/test/deploy/scm/mercurial_test.rb +10 -4
  31. data/test/deploy/strategy/copy_test.rb +16 -11
  32. data/test/role_test.rb +11 -0
  33. data/test/server_definition_test.rb +14 -1
  34. metadata +5 -3
  35. data/test/version_test.rb +0 -24
@@ -117,6 +117,11 @@ class ConfigurationLoadingTest < Test::Unit::TestCase
117
117
  end
118
118
  end
119
119
 
120
+ def test_require_from_config_should_return_false_when_called_a_second_time_with_same_args
121
+ assert @config.require("#{File.dirname(__FILE__)}/../fixtures/custom")
122
+ assert_equal false, @config.require("#{File.dirname(__FILE__)}/../fixtures/custom")
123
+ end
124
+
120
125
  def test_require_in_multiple_instances_should_load_recipes_in_each_instance
121
126
  config2 = MockConfig.new
122
127
  @config.require "#{File.dirname(__FILE__)}/../fixtures/custom"
@@ -124,4 +129,4 @@ class ConfigurationLoadingTest < Test::Unit::TestCase
124
129
  assert_equal :custom, @config.ping
125
130
  assert_equal :custom, config2.ping
126
131
  end
127
- end
132
+ end
@@ -0,0 +1,73 @@
1
+ require "utils"
2
+ require 'capistrano/recipes/deploy/local_dependency'
3
+
4
+ class LocalDependencyTest < Test::Unit::TestCase
5
+ def setup
6
+ @config = { }
7
+ @dependency = Capistrano::Deploy::LocalDependency.new(@config)
8
+ end
9
+
10
+ def test_should_use_standard_error_message
11
+ setup_for_one_path_entry(false)
12
+ @dependency.command("cat")
13
+ assert_equal "`cat' could not be found in the path on the local host", @dependency.message
14
+ end
15
+
16
+ def test_should_use_alternative_message_if_provided
17
+ setup_for_one_path_entry(false)
18
+ @dependency.command("cat").or("Sorry")
19
+ assert_equal "Sorry", @dependency.message
20
+ end
21
+
22
+ def test_env_with_no_path_should_never_find_command
23
+ ENV.expects(:[]).with("PATH").returns(nil)
24
+ assert !@dependency.command("cat").pass?
25
+ end
26
+
27
+ def test_env_with_one_path_entry_should_fail_if_command_not_found
28
+ setup_for_one_path_entry(false)
29
+ assert !@dependency.command("cat").pass?
30
+ end
31
+
32
+ def test_env_with_one_path_entry_should_pass_if_command_found
33
+ setup_for_one_path_entry(true)
34
+ assert @dependency.command("cat").pass?
35
+ end
36
+
37
+ def test_env_with_three_path_entries_should_fail_if_command_not_found
38
+ setup_for_three_path_entries(false)
39
+ assert !@dependency.command("cat").pass?
40
+ end
41
+
42
+ def test_env_with_three_path_entries_should_pass_if_command_found
43
+ setup_for_three_path_entries(true)
44
+ assert @dependency.command("cat").pass?
45
+ end
46
+
47
+ def test_env_with_one_path_entry_on_windows_should_pass_if_command_found_with_extension
48
+ setup_for_one_path_entry_on_windows(true)
49
+ assert @dependency.command("cat").pass?
50
+ end
51
+
52
+ private
53
+
54
+ def setup_for_one_path_entry(command_found)
55
+ ENV.expects(:[]).with("PATH").returns("/bin")
56
+ File.expects(:executable?).with("/bin/cat").returns(command_found)
57
+ end
58
+
59
+ def setup_for_three_path_entries(command_found)
60
+ path = %w(/bin /usr/bin /usr/local/bin).join(File::PATH_SEPARATOR)
61
+ ENV.expects(:[]).with("PATH").returns(path)
62
+ File.expects(:executable?).with("/usr/bin/cat").returns(command_found)
63
+ File.expects(:executable?).at_most(1).with("/bin/cat").returns(false)
64
+ File.expects(:executable?).at_most(1).with("/usr/local/bin/cat").returns(false)
65
+ end
66
+
67
+ def setup_for_one_path_entry_on_windows(command_found)
68
+ Capistrano::Deploy::LocalDependency.expects(:on_windows?).returns(true)
69
+ ENV.expects(:[]).with("PATH").returns("/cygwin/bin")
70
+ File.stubs(:executable?).returns(false)
71
+ File.expects(:executable?).with("/cygwin/bin/cat.exe").returns(command_found)
72
+ end
73
+ end
@@ -0,0 +1,114 @@
1
+ require "utils"
2
+ require 'capistrano/recipes/deploy/remote_dependency'
3
+
4
+ class RemoteDependencyTest < Test::Unit::TestCase
5
+ def setup
6
+ @config = { }
7
+ @dependency = Capistrano::Deploy::RemoteDependency.new(@config)
8
+ end
9
+
10
+ def test_should_use_standard_error_message_for_directory
11
+ setup_for_a_configuration_run("test -d /data", false)
12
+ @dependency.directory("/data")
13
+ assert_equal "`/data' is not a directory (host)", @dependency.message
14
+ end
15
+
16
+ def test_should_use_standard_error_message_for_file
17
+ setup_for_a_configuration_run("test -f /data/foo.txt", false)
18
+ @dependency.file("/data/foo.txt")
19
+ assert_equal "`/data/foo.txt' is not a file (host)", @dependency.message
20
+ end
21
+
22
+ def test_should_use_standard_error_message_for_writable
23
+ setup_for_a_configuration_run("test -w /data/foo.txt", false)
24
+ @dependency.writable("/data/foo.txt")
25
+ assert_equal "`/data/foo.txt' is not writable (host)", @dependency.message
26
+ end
27
+
28
+ def test_should_use_standard_error_message_for_command
29
+ setup_for_a_configuration_run("which cat", false)
30
+ @dependency.command("cat")
31
+ assert_equal "`cat' could not be found in the path (host)", @dependency.message
32
+ end
33
+
34
+ def test_should_use_standard_error_message_for_gem
35
+ setup_for_a_configuration_gem_run("capistrano", "9.9", false)
36
+ @dependency.gem("capistrano", 9.9)
37
+ assert_equal "gem `capistrano' 9.9 could not be found (host)", @dependency.message
38
+ end
39
+
40
+ def test_should_fail_if_directory_not_found
41
+ setup_for_a_configuration_run("test -d /data", false)
42
+ assert !@dependency.directory("/data").pass?
43
+ end
44
+
45
+ def test_should_pass_if_directory_found
46
+ setup_for_a_configuration_run("test -d /data", true)
47
+ assert @dependency.directory("/data").pass?
48
+ end
49
+
50
+ def test_should_fail_if_file_not_found
51
+ setup_for_a_configuration_run("test -f /data/foo.txt", false)
52
+ assert !@dependency.file("/data/foo.txt").pass?
53
+ end
54
+
55
+ def test_should_pas_if_file_found
56
+ setup_for_a_configuration_run("test -f /data/foo.txt", true)
57
+ assert @dependency.file("/data/foo.txt").pass?
58
+ end
59
+
60
+ def test_should_fail_if_writable_not_found
61
+ setup_for_a_configuration_run("test -w /data/foo.txt", false)
62
+ assert !@dependency.writable("/data/foo.txt").pass?
63
+ end
64
+
65
+ def test_should_pass_if_writable_found
66
+ setup_for_a_configuration_run("test -w /data/foo.txt", true)
67
+ assert @dependency.writable("/data/foo.txt").pass?
68
+ end
69
+
70
+ def test_should_fail_if_command_not_found
71
+ setup_for_a_configuration_run("which cat", false)
72
+ assert !@dependency.command("cat").pass?
73
+ end
74
+
75
+ def test_should_pass_if_command_found
76
+ setup_for_a_configuration_run("which cat", true)
77
+ assert @dependency.command("cat").pass?
78
+ end
79
+
80
+ def test_should_fail_if_gem_not_found
81
+ setup_for_a_configuration_gem_run("capistrano", "9.9", false)
82
+ assert !@dependency.gem("capistrano", 9.9).pass?
83
+ end
84
+
85
+ def test_should_pass_if_gem_found
86
+ setup_for_a_configuration_gem_run("capistrano", "9.9", true)
87
+ assert @dependency.gem("capistrano", 9.9).pass?
88
+ end
89
+
90
+ def test_should_use_alternative_message_if_provided
91
+ setup_for_a_configuration_run("which cat", false)
92
+ @dependency.command("cat").or("Sorry")
93
+ assert_equal "Sorry (host)", @dependency.message
94
+ end
95
+
96
+ private
97
+
98
+ def setup_for_a_configuration_run(command, passing)
99
+ expectation = @config.expects(:run).with(command, {})
100
+ if passing
101
+ expectation.returns(true)
102
+ else
103
+ error = Capistrano::CommandError.new
104
+ error.expects(:hosts).returns(["host"])
105
+ expectation.raises(error)
106
+ end
107
+ end
108
+
109
+ def setup_for_a_configuration_gem_run(name, version, passing)
110
+ @config.expects(:fetch).with(:gem_command, "gem").returns("gem")
111
+ find_gem_cmd = "gem specification --version '#{version}' #{name} 2>&1 | awk 'BEGIN { s = 0 } /^name:/ { s = 1; exit }; END { if(s == 0) exit 1 }'"
112
+ setup_for_a_configuration_run(find_gem_cmd, passing)
113
+ end
114
+ end
@@ -31,12 +31,20 @@ class DeploySCMGitTest < Test::Unit::TestCase
31
31
  @config[:repository] = "git@somehost.com:project.git"
32
32
  dest = "/var/www"
33
33
  rev = 'c2d9e79'
34
- assert_equal "git clone git@somehost.com:project.git /var/www && cd /var/www && git checkout -b deploy #{rev}", @source.checkout(rev, dest)
34
+ assert_equal "git clone -q git@somehost.com:project.git /var/www && cd /var/www && git checkout -q -b deploy #{rev}", @source.checkout(rev, dest)
35
35
 
36
36
  # With :scm_command
37
37
  git = "/opt/local/bin/git"
38
38
  @config[:scm_command] = git
39
- assert_equal "#{git} clone git@somehost.com:project.git /var/www && cd /var/www && #{git} checkout -b deploy #{rev}", @source.checkout(rev, dest)
39
+ assert_equal "#{git} clone -q git@somehost.com:project.git /var/www && cd /var/www && #{git} checkout -q -b deploy #{rev}", @source.checkout(rev, dest)
40
+ end
41
+
42
+ def test_checkout_with_verbose_should_not_use_q_switch
43
+ @config[:repository] = "git@somehost.com:project.git"
44
+ @config[:scm_verbose] = true
45
+ dest = "/var/www"
46
+ rev = 'c2d9e79'
47
+ assert_equal "git clone git@somehost.com:project.git /var/www && cd /var/www && git checkout -b deploy #{rev}", @source.checkout(rev, dest)
40
48
  end
41
49
 
42
50
  def test_diff
@@ -45,7 +53,7 @@ class DeploySCMGitTest < Test::Unit::TestCase
45
53
  end
46
54
 
47
55
  def test_log
48
- assert_equal "git log master", @source.log('master')
56
+ assert_equal "git log master..", @source.log('master')
49
57
  assert_equal "git log master..branch", @source.log('master', 'branch')
50
58
  end
51
59
 
@@ -57,6 +65,12 @@ class DeploySCMGitTest < Test::Unit::TestCase
57
65
  assert_equal "d11006102c07c94e5d54dd0ee63dca825c93ed61", revision
58
66
  end
59
67
 
68
+ def test_query_revision_deprecation_error
69
+ assert_raise(ArgumentError) do
70
+ revision = @source.query_revision('origin/release') {}
71
+ end
72
+ end
73
+
60
74
  def test_command_should_be_backwards_compatible
61
75
  # 1.x version of this module used ":git", not ":scm_command"
62
76
  @config[:git] = "/srv/bin/git"
@@ -66,12 +80,12 @@ class DeploySCMGitTest < Test::Unit::TestCase
66
80
  def test_sync
67
81
  dest = "/var/www"
68
82
  rev = 'c2d9e79'
69
- assert_equal "cd #{dest} && git fetch --tags origin && git reset --hard #{rev}", @source.sync(rev, dest)
83
+ assert_equal "cd #{dest} && git fetch -q origin && git reset -q --hard #{rev}", @source.sync(rev, dest)
70
84
 
71
85
  # With :scm_command
72
86
  git = "/opt/local/bin/git"
73
87
  @config[:scm_command] = git
74
- assert_equal "cd #{dest} && #{git} fetch --tags origin && #{git} reset --hard #{rev}", @source.sync(rev, dest)
88
+ assert_equal "cd #{dest} && #{git} fetch -q origin && #{git} reset -q --hard #{rev}", @source.sync(rev, dest)
75
89
  end
76
90
 
77
91
  def test_sync_with_remote
@@ -83,7 +97,7 @@ class DeploySCMGitTest < Test::Unit::TestCase
83
97
  @config[:repository] = repository
84
98
  @config[:remote] = remote
85
99
 
86
- assert_equal "cd #{dest} && git config remote.#{remote}.url #{repository} && git config remote.#{remote}.fetch +refs/heads/*:refs/remotes/#{remote}/* && git fetch --tags #{remote} && git reset --hard #{rev}", @source.sync(rev, dest)
100
+ assert_equal "cd #{dest} && git config remote.#{remote}.url #{repository} && git config remote.#{remote}.fetch +refs/heads/*:refs/remotes/#{remote}/* && git fetch -q #{remote} && git reset -q --hard #{rev}", @source.sync(rev, dest)
87
101
  end
88
102
 
89
103
  def test_shallow_clone
@@ -91,7 +105,7 @@ class DeploySCMGitTest < Test::Unit::TestCase
91
105
  @config[:git_shallow_clone] = 1
92
106
  dest = "/var/www"
93
107
  rev = 'c2d9e79'
94
- assert_equal "git clone --depth 1 git@somehost.com:project.git /var/www && cd /var/www && git checkout -b deploy #{rev}", @source.checkout(rev, dest)
108
+ assert_equal "git clone -q --depth 1 git@somehost.com:project.git /var/www && cd /var/www && git checkout -q -b deploy #{rev}", @source.checkout(rev, dest)
95
109
  end
96
110
 
97
111
  def test_remote_clone
@@ -99,7 +113,7 @@ class DeploySCMGitTest < Test::Unit::TestCase
99
113
  @config[:remote] = "username"
100
114
  dest = "/var/www"
101
115
  rev = 'c2d9e79'
102
- assert_equal "git clone -o username git@somehost.com:project.git /var/www && cd /var/www && git checkout -b deploy #{rev}", @source.checkout(rev, dest)
116
+ assert_equal "git clone -q -o username git@somehost.com:project.git /var/www && cd /var/www && git checkout -q -b deploy #{rev}", @source.checkout(rev, dest)
103
117
  end
104
118
 
105
119
  # Tests from base_test.rb, makin' sure we didn't break anything up there!
@@ -43,10 +43,10 @@ class DeploySCMMercurialTest < Test::Unit::TestCase
43
43
  require 'capistrano/logger'
44
44
  @config[:scm_user] = "fred"
45
45
  text = "user:"
46
- assert_equal "fred\n", @source.handle_data(:test_state, :test_stream, text)
46
+ assert_equal "fred\n", @source.handle_data(mock_state, :test_stream, text)
47
47
  # :scm_username takes priority
48
48
  @config[:scm_username] = "wilma"
49
- assert_equal "wilma\n", @source.handle_data(:test_state, :test_stream, text)
49
+ assert_equal "wilma\n", @source.handle_data(mock_state, :test_stream, text)
50
50
  end
51
51
 
52
52
  def test_sync
@@ -67,7 +67,7 @@ class DeploySCMMercurialTest < Test::Unit::TestCase
67
67
  require 'capistrano/logger'
68
68
  text = "password:"
69
69
  @config[:scm_password] = "opensesame"
70
- assert_equal "opensesame\n", @source.handle_data(:test_state, :test_stream, text)
70
+ assert_equal "opensesame\n", @source.handle_data(mock_state, :test_stream, text)
71
71
  end
72
72
 
73
73
  def test_prompts_for_password_if_preferred
@@ -76,7 +76,7 @@ class DeploySCMMercurialTest < Test::Unit::TestCase
76
76
  Capistrano::CLI.stubs(:password_prompt).with("hg password: ").returns("opensesame")
77
77
  @config[:scm_prefer_prompt] = true
78
78
  text = "password:"
79
- assert_equal "opensesame\n", @source.handle_data(:test_state, :test_stream, text)
79
+ assert_equal "opensesame\n", @source.handle_data(mock_state, :test_stream, text)
80
80
  end
81
81
 
82
82
 
@@ -120,4 +120,10 @@ class DeploySCMMercurialTest < Test::Unit::TestCase
120
120
  assert_equal "hg", @source.local.command
121
121
  assert_equal "/foo/bar/hg", @source.command
122
122
  end
123
+
124
+ private
125
+
126
+ def mock_state
127
+ { :channel => { :host => "abc" } }
128
+ end
123
129
  end
@@ -53,13 +53,12 @@ class DeployStrategyCopyTest < Test::Unit::TestCase
53
53
 
54
54
  @strategy.expects(:system).with(:local_checkout)
55
55
  @strategy.expects(:system).with("zip -qr 1234567890.zip 1234567890")
56
- @strategy.expects(:put).with(:mock_file_contents, "/tmp/1234567890.zip")
56
+ @strategy.expects(:upload).with("/temp/dir/1234567890.zip", "/tmp/1234567890.zip")
57
57
  @strategy.expects(:run).with("cd /u/apps/test/releases && unzip -q /tmp/1234567890.zip && rm /tmp/1234567890.zip")
58
58
 
59
59
  mock_file = mock("file")
60
60
  mock_file.expects(:puts).with("154")
61
61
  File.expects(:open).with("/temp/dir/1234567890/REVISION", "w").yields(mock_file)
62
- File.expects(:open).with("/temp/dir/1234567890.zip", "rb").yields(StringIO.new).returns(:mock_file_contents)
63
62
 
64
63
  FileUtils.expects(:rm).with("/temp/dir/1234567890.zip")
65
64
  FileUtils.expects(:rm_rf).with("/temp/dir/1234567890")
@@ -75,20 +74,29 @@ class DeployStrategyCopyTest < Test::Unit::TestCase
75
74
 
76
75
  @strategy.expects(:system).with(:local_checkout)
77
76
  @strategy.expects(:system).with("tar cjf 1234567890.tar.bz2 1234567890")
78
- @strategy.expects(:put).with(:mock_file_contents, "/tmp/1234567890.tar.bz2")
77
+ @strategy.expects(:upload).with("/temp/dir/1234567890.tar.bz2", "/tmp/1234567890.tar.bz2")
79
78
  @strategy.expects(:run).with("cd /u/apps/test/releases && tar xjf /tmp/1234567890.tar.bz2 && rm /tmp/1234567890.tar.bz2")
80
79
 
81
80
  mock_file = mock("file")
82
81
  mock_file.expects(:puts).with("154")
83
82
  File.expects(:open).with("/temp/dir/1234567890/REVISION", "w").yields(mock_file)
84
- File.expects(:open).with("/temp/dir/1234567890.tar.bz2", "rb").yields(StringIO.new).returns(:mock_file_contents)
85
83
 
86
84
  FileUtils.expects(:rm).with("/temp/dir/1234567890.tar.bz2")
87
85
  FileUtils.expects(:rm_rf).with("/temp/dir/1234567890")
88
86
 
89
87
  @strategy.deploy!
90
88
  end
91
-
89
+
90
+ def test_deploy_with_unknown_compression_type_should_error
91
+ @config[:copy_compression] = :bogus
92
+ Dir.expects(:tmpdir).returns("/temp/dir")
93
+ @source.expects(:checkout).with("154", "/temp/dir/1234567890").returns(:local_checkout)
94
+ @strategy.stubs(:system)
95
+ File.stubs(:open)
96
+
97
+ assert_raises(ArgumentError) { @strategy.deploy! }
98
+ end
99
+
92
100
  def test_deploy_with_custom_copy_dir_should_use_that_as_tmpdir
93
101
  Dir.expects(:tmpdir).never
94
102
  Dir.expects(:chdir).with("/other/path").yields
@@ -97,13 +105,12 @@ class DeployStrategyCopyTest < Test::Unit::TestCase
97
105
 
98
106
  @strategy.expects(:system).with(:local_checkout)
99
107
  @strategy.expects(:system).with("tar czf 1234567890.tar.gz 1234567890")
100
- @strategy.expects(:put).with(:mock_file_contents, "/tmp/1234567890.tar.gz")
108
+ @strategy.expects(:upload).with("/other/path/1234567890.tar.gz", "/tmp/1234567890.tar.gz")
101
109
  @strategy.expects(:run).with("cd /u/apps/test/releases && tar xzf /tmp/1234567890.tar.gz && rm /tmp/1234567890.tar.gz")
102
110
 
103
111
  mock_file = mock("file")
104
112
  mock_file.expects(:puts).with("154")
105
113
  File.expects(:open).with("/other/path/1234567890/REVISION", "w").yields(mock_file)
106
- File.expects(:open).with("/other/path/1234567890.tar.gz", "rb").yields(StringIO.new).returns(:mock_file_contents)
107
114
 
108
115
  FileUtils.expects(:rm).with("/other/path/1234567890.tar.gz")
109
116
  FileUtils.expects(:rm_rf).with("/other/path/1234567890")
@@ -119,13 +126,12 @@ class DeployStrategyCopyTest < Test::Unit::TestCase
119
126
 
120
127
  @strategy.expects(:system).with(:local_checkout)
121
128
  @strategy.expects(:system).with("tar czf 1234567890.tar.gz 1234567890")
122
- @strategy.expects(:put).with(:mock_file_contents, "/somewhere/else/1234567890.tar.gz")
129
+ @strategy.expects(:upload).with("/temp/dir/1234567890.tar.gz", "/somewhere/else/1234567890.tar.gz")
123
130
  @strategy.expects(:run).with("cd /u/apps/test/releases && tar xzf /somewhere/else/1234567890.tar.gz && rm /somewhere/else/1234567890.tar.gz")
124
131
 
125
132
  mock_file = mock("file")
126
133
  mock_file.expects(:puts).with("154")
127
134
  File.expects(:open).with("/temp/dir/1234567890/REVISION", "w").yields(mock_file)
128
- File.expects(:open).with("/temp/dir/1234567890.tar.gz", "rb").yields(StringIO.new).returns(:mock_file_contents)
129
135
 
130
136
  FileUtils.expects(:rm).with("/temp/dir/1234567890.tar.gz")
131
137
  FileUtils.expects(:rm_rf).with("/temp/dir/1234567890")
@@ -226,13 +232,12 @@ class DeployStrategyCopyTest < Test::Unit::TestCase
226
232
  def prepare_standard_compress_and_copy!
227
233
  Dir.expects(:chdir).with("/temp/dir").yields
228
234
  @strategy.expects(:system).with("tar czf 1234567890.tar.gz 1234567890")
229
- @strategy.expects(:put).with(:mock_file_contents, "/tmp/1234567890.tar.gz")
235
+ @strategy.expects(:upload).with("/temp/dir/1234567890.tar.gz", "/tmp/1234567890.tar.gz")
230
236
  @strategy.expects(:run).with("cd /u/apps/test/releases && tar xzf /tmp/1234567890.tar.gz && rm /tmp/1234567890.tar.gz")
231
237
 
232
238
  mock_file = mock("file")
233
239
  mock_file.expects(:puts).with("154")
234
240
  File.expects(:open).with("/temp/dir/1234567890/REVISION", "w").yields(mock_file)
235
- File.expects(:open).with("/temp/dir/1234567890.tar.gz", "rb").yields(StringIO.new).returns(:mock_file_contents)
236
241
 
237
242
  FileUtils.expects(:rm).with("/temp/dir/1234567890.tar.gz")
238
243
  FileUtils.expects(:rm_rf).with("/temp/dir/1234567890")
@@ -0,0 +1,11 @@
1
+ require "utils"
2
+ require 'capistrano/role'
3
+
4
+ class RoleTest < Test::Unit::TestCase
5
+ def test_clearing_a_populated_role_should_yield_no_servers
6
+ role = Capistrano::Role.new("app1.capistrano.test", lambda { "app2.capistrano.test" })
7
+ assert_equal 2, role.servers.size
8
+ role.clear
9
+ assert role.servers.empty?
10
+ end
11
+ end
@@ -62,6 +62,19 @@ class ServerDefinitionTest < Test::Unit::TestCase
62
62
  server = Capistrano::ServerDefinition.new("www.capistrano.test", :primary => true)
63
63
  assert_equal true, server.options[:primary]
64
64
  end
65
+
66
+ def test_default_user_should_try_to_guess_username
67
+ ENV.stubs(:[]).returns(nil)
68
+ assert_equal "not-specified", Capistrano::ServerDefinition.default_user
69
+
70
+ ENV.stubs(:[]).returns(nil)
71
+ ENV.stubs(:[]).with("USERNAME").returns("ryan")
72
+ assert_equal "ryan", Capistrano::ServerDefinition.default_user
73
+
74
+ ENV.stubs(:[]).returns(nil)
75
+ ENV.stubs(:[]).with("USER").returns("jamis")
76
+ assert_equal "jamis", Capistrano::ServerDefinition.default_user
77
+ end
65
78
 
66
79
  def test_comparison_should_match_when_host_user_port_are_same
67
80
  s1 = server("jamis@www.capistrano.test:8080")
@@ -105,4 +118,4 @@ class ServerDefinitionTest < Test::Unit::TestCase
105
118
  assert_equal "jamis@www.capistrano.test", server("jamis@www.capistrano.test").to_s
106
119
  assert_equal "jamis@www.capistrano.test:1234", server("jamis@www.capistrano.test:1234").to_s
107
120
  end
108
- end
121
+ end