##// END OF EJS Templates
Rails3: scm: git: fix error of test_db_consistent_ordering_init at unit model test...
Toshi MARUYAMA -
r6951:2510de53ae92
parent child
Show More
@@ -1,457 +1,458
1 # Redmine - project management software
1 # Redmine - project management software
2 # Copyright (C) 2006-2011 Jean-Philippe Lang
2 # Copyright (C) 2006-2011 Jean-Philippe Lang
3 #
3 #
4 # This program is free software; you can redistribute it and/or
4 # This program is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU General Public License
5 # modify it under the terms of the GNU General Public License
6 # as published by the Free Software Foundation; either version 2
6 # as published by the Free Software Foundation; either version 2
7 # of the License, or (at your option) any later version.
7 # of the License, or (at your option) any later version.
8 #
8 #
9 # This program is distributed in the hope that it will be useful,
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
12 # GNU General Public License for more details.
13 #
13 #
14 # You should have received a copy of the GNU General Public License
14 # You should have received a copy of the GNU General Public License
15 # along with this program; if not, write to the Free Software
15 # along with this program; if not, write to the Free Software
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17
17
18 require File.expand_path('../../test_helper', __FILE__)
18 require File.expand_path('../../test_helper', __FILE__)
19
19
20 class RepositoryGitTest < ActiveSupport::TestCase
20 class RepositoryGitTest < ActiveSupport::TestCase
21 fixtures :projects, :repositories, :enabled_modules, :users, :roles
21 fixtures :projects, :repositories, :enabled_modules, :users, :roles
22
22
23 REPOSITORY_PATH = Rails.root.join('tmp/test/git_repository').to_s
23 REPOSITORY_PATH = Rails.root.join('tmp/test/git_repository').to_s
24 REPOSITORY_PATH.gsub!(/\//, "\\") if Redmine::Platform.mswin?
24 REPOSITORY_PATH.gsub!(/\//, "\\") if Redmine::Platform.mswin?
25
25
26 NUM_REV = 21
26 NUM_REV = 21
27
27
28 FELIX_HEX = "Felix Sch\xC3\xA4fer"
28 FELIX_HEX = "Felix Sch\xC3\xA4fer"
29 CHAR_1_HEX = "\xc3\x9c"
29 CHAR_1_HEX = "\xc3\x9c"
30
30
31 ## Ruby uses ANSI api to fork a process on Windows.
31 ## Ruby uses ANSI api to fork a process on Windows.
32 ## Japanese Shift_JIS and Traditional Chinese Big5 have 0x5c(backslash) problem
32 ## Japanese Shift_JIS and Traditional Chinese Big5 have 0x5c(backslash) problem
33 ## and these are incompatible with ASCII.
33 ## and these are incompatible with ASCII.
34 # WINDOWS_PASS = Redmine::Platform.mswin?
34 # WINDOWS_PASS = Redmine::Platform.mswin?
35 WINDOWS_PASS = false
35 WINDOWS_PASS = false
36
36
37 ## Git, Mercurial and CVS path encodings are binary.
37 ## Git, Mercurial and CVS path encodings are binary.
38 ## Subversion supports URL encoding for path.
38 ## Subversion supports URL encoding for path.
39 ## Redmine Mercurial adapter and extension use URL encoding.
39 ## Redmine Mercurial adapter and extension use URL encoding.
40 ## Git accepts only binary path in command line parameter.
40 ## Git accepts only binary path in command line parameter.
41 ## So, there is no way to use binary command line parameter in JRuby.
41 ## So, there is no way to use binary command line parameter in JRuby.
42 JRUBY_SKIP = (RUBY_PLATFORM == 'java')
42 JRUBY_SKIP = (RUBY_PLATFORM == 'java')
43 JRUBY_SKIP_STR = "TODO: This test fails in JRuby"
43 JRUBY_SKIP_STR = "TODO: This test fails in JRuby"
44
44
45 if File.directory?(REPOSITORY_PATH)
45 if File.directory?(REPOSITORY_PATH)
46 def setup
46 def setup
47 klass = Repository::Git
47 klass = Repository::Git
48 assert_equal "Git", klass.scm_name
48 assert_equal "Git", klass.scm_name
49 assert klass.scm_adapter_class
49 assert klass.scm_adapter_class
50 assert_not_equal "", klass.scm_command
50 assert_not_equal "", klass.scm_command
51 assert_equal true, klass.scm_available
51 assert_equal true, klass.scm_available
52
52
53 @project = Project.find(3)
53 @project = Project.find(3)
54 @repository = Repository::Git.create(
54 @repository = Repository::Git.create(
55 :project => @project,
55 :project => @project,
56 :url => REPOSITORY_PATH,
56 :url => REPOSITORY_PATH,
57 :path_encoding => 'ISO-8859-1'
57 :path_encoding => 'ISO-8859-1'
58 )
58 )
59 assert @repository
59 assert @repository
60 @char_1 = CHAR_1_HEX.dup
60 @char_1 = CHAR_1_HEX.dup
61 if @char_1.respond_to?(:force_encoding)
61 if @char_1.respond_to?(:force_encoding)
62 @char_1.force_encoding('UTF-8')
62 @char_1.force_encoding('UTF-8')
63 end
63 end
64 end
64 end
65
65
66 def test_fetch_changesets_from_scratch
66 def test_fetch_changesets_from_scratch
67 assert_nil @repository.extra_info
67 assert_nil @repository.extra_info
68
68
69 assert_equal 0, @repository.changesets.count
69 assert_equal 0, @repository.changesets.count
70 @repository.fetch_changesets
70 @repository.fetch_changesets
71 @project.reload
71 @project.reload
72
72
73 assert_equal NUM_REV, @repository.changesets.count
73 assert_equal NUM_REV, @repository.changesets.count
74 assert_equal 33, @repository.changes.count
74 assert_equal 33, @repository.changes.count
75
75
76 commit = @repository.changesets.find(:first, :order => 'committed_on ASC')
76 commit = @repository.changesets.find(:first, :order => 'committed_on ASC')
77 assert_equal "Initial import.\nThe repository contains 3 files.", commit.comments
77 assert_equal "Initial import.\nThe repository contains 3 files.", commit.comments
78 assert_equal "jsmith <jsmith@foo.bar>", commit.committer
78 assert_equal "jsmith <jsmith@foo.bar>", commit.committer
79 assert_equal User.find_by_login('jsmith'), commit.user
79 assert_equal User.find_by_login('jsmith'), commit.user
80 # TODO: add a commit with commit time <> author time to the test repository
80 # TODO: add a commit with commit time <> author time to the test repository
81 assert_equal "2007-12-14 09:22:52".to_time, commit.committed_on
81 assert_equal "2007-12-14 09:22:52".to_time, commit.committed_on
82 assert_equal "2007-12-14".to_date, commit.commit_date
82 assert_equal "2007-12-14".to_date, commit.commit_date
83 assert_equal "7234cb2750b63f47bff735edc50a1c0a433c2518", commit.revision
83 assert_equal "7234cb2750b63f47bff735edc50a1c0a433c2518", commit.revision
84 assert_equal "7234cb2750b63f47bff735edc50a1c0a433c2518", commit.scmid
84 assert_equal "7234cb2750b63f47bff735edc50a1c0a433c2518", commit.scmid
85 assert_equal 3, commit.changes.count
85 assert_equal 3, commit.changes.count
86 change = commit.changes.sort_by(&:path).first
86 change = commit.changes.sort_by(&:path).first
87 assert_equal "README", change.path
87 assert_equal "README", change.path
88 assert_equal "A", change.action
88 assert_equal "A", change.action
89
89
90 assert_equal 4, @repository.extra_info["branches"].size
90 assert_equal 4, @repository.extra_info["branches"].size
91 end
91 end
92
92
93 def test_fetch_changesets_incremental
93 def test_fetch_changesets_incremental
94 assert_equal 0, @repository.changesets.count
94 assert_equal 0, @repository.changesets.count
95 @repository.fetch_changesets
95 @repository.fetch_changesets
96 @project.reload
96 @project.reload
97 assert_equal NUM_REV, @repository.changesets.count
97 assert_equal NUM_REV, @repository.changesets.count
98 assert_equal 33, @repository.changes.count
98 assert_equal 33, @repository.changes.count
99 extra_info_db = @repository.extra_info["branches"]
99 extra_info_db = @repository.extra_info["branches"]
100 assert_equal 4, extra_info_db.size
100 assert_equal 4, extra_info_db.size
101 assert_equal "1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127",
101 assert_equal "1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127",
102 extra_info_db["latin-1-path-encoding"]["last_scmid"]
102 extra_info_db["latin-1-path-encoding"]["last_scmid"]
103 assert_equal "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
103 assert_equal "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
104 extra_info_db["master"]["last_scmid"]
104 extra_info_db["master"]["last_scmid"]
105
105
106 del_revs = [
106 del_revs = [
107 "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
107 "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
108 "ed5bb786bbda2dee66a2d50faf51429dbc043a7b",
108 "ed5bb786bbda2dee66a2d50faf51429dbc043a7b",
109 "4f26664364207fa8b1af9f8722647ab2d4ac5d43",
109 "4f26664364207fa8b1af9f8722647ab2d4ac5d43",
110 "deff712f05a90d96edbd70facc47d944be5897e3",
110 "deff712f05a90d96edbd70facc47d944be5897e3",
111 "32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf",
111 "32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf",
112 "7e61ac704deecde634b51e59daa8110435dcb3da",
112 "7e61ac704deecde634b51e59daa8110435dcb3da",
113 ]
113 ]
114 @repository.changesets.each do |rev|
114 @repository.changesets.each do |rev|
115 rev.destroy if del_revs.detect {|r| r == rev.scmid.to_s }
115 rev.destroy if del_revs.detect {|r| r == rev.scmid.to_s }
116 end
116 end
117 @project.reload
117 @project.reload
118 cs1 = @repository.changesets
118 cs1 = @repository.changesets
119 assert_equal 15, cs1.count
119 assert_equal 15, cs1.count
120 h = @repository.extra_info.dup
120 h = @repository.extra_info.dup
121 h["branches"]["master"]["last_scmid"] =
121 h["branches"]["master"]["last_scmid"] =
122 "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8"
122 "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8"
123 @repository.merge_extra_info(h)
123 @repository.merge_extra_info(h)
124 @repository.save
124 @repository.save
125 @project.reload
125 @project.reload
126 extra_info_db_1 = @repository.extra_info["branches"]
126 extra_info_db_1 = @repository.extra_info["branches"]
127 assert_equal "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8",
127 assert_equal "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8",
128 extra_info_db_1["master"]["last_scmid"]
128 extra_info_db_1["master"]["last_scmid"]
129
129
130 @repository.fetch_changesets
130 @repository.fetch_changesets
131 @project.reload
131 @project.reload
132 assert_equal NUM_REV, @repository.changesets.count
132 assert_equal NUM_REV, @repository.changesets.count
133 end
133 end
134
134
135 def test_fetch_changesets_invalid_rev
135 def test_fetch_changesets_invalid_rev
136 assert_equal 0, @repository.changesets.count
136 assert_equal 0, @repository.changesets.count
137 @repository.fetch_changesets
137 @repository.fetch_changesets
138 @project.reload
138 @project.reload
139 assert_equal NUM_REV, @repository.changesets.count
139 assert_equal NUM_REV, @repository.changesets.count
140 extra_info_db = @repository.extra_info["branches"]
140 extra_info_db = @repository.extra_info["branches"]
141 assert_equal 4, extra_info_db.size
141 assert_equal 4, extra_info_db.size
142 assert_equal "1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127",
142 assert_equal "1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127",
143 extra_info_db["latin-1-path-encoding"]["last_scmid"]
143 extra_info_db["latin-1-path-encoding"]["last_scmid"]
144 assert_equal "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
144 assert_equal "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
145 extra_info_db["master"]["last_scmid"]
145 extra_info_db["master"]["last_scmid"]
146
146
147 del_revs = [
147 del_revs = [
148 "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
148 "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
149 "ed5bb786bbda2dee66a2d50faf51429dbc043a7b",
149 "ed5bb786bbda2dee66a2d50faf51429dbc043a7b",
150 "4f26664364207fa8b1af9f8722647ab2d4ac5d43",
150 "4f26664364207fa8b1af9f8722647ab2d4ac5d43",
151 "deff712f05a90d96edbd70facc47d944be5897e3",
151 "deff712f05a90d96edbd70facc47d944be5897e3",
152 "32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf",
152 "32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf",
153 "7e61ac704deecde634b51e59daa8110435dcb3da",
153 "7e61ac704deecde634b51e59daa8110435dcb3da",
154 ]
154 ]
155 @repository.changesets.each do |rev|
155 @repository.changesets.each do |rev|
156 rev.destroy if del_revs.detect {|r| r == rev.scmid.to_s }
156 rev.destroy if del_revs.detect {|r| r == rev.scmid.to_s }
157 end
157 end
158 @project.reload
158 @project.reload
159 cs1 = @repository.changesets
159 cs1 = @repository.changesets
160 assert_equal 15, cs1.count
160 assert_equal 15, cs1.count
161 h = @repository.extra_info.dup
161 h = @repository.extra_info.dup
162 h["branches"]["master"]["last_scmid"] =
162 h["branches"]["master"]["last_scmid"] =
163 "abcd1234efgh"
163 "abcd1234efgh"
164 @repository.merge_extra_info(h)
164 @repository.merge_extra_info(h)
165 @repository.save
165 @repository.save
166 @project.reload
166 @project.reload
167 extra_info_db_1 = @repository.extra_info["branches"]
167 extra_info_db_1 = @repository.extra_info["branches"]
168 assert_equal "abcd1234efgh",
168 assert_equal "abcd1234efgh",
169 extra_info_db_1["master"]["last_scmid"]
169 extra_info_db_1["master"]["last_scmid"]
170
170
171 @repository.fetch_changesets
171 @repository.fetch_changesets
172 @project.reload
172 @project.reload
173 assert_equal 15, @repository.changesets.count
173 assert_equal 15, @repository.changesets.count
174 end
174 end
175
175
176 def test_db_consistent_ordering_init
176 def test_db_consistent_ordering_init
177 assert_nil @repository.extra_info
177 assert_nil @repository.extra_info
178 assert_equal 0, @repository.changesets.count
178 @repository.fetch_changesets
179 @repository.fetch_changesets
179 @repository.reload
180 @project.reload
180 assert_equal 1, @repository.extra_info["db_consistent"]["ordering"]
181 assert_equal 1, @repository.extra_info["db_consistent"]["ordering"]
181 end
182 end
182
183
183 def test_db_consistent_ordering_before_1_2
184 def test_db_consistent_ordering_before_1_2
184 assert_nil @repository.extra_info
185 assert_nil @repository.extra_info
185 @repository.fetch_changesets
186 @repository.fetch_changesets
186 @repository.reload
187 @repository.reload
187 assert_equal 21, @repository.changesets.count
188 assert_equal 21, @repository.changesets.count
188 assert_not_nil @repository.extra_info
189 assert_not_nil @repository.extra_info
189 @repository.write_attribute(:extra_info, nil)
190 @repository.write_attribute(:extra_info, nil)
190 @repository.save
191 @repository.save
191 assert_nil @repository.extra_info
192 assert_nil @repository.extra_info
192 assert_equal 21, @repository.changesets.count
193 assert_equal 21, @repository.changesets.count
193 @repository.fetch_changesets
194 @repository.fetch_changesets
194 @repository.reload
195 @repository.reload
195 assert_equal 0, @repository.extra_info["db_consistent"]["ordering"]
196 assert_equal 0, @repository.extra_info["db_consistent"]["ordering"]
196
197
197 del_revs = [
198 del_revs = [
198 "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
199 "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
199 "ed5bb786bbda2dee66a2d50faf51429dbc043a7b",
200 "ed5bb786bbda2dee66a2d50faf51429dbc043a7b",
200 "4f26664364207fa8b1af9f8722647ab2d4ac5d43",
201 "4f26664364207fa8b1af9f8722647ab2d4ac5d43",
201 "deff712f05a90d96edbd70facc47d944be5897e3",
202 "deff712f05a90d96edbd70facc47d944be5897e3",
202 "32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf",
203 "32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf",
203 "7e61ac704deecde634b51e59daa8110435dcb3da",
204 "7e61ac704deecde634b51e59daa8110435dcb3da",
204 ]
205 ]
205 @repository.changesets.each do |rev|
206 @repository.changesets.each do |rev|
206 rev.destroy if del_revs.detect {|r| r == rev.scmid.to_s }
207 rev.destroy if del_revs.detect {|r| r == rev.scmid.to_s }
207 end
208 end
208 @repository.reload
209 @repository.reload
209 cs1 = @repository.changesets
210 cs1 = @repository.changesets
210 assert_equal 15, cs1.count
211 assert_equal 15, cs1.count
211 assert_equal 0, @repository.extra_info["db_consistent"]["ordering"]
212 assert_equal 0, @repository.extra_info["db_consistent"]["ordering"]
212 h = @repository.extra_info.dup
213 h = @repository.extra_info.dup
213 h["branches"]["master"]["last_scmid"] =
214 h["branches"]["master"]["last_scmid"] =
214 "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8"
215 "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8"
215 @repository.merge_extra_info(h)
216 @repository.merge_extra_info(h)
216 @repository.save
217 @repository.save
217 @repository.reload
218 @repository.reload
218 extra_info_db_1 = @repository.extra_info["branches"]
219 extra_info_db_1 = @repository.extra_info["branches"]
219 assert_equal "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8",
220 assert_equal "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8",
220 extra_info_db_1["master"]["last_scmid"]
221 extra_info_db_1["master"]["last_scmid"]
221
222
222 @repository.fetch_changesets
223 @repository.fetch_changesets
223 assert_equal 21, @repository.changesets.count
224 assert_equal 21, @repository.changesets.count
224 assert_equal 0, @repository.extra_info["db_consistent"]["ordering"]
225 assert_equal 0, @repository.extra_info["db_consistent"]["ordering"]
225 end
226 end
226
227
227 def test_latest_changesets
228 def test_latest_changesets
228 @repository.fetch_changesets
229 @repository.fetch_changesets
229 @repository.reload
230 @repository.reload
230 # with limit
231 # with limit
231 changesets = @repository.latest_changesets('', nil, 2)
232 changesets = @repository.latest_changesets('', nil, 2)
232 assert_equal 2, changesets.size
233 assert_equal 2, changesets.size
233
234
234 # with path
235 # with path
235 changesets = @repository.latest_changesets('images', nil)
236 changesets = @repository.latest_changesets('images', nil)
236 assert_equal [
237 assert_equal [
237 'deff712f05a90d96edbd70facc47d944be5897e3',
238 'deff712f05a90d96edbd70facc47d944be5897e3',
238 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
239 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
239 '7234cb2750b63f47bff735edc50a1c0a433c2518',
240 '7234cb2750b63f47bff735edc50a1c0a433c2518',
240 ], changesets.collect(&:revision)
241 ], changesets.collect(&:revision)
241
242
242 changesets = @repository.latest_changesets('README', nil)
243 changesets = @repository.latest_changesets('README', nil)
243 assert_equal [
244 assert_equal [
244 '32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf',
245 '32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf',
245 '4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8',
246 '4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8',
246 '713f4944648826f558cf548222f813dabe7cbb04',
247 '713f4944648826f558cf548222f813dabe7cbb04',
247 '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
248 '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
248 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
249 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
249 '7234cb2750b63f47bff735edc50a1c0a433c2518',
250 '7234cb2750b63f47bff735edc50a1c0a433c2518',
250 ], changesets.collect(&:revision)
251 ], changesets.collect(&:revision)
251
252
252 # with path, revision and limit
253 # with path, revision and limit
253 changesets = @repository.latest_changesets('images', '899a15dba')
254 changesets = @repository.latest_changesets('images', '899a15dba')
254 assert_equal [
255 assert_equal [
255 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
256 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
256 '7234cb2750b63f47bff735edc50a1c0a433c2518',
257 '7234cb2750b63f47bff735edc50a1c0a433c2518',
257 ], changesets.collect(&:revision)
258 ], changesets.collect(&:revision)
258
259
259 changesets = @repository.latest_changesets('images', '899a15dba', 1)
260 changesets = @repository.latest_changesets('images', '899a15dba', 1)
260 assert_equal [
261 assert_equal [
261 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
262 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
262 ], changesets.collect(&:revision)
263 ], changesets.collect(&:revision)
263
264
264 changesets = @repository.latest_changesets('README', '899a15dba')
265 changesets = @repository.latest_changesets('README', '899a15dba')
265 assert_equal [
266 assert_equal [
266 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
267 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
267 '7234cb2750b63f47bff735edc50a1c0a433c2518',
268 '7234cb2750b63f47bff735edc50a1c0a433c2518',
268 ], changesets.collect(&:revision)
269 ], changesets.collect(&:revision)
269
270
270 changesets = @repository.latest_changesets('README', '899a15dba', 1)
271 changesets = @repository.latest_changesets('README', '899a15dba', 1)
271 assert_equal [
272 assert_equal [
272 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
273 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
273 ], changesets.collect(&:revision)
274 ], changesets.collect(&:revision)
274
275
275 # with path, tag and limit
276 # with path, tag and limit
276 changesets = @repository.latest_changesets('images', 'tag01.annotated')
277 changesets = @repository.latest_changesets('images', 'tag01.annotated')
277 assert_equal [
278 assert_equal [
278 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
279 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
279 '7234cb2750b63f47bff735edc50a1c0a433c2518',
280 '7234cb2750b63f47bff735edc50a1c0a433c2518',
280 ], changesets.collect(&:revision)
281 ], changesets.collect(&:revision)
281
282
282 changesets = @repository.latest_changesets('images', 'tag01.annotated', 1)
283 changesets = @repository.latest_changesets('images', 'tag01.annotated', 1)
283 assert_equal [
284 assert_equal [
284 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
285 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
285 ], changesets.collect(&:revision)
286 ], changesets.collect(&:revision)
286
287
287 changesets = @repository.latest_changesets('README', 'tag01.annotated')
288 changesets = @repository.latest_changesets('README', 'tag01.annotated')
288 assert_equal [
289 assert_equal [
289 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
290 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
290 '7234cb2750b63f47bff735edc50a1c0a433c2518',
291 '7234cb2750b63f47bff735edc50a1c0a433c2518',
291 ], changesets.collect(&:revision)
292 ], changesets.collect(&:revision)
292
293
293 changesets = @repository.latest_changesets('README', 'tag01.annotated', 1)
294 changesets = @repository.latest_changesets('README', 'tag01.annotated', 1)
294 assert_equal [
295 assert_equal [
295 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
296 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
296 ], changesets.collect(&:revision)
297 ], changesets.collect(&:revision)
297
298
298 # with path, branch and limit
299 # with path, branch and limit
299 changesets = @repository.latest_changesets('images', 'test_branch')
300 changesets = @repository.latest_changesets('images', 'test_branch')
300 assert_equal [
301 assert_equal [
301 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
302 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
302 '7234cb2750b63f47bff735edc50a1c0a433c2518',
303 '7234cb2750b63f47bff735edc50a1c0a433c2518',
303 ], changesets.collect(&:revision)
304 ], changesets.collect(&:revision)
304
305
305 changesets = @repository.latest_changesets('images', 'test_branch', 1)
306 changesets = @repository.latest_changesets('images', 'test_branch', 1)
306 assert_equal [
307 assert_equal [
307 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
308 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
308 ], changesets.collect(&:revision)
309 ], changesets.collect(&:revision)
309
310
310 changesets = @repository.latest_changesets('README', 'test_branch')
311 changesets = @repository.latest_changesets('README', 'test_branch')
311 assert_equal [
312 assert_equal [
312 '713f4944648826f558cf548222f813dabe7cbb04',
313 '713f4944648826f558cf548222f813dabe7cbb04',
313 '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
314 '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
314 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
315 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
315 '7234cb2750b63f47bff735edc50a1c0a433c2518',
316 '7234cb2750b63f47bff735edc50a1c0a433c2518',
316 ], changesets.collect(&:revision)
317 ], changesets.collect(&:revision)
317
318
318 changesets = @repository.latest_changesets('README', 'test_branch', 2)
319 changesets = @repository.latest_changesets('README', 'test_branch', 2)
319 assert_equal [
320 assert_equal [
320 '713f4944648826f558cf548222f813dabe7cbb04',
321 '713f4944648826f558cf548222f813dabe7cbb04',
321 '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
322 '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
322 ], changesets.collect(&:revision)
323 ], changesets.collect(&:revision)
323
324
324 if JRUBY_SKIP
325 if JRUBY_SKIP
325 puts JRUBY_SKIP_STR
326 puts JRUBY_SKIP_STR
326 else
327 else
327 # latin-1 encoding path
328 # latin-1 encoding path
328 changesets = @repository.latest_changesets(
329 changesets = @repository.latest_changesets(
329 "latin-1-dir/test-#{@char_1}-2.txt", '64f1f3e89')
330 "latin-1-dir/test-#{@char_1}-2.txt", '64f1f3e89')
330 assert_equal [
331 assert_equal [
331 '64f1f3e89ad1cb57976ff0ad99a107012ba3481d',
332 '64f1f3e89ad1cb57976ff0ad99a107012ba3481d',
332 '4fc55c43bf3d3dc2efb66145365ddc17639ce81e',
333 '4fc55c43bf3d3dc2efb66145365ddc17639ce81e',
333 ], changesets.collect(&:revision)
334 ], changesets.collect(&:revision)
334
335
335 changesets = @repository.latest_changesets(
336 changesets = @repository.latest_changesets(
336 "latin-1-dir/test-#{@char_1}-2.txt", '64f1f3e89', 1)
337 "latin-1-dir/test-#{@char_1}-2.txt", '64f1f3e89', 1)
337 assert_equal [
338 assert_equal [
338 '64f1f3e89ad1cb57976ff0ad99a107012ba3481d',
339 '64f1f3e89ad1cb57976ff0ad99a107012ba3481d',
339 ], changesets.collect(&:revision)
340 ], changesets.collect(&:revision)
340 end
341 end
341 end
342 end
342
343
343 def test_latest_changesets_latin_1_dir
344 def test_latest_changesets_latin_1_dir
344 if WINDOWS_PASS
345 if WINDOWS_PASS
345 #
346 #
346 elsif JRUBY_SKIP
347 elsif JRUBY_SKIP
347 puts JRUBY_SKIP_STR
348 puts JRUBY_SKIP_STR
348 else
349 else
349 @repository.fetch_changesets
350 @repository.fetch_changesets
350 @repository.reload
351 @repository.reload
351 changesets = @repository.latest_changesets(
352 changesets = @repository.latest_changesets(
352 "latin-1-dir/test-#{@char_1}-subdir", '1ca7f5ed')
353 "latin-1-dir/test-#{@char_1}-subdir", '1ca7f5ed')
353 assert_equal [
354 assert_equal [
354 '1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127',
355 '1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127',
355 ], changesets.collect(&:revision)
356 ], changesets.collect(&:revision)
356 end
357 end
357 end
358 end
358
359
359 def test_find_changeset_by_name
360 def test_find_changeset_by_name
360 @repository.fetch_changesets
361 @repository.fetch_changesets
361 @repository.reload
362 @repository.reload
362 ['7234cb2750b63f47bff735edc50a1c0a433c2518', '7234cb2750b'].each do |r|
363 ['7234cb2750b63f47bff735edc50a1c0a433c2518', '7234cb2750b'].each do |r|
363 assert_equal '7234cb2750b63f47bff735edc50a1c0a433c2518',
364 assert_equal '7234cb2750b63f47bff735edc50a1c0a433c2518',
364 @repository.find_changeset_by_name(r).revision
365 @repository.find_changeset_by_name(r).revision
365 end
366 end
366 end
367 end
367
368
368 def test_find_changeset_by_empty_name
369 def test_find_changeset_by_empty_name
369 @repository.fetch_changesets
370 @repository.fetch_changesets
370 @repository.reload
371 @repository.reload
371 ['', ' ', nil].each do |r|
372 ['', ' ', nil].each do |r|
372 assert_nil @repository.find_changeset_by_name(r)
373 assert_nil @repository.find_changeset_by_name(r)
373 end
374 end
374 end
375 end
375
376
376 def test_identifier
377 def test_identifier
377 @repository.fetch_changesets
378 @repository.fetch_changesets
378 @repository.reload
379 @repository.reload
379 c = @repository.changesets.find_by_revision(
380 c = @repository.changesets.find_by_revision(
380 '7234cb2750b63f47bff735edc50a1c0a433c2518')
381 '7234cb2750b63f47bff735edc50a1c0a433c2518')
381 assert_equal c.scmid, c.identifier
382 assert_equal c.scmid, c.identifier
382 end
383 end
383
384
384 def test_format_identifier
385 def test_format_identifier
385 @repository.fetch_changesets
386 @repository.fetch_changesets
386 @repository.reload
387 @repository.reload
387 c = @repository.changesets.find_by_revision(
388 c = @repository.changesets.find_by_revision(
388 '7234cb2750b63f47bff735edc50a1c0a433c2518')
389 '7234cb2750b63f47bff735edc50a1c0a433c2518')
389 assert_equal '7234cb27', c.format_identifier
390 assert_equal '7234cb27', c.format_identifier
390 end
391 end
391
392
392 def test_activities
393 def test_activities
393 c = Changeset.new(:repository => @repository,
394 c = Changeset.new(:repository => @repository,
394 :committed_on => Time.now,
395 :committed_on => Time.now,
395 :revision => 'abc7234cb2750b63f47bff735edc50a1c0a433c2',
396 :revision => 'abc7234cb2750b63f47bff735edc50a1c0a433c2',
396 :scmid => 'abc7234cb2750b63f47bff735edc50a1c0a433c2',
397 :scmid => 'abc7234cb2750b63f47bff735edc50a1c0a433c2',
397 :comments => 'test')
398 :comments => 'test')
398 assert c.event_title.include?('abc7234c:')
399 assert c.event_title.include?('abc7234c:')
399 assert_equal 'abc7234cb2750b63f47bff735edc50a1c0a433c2', c.event_url[:rev]
400 assert_equal 'abc7234cb2750b63f47bff735edc50a1c0a433c2', c.event_url[:rev]
400 end
401 end
401
402
402 def test_log_utf8
403 def test_log_utf8
403 @repository.fetch_changesets
404 @repository.fetch_changesets
404 @repository.reload
405 @repository.reload
405 str_felix_hex = FELIX_HEX.dup
406 str_felix_hex = FELIX_HEX.dup
406 if str_felix_hex.respond_to?(:force_encoding)
407 if str_felix_hex.respond_to?(:force_encoding)
407 str_felix_hex.force_encoding('UTF-8')
408 str_felix_hex.force_encoding('UTF-8')
408 end
409 end
409 c = @repository.changesets.find_by_revision(
410 c = @repository.changesets.find_by_revision(
410 'ed5bb786bbda2dee66a2d50faf51429dbc043a7b')
411 'ed5bb786bbda2dee66a2d50faf51429dbc043a7b')
411 assert_equal "#{str_felix_hex} <felix@fachschaften.org>", c.committer
412 assert_equal "#{str_felix_hex} <felix@fachschaften.org>", c.committer
412 end
413 end
413
414
414 def test_previous
415 def test_previous
415 @repository.fetch_changesets
416 @repository.fetch_changesets
416 @repository.reload
417 @repository.reload
417 %w|1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127 1ca7f5ed|.each do |r1|
418 %w|1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127 1ca7f5ed|.each do |r1|
418 changeset = @repository.find_changeset_by_name(r1)
419 changeset = @repository.find_changeset_by_name(r1)
419 %w|64f1f3e89ad1cb57976ff0ad99a107012ba3481d 64f1f3e89ad1|.each do |r2|
420 %w|64f1f3e89ad1cb57976ff0ad99a107012ba3481d 64f1f3e89ad1|.each do |r2|
420 assert_equal @repository.find_changeset_by_name(r2), changeset.previous
421 assert_equal @repository.find_changeset_by_name(r2), changeset.previous
421 end
422 end
422 end
423 end
423 end
424 end
424
425
425 def test_previous_nil
426 def test_previous_nil
426 @repository.fetch_changesets
427 @repository.fetch_changesets
427 @repository.reload
428 @repository.reload
428 %w|7234cb2750b63f47bff735edc50a1c0a433c2518 7234cb2|.each do |r1|
429 %w|7234cb2750b63f47bff735edc50a1c0a433c2518 7234cb2|.each do |r1|
429 changeset = @repository.find_changeset_by_name(r1)
430 changeset = @repository.find_changeset_by_name(r1)
430 assert_nil changeset.previous
431 assert_nil changeset.previous
431 end
432 end
432 end
433 end
433
434
434 def test_next
435 def test_next
435 @repository.fetch_changesets
436 @repository.fetch_changesets
436 @repository.reload
437 @repository.reload
437 %w|64f1f3e89ad1cb57976ff0ad99a107012ba3481d 64f1f3e89ad1|.each do |r2|
438 %w|64f1f3e89ad1cb57976ff0ad99a107012ba3481d 64f1f3e89ad1|.each do |r2|
438 changeset = @repository.find_changeset_by_name(r2)
439 changeset = @repository.find_changeset_by_name(r2)
439 %w|1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127 1ca7f5ed|.each do |r1|
440 %w|1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127 1ca7f5ed|.each do |r1|
440 assert_equal @repository.find_changeset_by_name(r1), changeset.next
441 assert_equal @repository.find_changeset_by_name(r1), changeset.next
441 end
442 end
442 end
443 end
443 end
444 end
444
445
445 def test_next_nil
446 def test_next_nil
446 @repository.fetch_changesets
447 @repository.fetch_changesets
447 @repository.reload
448 @repository.reload
448 %w|67e7792ce20ccae2e4bb73eed09bb397819c8834 67e7792ce20cca|.each do |r1|
449 %w|67e7792ce20ccae2e4bb73eed09bb397819c8834 67e7792ce20cca|.each do |r1|
449 changeset = @repository.find_changeset_by_name(r1)
450 changeset = @repository.find_changeset_by_name(r1)
450 assert_nil changeset.next
451 assert_nil changeset.next
451 end
452 end
452 end
453 end
453 else
454 else
454 puts "Git test repository NOT FOUND. Skipping unit tests !!!"
455 puts "Git test repository NOT FOUND. Skipping unit tests !!!"
455 def test_fake; assert true end
456 def test_fake; assert true end
456 end
457 end
457 end
458 end
General Comments 0
You need to be logged in to leave comments. Login now