Remove excess whitespace.
[puppet_vcsrepo.git] / spec / unit / puppet / provider / vcsrepo / git_spec.rb
1 require 'spec_helper'
2
3 describe_provider :vcsrepo, :git, :resource => {:path => '/tmp/vcsrepo'} do
4
5   context 'creating' do
6     resource_with :source do
7       resource_with :ensure => :present do
8         context "with a revision that is a remote branch", :resource => {:revision => 'only/remote'} do
9           it "should execute 'git clone' and 'git checkout -b'" do
10             provider.expects('git').with('clone', resource.value(:source), resource.value(:path))
11             expects_chdir
12             provider.expects(:update_submodules)
13             provider.expects(:git).with('branch', '-a').returns(resource.value(:revision))
14             provider.expects(:git).with('checkout', '--force', resource.value(:revision))
15             provider.create
16           end
17         end
18         context "with a revision that is not a remote branch", :resource => {:revision => 'a-commit-or-tag'} do
19           it "should execute 'git clone' and 'git reset --hard'" do
20             provider.expects('git').with('clone', resource.value(:source), resource.value(:path))
21             expects_chdir
22             provider.expects(:update_submodules)
23             provider.expects(:git).with('branch', '-a').returns(resource.value(:revision))
24             provider.expects(:git).with('checkout', '--force', resource.value(:revision))
25             provider.create
26           end
27         end
28         resource_without :revision do
29           it "should execute 'git clone' and submodule commands" do
30             provider.expects(:git).with('clone', resource.value(:source), resource.value(:path))
31             provider.expects(:update_submodules)
32             provider.create
33           end
34         end
35       end
36
37       resource_with :ensure => :bare do
38         resource_with :revision do
39           it "should just execute 'git clone --bare'" do
40             provider.expects(:git).with('clone', '--bare', resource.value(:source), resource.value(:path))
41             provider.create
42           end
43         end
44
45         resource_without :revision do
46           it "should just execute 'git clone --bare'" do
47             provider.expects(:git).with('clone', '--bare', resource.value(:source), resource.value(:path))
48             provider.create
49           end
50         end
51       end
52     end
53
54     context "when a source is not given" do
55       resource_with :ensure => :present do
56         context "when the path does not exist" do
57           it "should execute 'git init'" do
58             expects_mkdir
59             expects_chdir
60             expects_directory?(false)
61             provider.expects(:bare_exists?).returns(false)
62             provider.expects(:git).with('init')
63             provider.create
64           end
65         end
66
67         context "when the path is a bare repository" do
68           it "should convert it to a working copy" do
69             provider.expects(:bare_exists?).returns(true)
70             provider.expects(:convert_bare_to_working_copy)
71             provider.create
72           end
73         end
74
75         context "when the path is not a repository" do
76           it "should raise an exception" do
77             provider.expects(:path_exists?).returns(true)
78             proc { provider.create }.should raise_error(Puppet::Error)
79           end
80         end
81       end
82
83       resource_with :ensure => :bare do
84         context "when the path does not exist" do
85           it "should execute 'git init --bare'" do
86             expects_chdir
87             expects_mkdir
88             expects_directory?(false)
89             provider.expects(:working_copy_exists?).returns(false)
90             provider.expects(:git).with('init', '--bare')
91             provider.create
92           end
93         end
94
95         context "when the path is a working copy repository" do
96           it "should convert it to a bare repository" do
97             provider.expects(:working_copy_exists?).returns(true)
98             provider.expects(:convert_working_copy_to_bare)
99             provider.create
100           end
101         end
102
103         context "when the path is not a repository" do
104           it "should raise an exception" do
105             expects_directory?(true)
106             proc { provider.create }.should raise_error(Puppet::Error)
107           end
108         end
109       end
110     end
111
112   end
113
114   context 'destroying' do
115     it "it should remove the directory" do
116       expects_rm_rf
117       provider.destroy
118     end
119   end
120
121   context "checking the revision property" do
122     resource_with :revision do
123       before do
124         expects_chdir
125         provider.expects(:git).with('rev-parse', 'HEAD').returns('currentsha')
126       end
127
128       context "when its SHA is not different than the current SHA" do
129         it "should return the ref" do
130           provider.expects(:git).with('fetch', 'origin') # FIXME
131           provider.expects(:git).with('fetch', '--tags', 'origin')
132           provider.expects(:git).with('rev-parse', resource.value(:revision)).returns('currentsha')
133           provider.expects(:git).with('tag', '-l').returns("Hello")
134           provider.revision.should == resource.value(:revision)
135         end
136       end
137
138       context "when its SHA is different than the current SHA" do
139         it "should return the current SHA" do
140           provider.expects(:git).with('fetch', 'origin') # FIXME
141           provider.expects(:git).with('fetch', '--tags', 'origin')
142           provider.expects(:git).with('rev-parse', resource.value(:revision)).returns('othersha')
143           provider.expects(:git).with('tag', '-l').returns("Hello")
144           provider.revision.should == 'currentsha'
145         end
146       end
147     end
148   end
149
150   context "setting the revision property" do
151     before do
152       expects_chdir
153     end
154     context "when it's an existing local branch", :resource => {:revision => 'feature/foo'} do
155       it "should use 'git fetch' and 'git reset'" do
156         provider.expects(:update_submodules)
157         provider.expects(:git).with('branch', '-a').returns(resource.value(:revision))
158         provider.expects(:git).with('checkout', '--force', resource.value(:revision))
159         provider.expects(:git).with('branch', '-a').returns(resource.value(:revision))
160         provider.expects(:git).with('reset', '--hard', "origin/#{resource.value(:revision)}")
161         provider.revision = resource.value(:revision)
162       end
163     end
164     context "when it's a remote branch", :resource => {:revision => 'only/remote'} do
165       it "should use 'git fetch' and 'git reset'" do
166         provider.expects(:update_submodules)
167         provider.expects(:git).with('branch', '-a').returns(resource.value(:revision))
168         provider.expects(:git).with('checkout', '--force', resource.value(:revision))
169         provider.expects(:git).with('branch', '-a').returns(resource.value(:revision))
170         provider.expects(:git).with('reset', '--hard', "origin/#{resource.value(:revision)}")
171         provider.revision = resource.value(:revision)
172       end
173     end
174     context "when it's a commit or tag", :resource => {:revision => 'a-commit-or-tag'} do
175       it "should use 'git fetch' and 'git reset'" do
176         provider.expects(:git).with('branch', '-a').returns(fixture(:git_branch_a))
177         provider.expects(:git).with('checkout', '--force', resource.value(:revision))
178         provider.expects(:git).with('branch', '-a').returns(fixture(:git_branch_a))
179         provider.expects(:git).with('submodule', 'init')
180         provider.expects(:git).with('submodule', 'update')
181         provider.expects(:git).with('branch', '-a').returns(fixture(:git_branch_a))
182         provider.expects(:git).with('submodule', 'foreach', 'git', 'submodule', 'init')
183         provider.expects(:git).with('submodule', 'foreach', 'git', 'submodule', 'update')
184         provider.revision = resource.value(:revision)
185       end
186     end
187   end
188
189   context "updating references" do
190     it "should use 'git fetch --tags'" do
191       expects_chdir
192       provider.expects(:git).with('fetch', 'origin')
193       provider.expects(:git).with('fetch', '--tags', 'origin')
194       provider.update_references
195     end
196   end
197
198   context "checking if revision" do
199     before do
200       expects_chdir
201       provider.expects(:git).with('branch', '-a').returns(fixture(:git_branch_a))
202     end
203     context "is a local branch" do
204       context "when it's listed in 'git branch -a'", :resource => {:revision => 'feature/foo'} do
205         it "should return true" do
206           provider.should be_local_branch_revision
207         end
208       end
209       context "when it's not listed in 'git branch -a'" , :resource => {:revision => 'feature/notexist'}do
210         it "should return false" do
211           provider.should_not be_local_branch_revision
212         end
213       end
214     end
215     context "is a remote branch" do
216       context "when it's listed in 'git branch -a' with an 'origin/' prefix", :resource => {:revision => 'only/remote'} do
217         it "should return true" do
218           provider.should be_remote_branch_revision
219         end
220       end
221       context "when it's not listed in 'git branch -a' with an 'origin/' prefix" , :resource => {:revision => 'only/local'}do
222         it "should return false" do
223           provider.should_not be_remote_branch_revision
224         end
225       end
226     end
227   end
228
229 end