##// END OF EJS Templates
Rails3: scm: git: fix error of test_db_consistent_ordering_before_1_2 at unit model test...
Toshi MARUYAMA -
r6952:56ef96081b49
parent child
Show More
@@ -1,458 +1,459
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 assert_equal 0, @repository.changesets.count
179 @repository.fetch_changesets
179 @repository.fetch_changesets
180 @project.reload
180 @project.reload
181 assert_equal 1, @repository.extra_info["db_consistent"]["ordering"]
181 assert_equal 1, @repository.extra_info["db_consistent"]["ordering"]
182 end
182 end
183
183
184 def test_db_consistent_ordering_before_1_2
184 def test_db_consistent_ordering_before_1_2
185 assert_nil @repository.extra_info
185 assert_nil @repository.extra_info
186 assert_equal 0, @repository.changesets.count
186 @repository.fetch_changesets
187 @repository.fetch_changesets
187 @repository.reload
188 @project.reload
188 assert_equal 21, @repository.changesets.count
189 assert_equal NUM_REV, @repository.changesets.count
189 assert_not_nil @repository.extra_info
190 assert_not_nil @repository.extra_info
190 @repository.write_attribute(:extra_info, nil)
191 @repository.write_attribute(:extra_info, nil)
191 @repository.save
192 @repository.save
192 assert_nil @repository.extra_info
193 assert_nil @repository.extra_info
193 assert_equal 21, @repository.changesets.count
194 assert_equal NUM_REV, @repository.changesets.count
194 @repository.fetch_changesets
195 @repository.fetch_changesets
195 @repository.reload
196 @project.reload
196 assert_equal 0, @repository.extra_info["db_consistent"]["ordering"]
197 assert_equal 0, @repository.extra_info["db_consistent"]["ordering"]
197
198
198 del_revs = [
199 del_revs = [
199 "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
200 "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
200 "ed5bb786bbda2dee66a2d50faf51429dbc043a7b",
201 "ed5bb786bbda2dee66a2d50faf51429dbc043a7b",
201 "4f26664364207fa8b1af9f8722647ab2d4ac5d43",
202 "4f26664364207fa8b1af9f8722647ab2d4ac5d43",
202 "deff712f05a90d96edbd70facc47d944be5897e3",
203 "deff712f05a90d96edbd70facc47d944be5897e3",
203 "32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf",
204 "32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf",
204 "7e61ac704deecde634b51e59daa8110435dcb3da",
205 "7e61ac704deecde634b51e59daa8110435dcb3da",
205 ]
206 ]
206 @repository.changesets.each do |rev|
207 @repository.changesets.each do |rev|
207 rev.destroy if del_revs.detect {|r| r == rev.scmid.to_s }
208 rev.destroy if del_revs.detect {|r| r == rev.scmid.to_s }
208 end
209 end
209 @repository.reload
210 @repository.reload
210 cs1 = @repository.changesets
211 cs1 = @repository.changesets
211 assert_equal 15, cs1.count
212 assert_equal 15, cs1.count
212 assert_equal 0, @repository.extra_info["db_consistent"]["ordering"]
213 assert_equal 0, @repository.extra_info["db_consistent"]["ordering"]
213 h = @repository.extra_info.dup
214 h = @repository.extra_info.dup
214 h["branches"]["master"]["last_scmid"] =
215 h["branches"]["master"]["last_scmid"] =
215 "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8"
216 "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8"
216 @repository.merge_extra_info(h)
217 @repository.merge_extra_info(h)
217 @repository.save
218 @repository.save
218 @repository.reload
219 @project.reload
219 extra_info_db_1 = @repository.extra_info["branches"]
220 extra_info_db_1 = @repository.extra_info["branches"]
220 assert_equal "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8",
221 assert_equal "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8",
221 extra_info_db_1["master"]["last_scmid"]
222 extra_info_db_1["master"]["last_scmid"]
222
223
223 @repository.fetch_changesets
224 @repository.fetch_changesets
224 assert_equal 21, @repository.changesets.count
225 assert_equal NUM_REV, @repository.changesets.count
225 assert_equal 0, @repository.extra_info["db_consistent"]["ordering"]
226 assert_equal 0, @repository.extra_info["db_consistent"]["ordering"]
226 end
227 end
227
228
228 def test_latest_changesets
229 def test_latest_changesets
229 @repository.fetch_changesets
230 @repository.fetch_changesets
230 @repository.reload
231 @repository.reload
231 # with limit
232 # with limit
232 changesets = @repository.latest_changesets('', nil, 2)
233 changesets = @repository.latest_changesets('', nil, 2)
233 assert_equal 2, changesets.size
234 assert_equal 2, changesets.size
234
235
235 # with path
236 # with path
236 changesets = @repository.latest_changesets('images', nil)
237 changesets = @repository.latest_changesets('images', nil)
237 assert_equal [
238 assert_equal [
238 'deff712f05a90d96edbd70facc47d944be5897e3',
239 'deff712f05a90d96edbd70facc47d944be5897e3',
239 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
240 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
240 '7234cb2750b63f47bff735edc50a1c0a433c2518',
241 '7234cb2750b63f47bff735edc50a1c0a433c2518',
241 ], changesets.collect(&:revision)
242 ], changesets.collect(&:revision)
242
243
243 changesets = @repository.latest_changesets('README', nil)
244 changesets = @repository.latest_changesets('README', nil)
244 assert_equal [
245 assert_equal [
245 '32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf',
246 '32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf',
246 '4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8',
247 '4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8',
247 '713f4944648826f558cf548222f813dabe7cbb04',
248 '713f4944648826f558cf548222f813dabe7cbb04',
248 '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
249 '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
249 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
250 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
250 '7234cb2750b63f47bff735edc50a1c0a433c2518',
251 '7234cb2750b63f47bff735edc50a1c0a433c2518',
251 ], changesets.collect(&:revision)
252 ], changesets.collect(&:revision)
252
253
253 # with path, revision and limit
254 # with path, revision and limit
254 changesets = @repository.latest_changesets('images', '899a15dba')
255 changesets = @repository.latest_changesets('images', '899a15dba')
255 assert_equal [
256 assert_equal [
256 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
257 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
257 '7234cb2750b63f47bff735edc50a1c0a433c2518',
258 '7234cb2750b63f47bff735edc50a1c0a433c2518',
258 ], changesets.collect(&:revision)
259 ], changesets.collect(&:revision)
259
260
260 changesets = @repository.latest_changesets('images', '899a15dba', 1)
261 changesets = @repository.latest_changesets('images', '899a15dba', 1)
261 assert_equal [
262 assert_equal [
262 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
263 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
263 ], changesets.collect(&:revision)
264 ], changesets.collect(&:revision)
264
265
265 changesets = @repository.latest_changesets('README', '899a15dba')
266 changesets = @repository.latest_changesets('README', '899a15dba')
266 assert_equal [
267 assert_equal [
267 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
268 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
268 '7234cb2750b63f47bff735edc50a1c0a433c2518',
269 '7234cb2750b63f47bff735edc50a1c0a433c2518',
269 ], changesets.collect(&:revision)
270 ], changesets.collect(&:revision)
270
271
271 changesets = @repository.latest_changesets('README', '899a15dba', 1)
272 changesets = @repository.latest_changesets('README', '899a15dba', 1)
272 assert_equal [
273 assert_equal [
273 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
274 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
274 ], changesets.collect(&:revision)
275 ], changesets.collect(&:revision)
275
276
276 # with path, tag and limit
277 # with path, tag and limit
277 changesets = @repository.latest_changesets('images', 'tag01.annotated')
278 changesets = @repository.latest_changesets('images', 'tag01.annotated')
278 assert_equal [
279 assert_equal [
279 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
280 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
280 '7234cb2750b63f47bff735edc50a1c0a433c2518',
281 '7234cb2750b63f47bff735edc50a1c0a433c2518',
281 ], changesets.collect(&:revision)
282 ], changesets.collect(&:revision)
282
283
283 changesets = @repository.latest_changesets('images', 'tag01.annotated', 1)
284 changesets = @repository.latest_changesets('images', 'tag01.annotated', 1)
284 assert_equal [
285 assert_equal [
285 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
286 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
286 ], changesets.collect(&:revision)
287 ], changesets.collect(&:revision)
287
288
288 changesets = @repository.latest_changesets('README', 'tag01.annotated')
289 changesets = @repository.latest_changesets('README', 'tag01.annotated')
289 assert_equal [
290 assert_equal [
290 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
291 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
291 '7234cb2750b63f47bff735edc50a1c0a433c2518',
292 '7234cb2750b63f47bff735edc50a1c0a433c2518',
292 ], changesets.collect(&:revision)
293 ], changesets.collect(&:revision)
293
294
294 changesets = @repository.latest_changesets('README', 'tag01.annotated', 1)
295 changesets = @repository.latest_changesets('README', 'tag01.annotated', 1)
295 assert_equal [
296 assert_equal [
296 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
297 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
297 ], changesets.collect(&:revision)
298 ], changesets.collect(&:revision)
298
299
299 # with path, branch and limit
300 # with path, branch and limit
300 changesets = @repository.latest_changesets('images', 'test_branch')
301 changesets = @repository.latest_changesets('images', 'test_branch')
301 assert_equal [
302 assert_equal [
302 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
303 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
303 '7234cb2750b63f47bff735edc50a1c0a433c2518',
304 '7234cb2750b63f47bff735edc50a1c0a433c2518',
304 ], changesets.collect(&:revision)
305 ], changesets.collect(&:revision)
305
306
306 changesets = @repository.latest_changesets('images', 'test_branch', 1)
307 changesets = @repository.latest_changesets('images', 'test_branch', 1)
307 assert_equal [
308 assert_equal [
308 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
309 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
309 ], changesets.collect(&:revision)
310 ], changesets.collect(&:revision)
310
311
311 changesets = @repository.latest_changesets('README', 'test_branch')
312 changesets = @repository.latest_changesets('README', 'test_branch')
312 assert_equal [
313 assert_equal [
313 '713f4944648826f558cf548222f813dabe7cbb04',
314 '713f4944648826f558cf548222f813dabe7cbb04',
314 '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
315 '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
315 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
316 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
316 '7234cb2750b63f47bff735edc50a1c0a433c2518',
317 '7234cb2750b63f47bff735edc50a1c0a433c2518',
317 ], changesets.collect(&:revision)
318 ], changesets.collect(&:revision)
318
319
319 changesets = @repository.latest_changesets('README', 'test_branch', 2)
320 changesets = @repository.latest_changesets('README', 'test_branch', 2)
320 assert_equal [
321 assert_equal [
321 '713f4944648826f558cf548222f813dabe7cbb04',
322 '713f4944648826f558cf548222f813dabe7cbb04',
322 '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
323 '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
323 ], changesets.collect(&:revision)
324 ], changesets.collect(&:revision)
324
325
325 if JRUBY_SKIP
326 if JRUBY_SKIP
326 puts JRUBY_SKIP_STR
327 puts JRUBY_SKIP_STR
327 else
328 else
328 # latin-1 encoding path
329 # latin-1 encoding path
329 changesets = @repository.latest_changesets(
330 changesets = @repository.latest_changesets(
330 "latin-1-dir/test-#{@char_1}-2.txt", '64f1f3e89')
331 "latin-1-dir/test-#{@char_1}-2.txt", '64f1f3e89')
331 assert_equal [
332 assert_equal [
332 '64f1f3e89ad1cb57976ff0ad99a107012ba3481d',
333 '64f1f3e89ad1cb57976ff0ad99a107012ba3481d',
333 '4fc55c43bf3d3dc2efb66145365ddc17639ce81e',
334 '4fc55c43bf3d3dc2efb66145365ddc17639ce81e',
334 ], changesets.collect(&:revision)
335 ], changesets.collect(&:revision)
335
336
336 changesets = @repository.latest_changesets(
337 changesets = @repository.latest_changesets(
337 "latin-1-dir/test-#{@char_1}-2.txt", '64f1f3e89', 1)
338 "latin-1-dir/test-#{@char_1}-2.txt", '64f1f3e89', 1)
338 assert_equal [
339 assert_equal [
339 '64f1f3e89ad1cb57976ff0ad99a107012ba3481d',
340 '64f1f3e89ad1cb57976ff0ad99a107012ba3481d',
340 ], changesets.collect(&:revision)
341 ], changesets.collect(&:revision)
341 end
342 end
342 end
343 end
343
344
344 def test_latest_changesets_latin_1_dir
345 def test_latest_changesets_latin_1_dir
345 if WINDOWS_PASS
346 if WINDOWS_PASS
346 #
347 #
347 elsif JRUBY_SKIP
348 elsif JRUBY_SKIP
348 puts JRUBY_SKIP_STR
349 puts JRUBY_SKIP_STR
349 else
350 else
350 @repository.fetch_changesets
351 @repository.fetch_changesets
351 @repository.reload
352 @repository.reload
352 changesets = @repository.latest_changesets(
353 changesets = @repository.latest_changesets(
353 "latin-1-dir/test-#{@char_1}-subdir", '1ca7f5ed')
354 "latin-1-dir/test-#{@char_1}-subdir", '1ca7f5ed')
354 assert_equal [
355 assert_equal [
355 '1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127',
356 '1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127',
356 ], changesets.collect(&:revision)
357 ], changesets.collect(&:revision)
357 end
358 end
358 end
359 end
359
360
360 def test_find_changeset_by_name
361 def test_find_changeset_by_name
361 @repository.fetch_changesets
362 @repository.fetch_changesets
362 @repository.reload
363 @repository.reload
363 ['7234cb2750b63f47bff735edc50a1c0a433c2518', '7234cb2750b'].each do |r|
364 ['7234cb2750b63f47bff735edc50a1c0a433c2518', '7234cb2750b'].each do |r|
364 assert_equal '7234cb2750b63f47bff735edc50a1c0a433c2518',
365 assert_equal '7234cb2750b63f47bff735edc50a1c0a433c2518',
365 @repository.find_changeset_by_name(r).revision
366 @repository.find_changeset_by_name(r).revision
366 end
367 end
367 end
368 end
368
369
369 def test_find_changeset_by_empty_name
370 def test_find_changeset_by_empty_name
370 @repository.fetch_changesets
371 @repository.fetch_changesets
371 @repository.reload
372 @repository.reload
372 ['', ' ', nil].each do |r|
373 ['', ' ', nil].each do |r|
373 assert_nil @repository.find_changeset_by_name(r)
374 assert_nil @repository.find_changeset_by_name(r)
374 end
375 end
375 end
376 end
376
377
377 def test_identifier
378 def test_identifier
378 @repository.fetch_changesets
379 @repository.fetch_changesets
379 @repository.reload
380 @repository.reload
380 c = @repository.changesets.find_by_revision(
381 c = @repository.changesets.find_by_revision(
381 '7234cb2750b63f47bff735edc50a1c0a433c2518')
382 '7234cb2750b63f47bff735edc50a1c0a433c2518')
382 assert_equal c.scmid, c.identifier
383 assert_equal c.scmid, c.identifier
383 end
384 end
384
385
385 def test_format_identifier
386 def test_format_identifier
386 @repository.fetch_changesets
387 @repository.fetch_changesets
387 @repository.reload
388 @repository.reload
388 c = @repository.changesets.find_by_revision(
389 c = @repository.changesets.find_by_revision(
389 '7234cb2750b63f47bff735edc50a1c0a433c2518')
390 '7234cb2750b63f47bff735edc50a1c0a433c2518')
390 assert_equal '7234cb27', c.format_identifier
391 assert_equal '7234cb27', c.format_identifier
391 end
392 end
392
393
393 def test_activities
394 def test_activities
394 c = Changeset.new(:repository => @repository,
395 c = Changeset.new(:repository => @repository,
395 :committed_on => Time.now,
396 :committed_on => Time.now,
396 :revision => 'abc7234cb2750b63f47bff735edc50a1c0a433c2',
397 :revision => 'abc7234cb2750b63f47bff735edc50a1c0a433c2',
397 :scmid => 'abc7234cb2750b63f47bff735edc50a1c0a433c2',
398 :scmid => 'abc7234cb2750b63f47bff735edc50a1c0a433c2',
398 :comments => 'test')
399 :comments => 'test')
399 assert c.event_title.include?('abc7234c:')
400 assert c.event_title.include?('abc7234c:')
400 assert_equal 'abc7234cb2750b63f47bff735edc50a1c0a433c2', c.event_url[:rev]
401 assert_equal 'abc7234cb2750b63f47bff735edc50a1c0a433c2', c.event_url[:rev]
401 end
402 end
402
403
403 def test_log_utf8
404 def test_log_utf8
404 @repository.fetch_changesets
405 @repository.fetch_changesets
405 @repository.reload
406 @repository.reload
406 str_felix_hex = FELIX_HEX.dup
407 str_felix_hex = FELIX_HEX.dup
407 if str_felix_hex.respond_to?(:force_encoding)
408 if str_felix_hex.respond_to?(:force_encoding)
408 str_felix_hex.force_encoding('UTF-8')
409 str_felix_hex.force_encoding('UTF-8')
409 end
410 end
410 c = @repository.changesets.find_by_revision(
411 c = @repository.changesets.find_by_revision(
411 'ed5bb786bbda2dee66a2d50faf51429dbc043a7b')
412 'ed5bb786bbda2dee66a2d50faf51429dbc043a7b')
412 assert_equal "#{str_felix_hex} <felix@fachschaften.org>", c.committer
413 assert_equal "#{str_felix_hex} <felix@fachschaften.org>", c.committer
413 end
414 end
414
415
415 def test_previous
416 def test_previous
416 @repository.fetch_changesets
417 @repository.fetch_changesets
417 @repository.reload
418 @repository.reload
418 %w|1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127 1ca7f5ed|.each do |r1|
419 %w|1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127 1ca7f5ed|.each do |r1|
419 changeset = @repository.find_changeset_by_name(r1)
420 changeset = @repository.find_changeset_by_name(r1)
420 %w|64f1f3e89ad1cb57976ff0ad99a107012ba3481d 64f1f3e89ad1|.each do |r2|
421 %w|64f1f3e89ad1cb57976ff0ad99a107012ba3481d 64f1f3e89ad1|.each do |r2|
421 assert_equal @repository.find_changeset_by_name(r2), changeset.previous
422 assert_equal @repository.find_changeset_by_name(r2), changeset.previous
422 end
423 end
423 end
424 end
424 end
425 end
425
426
426 def test_previous_nil
427 def test_previous_nil
427 @repository.fetch_changesets
428 @repository.fetch_changesets
428 @repository.reload
429 @repository.reload
429 %w|7234cb2750b63f47bff735edc50a1c0a433c2518 7234cb2|.each do |r1|
430 %w|7234cb2750b63f47bff735edc50a1c0a433c2518 7234cb2|.each do |r1|
430 changeset = @repository.find_changeset_by_name(r1)
431 changeset = @repository.find_changeset_by_name(r1)
431 assert_nil changeset.previous
432 assert_nil changeset.previous
432 end
433 end
433 end
434 end
434
435
435 def test_next
436 def test_next
436 @repository.fetch_changesets
437 @repository.fetch_changesets
437 @repository.reload
438 @repository.reload
438 %w|64f1f3e89ad1cb57976ff0ad99a107012ba3481d 64f1f3e89ad1|.each do |r2|
439 %w|64f1f3e89ad1cb57976ff0ad99a107012ba3481d 64f1f3e89ad1|.each do |r2|
439 changeset = @repository.find_changeset_by_name(r2)
440 changeset = @repository.find_changeset_by_name(r2)
440 %w|1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127 1ca7f5ed|.each do |r1|
441 %w|1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127 1ca7f5ed|.each do |r1|
441 assert_equal @repository.find_changeset_by_name(r1), changeset.next
442 assert_equal @repository.find_changeset_by_name(r1), changeset.next
442 end
443 end
443 end
444 end
444 end
445 end
445
446
446 def test_next_nil
447 def test_next_nil
447 @repository.fetch_changesets
448 @repository.fetch_changesets
448 @repository.reload
449 @repository.reload
449 %w|67e7792ce20ccae2e4bb73eed09bb397819c8834 67e7792ce20cca|.each do |r1|
450 %w|67e7792ce20ccae2e4bb73eed09bb397819c8834 67e7792ce20cca|.each do |r1|
450 changeset = @repository.find_changeset_by_name(r1)
451 changeset = @repository.find_changeset_by_name(r1)
451 assert_nil changeset.next
452 assert_nil changeset.next
452 end
453 end
453 end
454 end
454 else
455 else
455 puts "Git test repository NOT FOUND. Skipping unit tests !!!"
456 puts "Git test repository NOT FOUND. Skipping unit tests !!!"
456 def test_fake; assert true end
457 def test_fake; assert true end
457 end
458 end
458 end
459 end
General Comments 0
You need to be logged in to leave comments. Login now