Commit 7e00c87cbb6a87241fce4b75cba74c3bd9675882

Authored by Braulio Bhavamitra
1 parent 0e75f1c2

rails4: fix integration tests

lib/authenticated_test_helper.rb
@@ -1,98 +0,0 @@ @@ -1,98 +0,0 @@
1 -module AuthenticatedTestHelper  
2 - # Sets the current user in the session from the user fixtures.  
3 - def login_as(user)  
4 - @request.session[:user] = User.find_by_login(user.to_s).id  
5 - end  
6 -  
7 - def logout  
8 - @request.session.delete(:user)  
9 - end  
10 -  
11 - def content_type(type)  
12 - @request.env['Content-Type'] = type  
13 - end  
14 -  
15 - def accept(accept)  
16 - @request.env["HTTP_ACCEPT"] = accept  
17 - end  
18 -  
19 - def authorize_as(user)  
20 - if user  
21 - @request.env["HTTP_AUTHORIZATION"] = "Basic #{Base64.encode64("#{users(user).login}:test")}"  
22 - accept 'application/xml'  
23 - content_type 'application/xml'  
24 - else  
25 - @request.env["HTTP_AUTHORIZATION"] = nil  
26 - accept nil  
27 - content_type nil  
28 - end  
29 - end  
30 -  
31 - # Assert the block redirects to the login  
32 - #  
33 - # assert_requires_login(:bob) { |c| c.get :edit, :id => 1 }  
34 - #  
35 - def assert_requires_login(login = nil)  
36 - yield HttpLoginProxy.new(self, login)  
37 - end  
38 -  
39 - def assert_http_authentication_required(login = nil)  
40 - yield XmlLoginProxy.new(self, login)  
41 - end  
42 -  
43 - def reset!(*instance_vars)  
44 - instance_vars = [:controller, :request, :response] unless instance_vars.any?  
45 - instance_vars.collect! { |v| "@#{v}".to_sym }  
46 - instance_vars.each do |var|  
47 - instance_variable_set(var, instance_variable_get(var).class.new)  
48 - end  
49 - end  
50 -end  
51 -  
52 -class BaseLoginProxy  
53 - attr_reader :controller  
54 - attr_reader :options  
55 - def initialize(controller, login)  
56 - @controller = controller  
57 - @login = login  
58 - end  
59 -  
60 - private  
61 - def authenticated  
62 - raise NotImplementedError  
63 - end  
64 -  
65 - def check  
66 - raise NotImplementedError  
67 - end  
68 -  
69 - def method_missing(method, *args)  
70 - @controller.reset!  
71 - authenticate  
72 - @controller.send(method, *args)  
73 - check  
74 - end  
75 -end  
76 -  
77 -class HttpLoginProxy < BaseLoginProxy  
78 - protected  
79 - def authenticate  
80 - @controller.login_as @login if @login  
81 - end  
82 -  
83 - def check  
84 - @controller.assert_redirected_to :controller => 'account', :action => 'login'  
85 - end  
86 -end  
87 -  
88 -class XmlLoginProxy < BaseLoginProxy  
89 - protected  
90 - def authenticate  
91 - @controller.accept 'application/xml'  
92 - @controller.authorize_as @login if @login  
93 - end  
94 -  
95 - def check  
96 - @controller.assert_response 401  
97 - end  
98 -end  
plugins/sniffer/test/integration/sniffer_map_test.rb
1 require "#{File.dirname(__FILE__)}/../../../../test/test_helper" 1 require "#{File.dirname(__FILE__)}/../../../../test/test_helper"
2 2
3 -class SnifferMapTest < ActionController::IntegrationTest 3 +class SnifferMapTest < ActionDispatch::IntegrationTest
4 4
5 fixtures :users, :profiles 5 fixtures :users, :profiles
6 6
test/action_tracker_test_helper.rb
@@ -1,16 +0,0 @@ @@ -1,16 +0,0 @@
1 -class UserStampSweeper < ActionController::Caching::Sweeper  
2 - private  
3 - def current_user  
4 - Person.first  
5 - end  
6 -end  
7 -  
8 -module ActionTracker  
9 - class Record  
10 - def back_in_time(time = 25.hours)  
11 - self.updated_at = Time.now.ago(time)  
12 - self.send :update_without_callbacks  
13 - self  
14 - end  
15 - end  
16 -end  
test/factories.rb
@@ -1,496 +0,0 @@ @@ -1,496 +0,0 @@
1 -module Noosfero::Factory  
2 -  
3 - def fast_create(name, attrs = {}, options = {})  
4 - defaults = defaults_for(name)  
5 - attrs[:slug] = attrs[:name].to_slug if attrs[:name].present? && attrs[:slug].blank? && defaults[:slug].present?  
6 - data = defaults_for(name.to_s.gsub('::','')).merge(attrs)  
7 - klass = name.to_s.camelize.constantize  
8 - if klass.superclass != ActiveRecord::Base  
9 - data[:type] = klass.to_s  
10 - end  
11 - if options[:timestamps]  
12 - fast_insert_with_timestamps(klass, data)  
13 - else  
14 - fast_insert(klass, data)  
15 - end  
16 - obj = klass.last(:order => "id")  
17 - if options[:category]  
18 - categories = options[:category]  
19 - unless categories.is_a?(Array)  
20 - categories = [categories]  
21 - end  
22 - categories.each do |category|  
23 - obj.add_category(category)  
24 - end  
25 - end  
26 - obj  
27 - end  
28 -  
29 - def create(name, attrs = {})  
30 - target = 'create_' + name.to_s  
31 - if respond_to?(target)  
32 - send(target, attrs)  
33 - else  
34 - obj = build name  
35 - attrs.each{ |a, v| obj.send "#{a}=", v }  
36 - obj.save!  
37 - obj  
38 - end  
39 - end  
40 -  
41 - def build(name, attrs = {})  
42 - defaults = defaults_for(name)  
43 - attrs[:slug] = attrs[:name].to_slug if attrs[:name].present? && attrs[:slug].blank? && defaults[:slug].present?  
44 - data = defaults_for(name).merge(attrs)  
45 - object = name.to_s.camelize.constantize.new  
46 - if object.respond_to?(:assign_attributes)  
47 - object.assign_attributes(data, :without_protection => true)  
48 - else  
49 - data.each { |attribute, value| object.send(attribute.to_s+'=', value) }  
50 - end  
51 - object  
52 - end  
53 -  
54 - def defaults_for(name)  
55 - send('defaults_for_' + name.to_s.underscore)  
56 - rescue  
57 - {}  
58 - end  
59 -  
60 - def self.num_seq  
61 - @num_seq ||= 0  
62 - @num_seq += 1  
63 - @num_seq  
64 - end  
65 -  
66 - ###### old stuff to be rearranged  
67 - def create_admin_user(env)  
68 - admin_user = User.find_by_login('adminuser') || create_user('adminuser', :email => 'adminuser@noosfero.org', :password => 'adminuser', :password_confirmation => 'adminuser', :environment => env)  
69 - admin_role = Role.find_by_name('admin_role') || Role.create!(:name => 'admin_role', :permissions => ['view_environment_admin_panel','edit_environment_features', 'edit_environment_design', 'manage_environment_categories', 'manage_environment_roles', 'manage_environment_trusted_sites', 'manage_environment_validators', 'manage_environment_users', 'manage_environment_organizations', 'manage_environment_templates', 'manage_environment_licenses', 'edit_appearance'])  
70 - create(RoleAssignment, :accessor => admin_user.person, :role => admin_role, :resource => env) unless admin_user.person.role_assignments.map{|ra|[ra.role, ra.accessor, ra.resource]}.include?([admin_role, admin_user, env])  
71 - admin_user.login  
72 - end  
73 -  
74 - def create_environment(domainname)  
75 - environment = fast_create(Environment)  
76 - fast_create(Domain, :name => domainname, :owner_type => 'Environment', :owner_id => environment.id)  
77 - environment  
78 - end  
79 -  
80 - # Old version of create user. Use it if you need to create an user for  
81 - # testing that passes through the actual user creation process.  
82 - #  
83 - # Be aware that this is slow, though.  
84 - def create_user_full(name = nil, options = {}, person_options = {})  
85 - name ||= 'user' + factory_num_seq.to_s  
86 - data = {  
87 - :login => name,  
88 - :email => name + '@noosfero.org',  
89 - :password => name.underscore,  
90 - :password_confirmation => name.underscore  
91 - }.merge(options)  
92 - user = build(User, data)  
93 - user.person_data = person_options  
94 - user.save!  
95 - user  
96 - end  
97 -  
98 - def person_data  
99 - {}  
100 - end  
101 -  
102 - # This method knows way too much about the model. But since creating an  
103 - # actual user is really expensive, for tests we need a fast alternative.  
104 - def create_user(name = nil, options = {}, person_options = {})  
105 - name ||= 'user' + factory_num_seq.to_s  
106 - environment_id = options.delete(:environment_id) || (options.delete(:environment) || Environment.default).id  
107 -  
108 - password = options.delete(:password)  
109 - password_confirmation = options.delete(:password_confirmation)  
110 - raise build(Exception, "Passwords don't match") if (password && password_confirmation && password != password_confirmation)  
111 - crypted_password = (password || name).crypt('xy')  
112 -  
113 - data = {  
114 - :login => name,  
115 - :email => name + '@noosfero.org',  
116 - :crypted_password => crypted_password,  
117 - :password_type => 'crypt',  
118 - :salt => 'xy',  
119 - :environment_id => environment_id,  
120 - }.merge(options)  
121 - user = fast_insert_with_timestamps(User, data)  
122 - person = fast_insert_with_timestamps(Person, { :type => 'Person', :identifier => name, :name => name, :user_id => user.id, :environment_id => environment_id }.merge(person_options))  
123 - homepage = fast_insert_with_timestamps(TextileArticle, { :type => 'TextileArticle', :name => 'homepage', :slug => 'homepage', :path => 'homepage', :profile_id => person.id })  
124 - fast_update(person, {:home_page_id => homepage.id})  
125 - box = fast_insert(Box, { :owner_type => "Profile", :owner_id => person.id, :position => 1})  
126 - block = fast_insert(Block, { :box_id => box.id, :type => 'MainBlock', :position => 0})  
127 - user  
128 - end  
129 -  
130 - def fast_insert(klass, data)  
131 - names = data.keys  
132 - values = names.map {|k| ActiveRecord::Base.send(:sanitize_sql_array, ['?', data[k]]) }  
133 - sql = 'insert into %s(%s) values (%s)' % [klass.table_name, names.join(','), values.join(',')]  
134 - klass.connection.execute(sql)  
135 - klass.last(:order => 'id')  
136 - end  
137 -  
138 - def fast_insert_with_timestamps(klass, data)  
139 - now = Time.now  
140 - fast_insert(klass, { :created_at => now, :updated_at => now}.merge(data))  
141 - end  
142 -  
143 - def fast_update(obj, data)  
144 - obj.class.connection.execute('update %s set %s where id = %d' % [obj.class.table_name, obj.class.send(:sanitize_sql_for_assignment, data), obj.id])  
145 - end  
146 -  
147 - def give_permission(user, permission, target)  
148 - user = Person.find_by_identifier(user) if user.kind_of?(String)  
149 - target ||= user  
150 - i = 0  
151 - while Role.find_by_name('test_role' + i.to_s)  
152 - i+=1  
153 - end  
154 -  
155 - role = create(Role, :name => 'test_role' + i.to_s, :permissions => [permission])  
156 - assert user.add_role(role, target)  
157 - assert user.has_permission?(permission, target)  
158 - user  
159 - end  
160 -  
161 - def create_user_with_permission(name, permission, target= nil)  
162 - user = create_user(name).person  
163 - give_permission(user, permission, target)  
164 - end  
165 -  
166 -  
167 - protected  
168 -  
169 - def factory_num_seq  
170 - Noosfero::Factory.num_seq  
171 - end  
172 -  
173 - ###############################################  
174 - # Environment  
175 - ###############################################  
176 -  
177 - def defaults_for_environment  
178 - seq = factory_num_seq  
179 - {  
180 - :name => "Environment %d" % seq,  
181 - :contact_email => "environment%d@example.com" % seq  
182 - }  
183 - end  
184 -  
185 - ###############################################  
186 - # Enterprise  
187 - ###############################################  
188 -  
189 - def defaults_for_enterprise  
190 - n = factory_num_seq.to_s  
191 - defaults_for_profile.merge({ :identifier => "enterprise-" + n, :name => 'Enterprise ' + n })  
192 - end  
193 -  
194 - ###############################################  
195 - # Community  
196 - ###############################################  
197 -  
198 - def defaults_for_community  
199 - n = factory_num_seq.to_s  
200 - defaults_for_profile.merge({ :identifier => "community-" + n, :name => 'Community ' + n })  
201 - end  
202 -  
203 - ###############################################  
204 - # Person  
205 - ###############################################  
206 -  
207 - def defaults_for_person  
208 - n = factory_num_seq.to_s  
209 - defaults_for_profile.merge({ :identifier => "person-" + n, :name => 'Person ' + n, :created_at => DateTime.now })  
210 - end  
211 -  
212 - ###############################################  
213 - # Profile  
214 - ###############################################  
215 -  
216 - def defaults_for_profile  
217 - n = factory_num_seq.to_s  
218 - { :public_profile => true, :identifier => 'profile-' + n, :name => 'Profile ' + n, :environment_id => 1 }  
219 - end  
220 -  
221 - ###############################################  
222 - # Organization  
223 - ###############################################  
224 -  
225 - def defaults_for_organization  
226 - n = factory_num_seq.to_s  
227 - defaults_for_profile.merge({:identifier => 'organization-' + n, :name => 'Organization ' + n})  
228 - end  
229 -  
230 - ###############################################  
231 - # Article (and friends)  
232 - ###############################################  
233 -  
234 - def defaults_for_article  
235 - name = 'My article ' + factory_num_seq.to_s  
236 - { :name => name, :slug => name.to_slug, :path => name.to_slug }  
237 - end  
238 -  
239 - alias :defaults_for_text_article :defaults_for_article  
240 - alias :defaults_for_textile_article :defaults_for_article  
241 - alias :defaults_for_tiny_mce_article :defaults_for_article  
242 - alias :defaults_for_rss_feed :defaults_for_article  
243 - alias :defaults_for_published_article :defaults_for_article  
244 - alias :defaults_for_folder :defaults_for_article  
245 -  
246 - ###############################################  
247 - # Event  
248 - ###############################################  
249 -  
250 - def defaults_for_event  
251 - num = factory_num_seq.to_s  
252 - {  
253 - :name => 'My event ' + num,  
254 - :slug => 'my-event-' + num,  
255 - :path => '/my-event-' + num,  
256 - :start_date => Date.today  
257 - }  
258 - end  
259 -  
260 - ###############################################  
261 - # UploadedFile  
262 - ###############################################  
263 -  
264 - def defaults_for_uploaded_file  
265 - name = 'My uploaded file ' + factory_num_seq.to_s  
266 - { :name => name, :abstract => name }  
267 - end  
268 -  
269 - ###############################################  
270 - # Blog  
271 - ###############################################  
272 - def defaults_for_blog  
273 - name = 'My blog ' + factory_num_seq.to_s  
274 - { :name => name, :slug => name.to_slug, :path => name.to_slug }  
275 - end  
276 -  
277 - def create_blog  
278 - profile = create(Profile, :identifier => 'testuser' + factory_num_seq.to_s, :name => 'Test user')  
279 - create(Blog, :name => 'blog', :profile => profile)  
280 - end  
281 -  
282 - ###############################################  
283 - # ExternalFeed  
284 - ###############################################  
285 - def defaults_for_external_feed  
286 - { :address => Rails.root.join('test', 'fixtures', 'files', 'feed.xml'), :blog_id => factory_num_seq }  
287 - end  
288 -  
289 - def create_external_feed(attrs = {})  
290 - feed = build(:external_feed, attrs)  
291 - feed.blog = create_blog  
292 - feed.save!  
293 - feed  
294 - end  
295 -  
296 - ###############################################  
297 - # FeedReaderBlock  
298 - ###############################################  
299 - def defaults_for_feed_reader_block  
300 - { :address => Rails.root.join('test/fixtures/files/feed.xml') }  
301 - end  
302 -  
303 - ###############################################  
304 - # Domain  
305 - ###############################################  
306 - def defaults_for_domain  
307 - { :name => 'example' + factory_num_seq.to_s + '.com' }  
308 - end  
309 -  
310 - ###############################################  
311 - # Category  
312 - ###############################################  
313 - def defaults_for_category  
314 - name = 'category' + factory_num_seq.to_s  
315 - { :environment_id => 1, :name => name, :slug => name.to_slug, :path => name.to_slug }  
316 - end  
317 -  
318 - alias :defaults_for_region :defaults_for_category  
319 - alias :defaults_for_product_category :defaults_for_category  
320 -  
321 - ###############################################  
322 - # Box  
323 - ###############################################  
324 - def defaults_for_box  
325 - { }  
326 - end  
327 -  
328 - ###############################################  
329 - # Block  
330 - ###############################################  
331 - def defaults_for_block  
332 - { }  
333 - end  
334 -  
335 - alias :defaults_for_blog_archives_block :defaults_for_block  
336 - alias :defaults_for_profile_list_block :defaults_for_block  
337 -  
338 - ###############################################  
339 - # Task  
340 - ###############################################  
341 - def defaults_for_task  
342 - { :code => "task_for_test_#{factory_num_seq.to_s}" }  
343 - end  
344 -  
345 - alias :defaults_for_add_friend :defaults_for_task  
346 - alias :defaults_for_add_member :defaults_for_task  
347 - alias :defaults_for_create_community :defaults_for_task  
348 - alias :defaults_for_email_activation :defaults_for_task  
349 -  
350 - ###############################################  
351 - # Product  
352 - ###############################################  
353 -  
354 - def defaults_for_product  
355 - { :name => 'Product ' + factory_num_seq.to_s }  
356 - end  
357 -  
358 - ###############################################  
359 - # Input  
360 - ###############################################  
361 -  
362 - def defaults_for_input  
363 - { }  
364 - end  
365 -  
366 - ###############################################  
367 - # Contact  
368 - ###############################################  
369 -  
370 - def defaults_for_contact  
371 - { :subject => 'hello there', :message => 'here I come to SPAM you' }  
372 - end  
373 -  
374 - ###############################################  
375 - # Qualifier  
376 - ###############################################  
377 -  
378 - def defaults_for_qualifier  
379 - { :name => 'Qualifier ' + factory_num_seq.to_s, :environment_id => 1 }  
380 - end  
381 -  
382 - ###############################################  
383 - # Certifier  
384 - ###############################################  
385 -  
386 - def defaults_for_certifier  
387 - defaults_for_qualifier.merge({ :name => 'Certifier ' + factory_num_seq.to_s })  
388 - end  
389 -  
390 - ###############################################  
391 - # Scrap  
392 - ###############################################  
393 -  
394 - def defaults_for_scrap(params = {})  
395 - { :content => 'some content ', :sender_id => 1, :receiver_id => 1, :created_at => DateTime.now }.merge(params)  
396 - end  
397 -  
398 - ###############################################  
399 - # ActionTrackerNotification  
400 - ###############################################  
401 -  
402 - def defaults_for_action_tracker_notification(params = {})  
403 - { :action_tracker_id => 1, :profile_id => 1 }.merge(params)  
404 - end  
405 -  
406 - ###############################################  
407 - # ActionTracker  
408 - ###############################################  
409 -  
410 - def defaults_for_action_tracker_record(params = {})  
411 - { :created_at => DateTime.now, :verb => 'add_member_in_community', :user_type => 'Profile', :user_id => 1 }.merge(params)  
412 - end  
413 -  
414 - ###############################################  
415 - # Friendship  
416 - ###############################################  
417 -  
418 - def defaults_for_friendship(params = {})  
419 - { :created_at => DateTime.now, :person_id => 1, :friend_id => 2 }.merge(params)  
420 - end  
421 -  
422 - ###############################################  
423 - # RoleAssignment  
424 - ###############################################  
425 -  
426 - def defaults_for_role_assignment(params = {})  
427 - { :role_id => 1, :accessor_id => 1, :accessor_type => 'Profile', :resource_id => 2, :resource_type => 'Profile' }.merge(params)  
428 - end  
429 -  
430 - ###############################################  
431 - # User  
432 - ###############################################  
433 -  
434 - def defaults_for_user(params = {})  
435 - username = "user_#{rand(1000)}"  
436 - { :login => username, :email => username + '@noosfero.colivre', :crypted_password => 'test'}.merge(params)  
437 - end  
438 -  
439 - ###############################################  
440 - # Forum  
441 - ###############################################  
442 -  
443 - def defaults_for_forum(params = {})  
444 - name = "forum_#{rand(1000)}"  
445 - { :profile_id => 1, :path => name.to_slug, :name => name, :slug => name.to_slug }.merge(params)  
446 - end  
447 -  
448 - ###############################################  
449 - # Gallery  
450 - ###############################################  
451 -  
452 - def defaults_for_gallery(params = {})  
453 - name = "gallery_#{rand(1000)}"  
454 - { :profile_id => 1, :path => name.to_slug, :name => name, :slug => name.to_slug }.merge(params)  
455 - end  
456 -  
457 - def defaults_for_suggest_article  
458 - { :name => 'Sender', :email => 'sender@example.com', :article => {:name => 'Some title', :body => 'some body text', :abstract => 'some abstract text'}}  
459 - end  
460 -  
461 - def defaults_for_comment(params = {})  
462 - name = "comment_#{rand(1000)}"  
463 - { :title => name, :body => "my own comment", :source_id => 1, :source_type => 'Article' }.merge(params)  
464 - end  
465 -  
466 - ###############################################  
467 - # Unit  
468 - ###############################################  
469 -  
470 - def defaults_for_unit  
471 - { :singular => 'Litre', :plural => 'Litres', :environment_id => 1 }  
472 - end  
473 -  
474 - ###############################################  
475 - # Production Cost  
476 - ###############################################  
477 -  
478 - def defaults_for_production_cost  
479 - { :name => 'Production cost ' + factory_num_seq.to_s }  
480 - end  
481 -  
482 - ###############################################  
483 - # National Region  
484 - ###############################################  
485 -  
486 - def defaults_for_national_region  
487 - { :name => 'National region ' + factory_num_seq.to_s }  
488 - end  
489 -  
490 - def defaults_for_license  
491 - name = "License #{rand(1000)}"  
492 - slug = name.to_slug  
493 - { :name => name, :url => "#{slug}.org", :slug => slug, :environment_id => 1}  
494 - end  
495 -  
496 -end  
test/functional/account_controller_test.rb
@@ -2,9 +2,7 @@ require_relative &quot;../test_helper&quot; @@ -2,9 +2,7 @@ require_relative &quot;../test_helper&quot;
2 require 'account_controller' 2 require 'account_controller'
3 3
4 class AccountControllerTest < ActionController::TestCase 4 class AccountControllerTest < ActionController::TestCase
5 - # Be sure to include AuthenticatedTestHelper in test/test_helper.rb instead  
6 - # Then, you can remove it from this and the units test.  
7 - include AuthenticatedTestHelper 5 +
8 all_fixtures 6 all_fixtures
9 7
10 def teardown 8 def teardown
test/integration/approve_reject_enterprise_test.rb
@@ -1,9 +0,0 @@ @@ -1,9 +0,0 @@
1 -require_relative "../test_helper"  
2 -  
3 -class ApproveRejectEnterpriseTest < ActionController::IntegrationTest  
4 - all_fixtures  
5 -  
6 - def test_approving  
7 - true  
8 - end  
9 -end  
test/integration/assets_menu_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class AssetsMenuTest < ActionController::IntegrationTest 3 +class AssetsMenuTest < ActionDispatch::IntegrationTest
4 4
5 def setup 5 def setup
6 # HomeController.any_instance.stubs(:get_layout).returns('application') 6 # HomeController.any_instance.stubs(:get_layout).returns('application')
@@ -9,18 +9,18 @@ class AssetsMenuTest &lt; ActionController::IntegrationTest @@ -9,18 +9,18 @@ class AssetsMenuTest &lt; ActionController::IntegrationTest
9 parent = Category.create!(:name => "Parent Category", :environment => Environment.default, :display_color => '#888a85') 9 parent = Category.create!(:name => "Parent Category", :environment => Environment.default, :display_color => '#888a85')
10 @category = Category.create!(:name => "Category A", :environment => Environment.default, :parent => parent) 10 @category = Category.create!(:name => "Category A", :environment => Environment.default, :parent => parent)
11 end 11 end
12 - 12 +
13 should 'link to uncategorized assets at site root' do 13 should 'link to uncategorized assets at site root' do
14 get '/' 14 get '/'
15 assert_tag :tag => 'a', :attributes => { :href => '/search/contents' } 15 assert_tag :tag => 'a', :attributes => { :href => '/search/contents' }
16 end 16 end
17 17
18 should 'link to assets inside category root' do 18 should 'link to assets inside category root' do
19 - (1..SearchController::MULTIPLE_SEARCH_LIMIT+1).each do |i| 19 + (1..SearchController::MULTIPLE_SEARCH_LIMIT+1).each do |i|
20 enterprise = Enterprise.create! :identifier => "ent#{i}", :name => "enterprise#{i}" 20 enterprise = Enterprise.create! :identifier => "ent#{i}", :name => "enterprise#{i}"
21 ProfileCategorization.add_category_to_profile(@category, enterprise) 21 ProfileCategorization.add_category_to_profile(@category, enterprise)
22 end 22 end
23 - 23 +
24 get '/cat/parent-category/category-a' 24 get '/cat/parent-category/category-a'
25 assert_tag :tag => 'a', :attributes => { :href => '/search/enterprises/parent-category/category-a' } 25 assert_tag :tag => 'a', :attributes => { :href => '/search/enterprises/parent-category/category-a' }
26 end 26 end
test/integration/assigning_validator_organizations_to_regions_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class AssigningValidatorOrganizationsToRegionsTest < ActionController::IntegrationTest 3 +class AssigningValidatorOrganizationsToRegionsTest < ActionDispatch::IntegrationTest
4 4
5 should 'be able to properly assign organizations as validators to regions' do 5 should 'be able to properly assign organizations as validators to regions' do
6 env = Environment.default 6 env = Environment.default
@@ -25,7 +25,7 @@ class AssigningValidatorOrganizationsToRegionsTest &lt; ActionController::Integrati @@ -25,7 +25,7 @@ class AssigningValidatorOrganizationsToRegionsTest &lt; ActionController::Integrati
25 get "/admin/region_validators/region/#{region1.id}", :search => 'two' 25 get "/admin/region_validators/region/#{region1.id}", :search => 'two'
26 assert_response :success 26 assert_response :success
27 assert_tag :tag => 'form', :attributes => { :action => "/admin/region_validators/add/#{region1.id}" }, :descendant => { :tag => 'input', :attributes => { :type => 'hidden', :name => 'validator_id', :value => org2.id } } 27 assert_tag :tag => 'form', :attributes => { :action => "/admin/region_validators/add/#{region1.id}" }, :descendant => { :tag => 'input', :attributes => { :type => 'hidden', :name => 'validator_id', :value => org2.id } }
28 - 28 +
29 post "/admin/region_validators/add/#{region1.id}", :validator_id => org2.id 29 post "/admin/region_validators/add/#{region1.id}", :validator_id => org2.id
30 assert_response :redirect 30 assert_response :redirect
31 31
test/integration/blocks_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class BlocksTest < ActionController::IntegrationTest 3 +class BlocksTest < ActionDispatch::IntegrationTest
  4 +
4 def blog_on_article_block_bootstrap 5 def blog_on_article_block_bootstrap
5 profile = fast_create(Profile) 6 profile = fast_create(Profile)
6 blog = fast_create(Blog, :name => 'Blog', :profile_id => profile.id) 7 blog = fast_create(Blog, :name => 'Blog', :profile_id => profile.id)
test/integration/controller_naming_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class ControllerNamingTest < ActionController::IntegrationTest 3 +class ControllerNamingTest < ActionDispatch::IntegrationTest
4 4
5 should 'not have controllers with same name in different folders' do 5 should 'not have controllers with same name in different folders' do
6 controllers = Dir.glob(Rails.root.join("app", "controllers", "**", "*_controller.rb")).map { |item| item.split(/\//).last } 6 controllers = Dir.glob(Rails.root.join("app", "controllers", "**", "*_controller.rb")).map { |item| item.split(/\//).last }
test/integration/editing_person_info_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class EditingPersonInfoTest < ActionController::IntegrationTest 3 +class EditingPersonInfoTest < ActionDispatch::IntegrationTest
4 4
5 fixtures :users, :profiles, :domains, :environments 5 fixtures :users, :profiles, :domains, :environments
6 6
test/integration/enable_disable_features_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class EnableDisableFeaturesTest < ActionController::IntegrationTest 3 +class EnableDisableFeaturesTest < ActionDispatch::IntegrationTest
  4 +
4 all_fixtures 5 all_fixtures
5 6
6 def test_enable_features 7 def test_enable_features
test/integration/enterprise_registration_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class EnterpriseRegistrationTest < ActionController::IntegrationTest 3 +class EnterpriseRegistrationTest < ActionDispatch::IntegrationTest
4 4
5 fixtures :users, :profiles, :environments 5 fixtures :users, :profiles, :environments
6 6
@@ -40,7 +40,7 @@ class EnterpriseRegistrationTest &lt; ActionController::IntegrationTest @@ -40,7 +40,7 @@ class EnterpriseRegistrationTest &lt; ActionController::IntegrationTest
40 assert_difference 'CreateEnterprise.count' do 40 assert_difference 'CreateEnterprise.count' do
41 post '/enterprise_registration', :create_enterprise => data.merge(:target_id => org.id) 41 post '/enterprise_registration', :create_enterprise => data.merge(:target_id => org.id)
42 end 42 end
43 - 43 +
44 assert_template 'confirmation' 44 assert_template 'confirmation'
45 assert_tag :tag => 'a', :attributes => { :href => '/' } 45 assert_tag :tag => 'a', :attributes => { :href => '/' }
46 46
@@ -63,7 +63,7 @@ class EnterpriseRegistrationTest &lt; ActionController::IntegrationTest @@ -63,7 +63,7 @@ class EnterpriseRegistrationTest &lt; ActionController::IntegrationTest
63 63
64 post "/myprofile/myorg/enterprise_validation/approve/#{code}" 64 post "/myprofile/myorg/enterprise_validation/approve/#{code}"
65 assert_response :redirect 65 assert_response :redirect
66 - 66 +
67 follow_redirect! 67 follow_redirect!
68 assert_equal "/myprofile/myorg/enterprise_validation/view_processed/#{code}", path 68 assert_equal "/myprofile/myorg/enterprise_validation/view_processed/#{code}", path
69 assert_tag :span, :attributes => { :class => 'validation_approved' } 69 assert_tag :span, :attributes => { :class => 'validation_approved' }
test/integration/forgot_password_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class ForgotPasswordTest < ActionController::IntegrationTest 3 +class ForgotPasswordTest < ActionDispatch::IntegrationTest
4 4
5 def setup 5 def setup
6 - ActionController::Integration::Session.any_instance.stubs(:https?).returns(true) 6 + ActionDispatch::Integration::Session.any_instance.stubs(:https?).returns(true)
7 end 7 end
8 8
9 def test_forgot_password_with_login 9 def test_forgot_password_with_login
test/integration/http_caching_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class HttpCachingTest < ActionController::IntegrationTest 3 +class HttpCachingTest < ActionDispatch::IntegrationTest
4 4
5 def setup 5 def setup
6 create_user('joao', password: 'test', password_confirmation: 'test').activate 6 create_user('joao', password: 'test', password_confirmation: 'test').activate
test/integration/login_to_the_application_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class LoginToTheApplicationTest < ActionController::IntegrationTest 3 +class LoginToTheApplicationTest < ActionDispatch::IntegrationTest
  4 +
4 fixtures :users, :environments, :profiles 5 fixtures :users, :environments, :profiles
5 6
6 def test_unauthenticated_user_tries_to_access_his_control_panel 7 def test_unauthenticated_user_tries_to_access_his_control_panel
test/integration/manage_documents_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class ManageDocumentsTest < ActionController::IntegrationTest 3 +class ManageDocumentsTest < ActionDispatch::IntegrationTest
4 4
5 all_fixtures 5 all_fixtures
6 6
@@ -78,18 +78,18 @@ class ManageDocumentsTest &lt; ActionController::IntegrationTest @@ -78,18 +78,18 @@ class ManageDocumentsTest &lt; ActionController::IntegrationTest
78 assert_tag :tag => 'a', :attributes => { :href => "/myprofile/#{profile.identifier}" } 78 assert_tag :tag => 'a', :attributes => { :href => "/myprofile/#{profile.identifier}" }
79 get '/myprofile/myuser' 79 get '/myprofile/myuser'
80 assert_response :success 80 assert_response :success
81 - 81 +
82 assert_tag :tag => 'a', :attributes => { :href => '/myprofile/myuser/cms' } 82 assert_tag :tag => 'a', :attributes => { :href => '/myprofile/myuser/cms' }
83 get '/myprofile/myuser/cms' 83 get '/myprofile/myuser/cms'
84 assert_response :success 84 assert_response :success
85 85
86 - assert_tag :tag => 'a', :attributes => { :href => "/myprofile/myuser/cms/destroy/#{article.id}", 'data-confirm' => /Are you sure/ } 86 + assert_tag tag: 'a', attributes: { href: "/myprofile/myuser/cms/destroy/#{article.id}" }
87 post "/myprofile/myuser/cms/destroy/#{article.id}" 87 post "/myprofile/myuser/cms/destroy/#{article.id}"
88 88
89 assert_response :redirect 89 assert_response :redirect
90 follow_redirect! 90 follow_redirect!
91 assert_equal "/myuser", path 91 assert_equal "/myuser", path
92 - 92 +
93 # the article was actually deleted 93 # the article was actually deleted
94 assert_raise ActiveRecord::RecordNotFound do 94 assert_raise ActiveRecord::RecordNotFound do
95 Article.find(article.id) 95 Article.find(article.id)
test/integration/manage_friendships_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class ManageFriendshipsTest < ActionController::IntegrationTest 3 +class ManageFriendshipsTest < ActionDispatch::IntegrationTest
4 4
5 def setup 5 def setup
6 FriendsController.any_instance.stubs(:get_layout).returns('application') 6 FriendsController.any_instance.stubs(:get_layout).returns('application')
test/integration/online_doc_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class OnlineDocTest < ActionController::IntegrationTest 3 +class OnlineDocTest < ActionDispatch::IntegrationTest
4 4
5 def test_404_section 5 def test_404_section
6 get '/doc/something-very-unlikely' 6 get '/doc/something-very-unlikely'
test/integration/performance_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 require 'benchmark' 2 require 'benchmark'
3 3
4 -class PerformanceTest < ActionController::IntegrationTest 4 +class PerformanceTest < ActionDispatch::IntegrationTest
5 5
6 all_fixtures 6 all_fixtures
7 7
test/integration/routing_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class RoutingTest < ActionController::IntegrationTest 3 +class RoutingTest < ActionDispatch::IntegrationTest
4 4
5 def setup 5 def setup
6 Domain.clear_cache 6 Domain.clear_cache
test/integration/search_popup_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class SearchPopupTest < ActionController::IntegrationTest 3 +class SearchPopupTest < ActionDispatch::IntegrationTest
4 4
5 def setup 5 def setup
6 HomeController.any_instance.stubs(:get_layout).returns('application') 6 HomeController.any_instance.stubs(:get_layout).returns('application')
test/integration/signup_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class SignupTest < ActionController::IntegrationTest 3 +class SignupTest < ActionDispatch::IntegrationTest
  4 +
4 all_fixtures 5 all_fixtures
5 6
6 def setup 7 def setup
7 - ActionController::Integration::Session.any_instance.stubs(:https?).returns(true) 8 + ActionDispatch::Integration::Session.any_instance.stubs(:https?).returns(true)
8 end 9 end
9 10
10 def test_signup_form_submission_must_be_blocked_for_fast_bots 11 def test_signup_form_submission_must_be_blocked_for_fast_bots
test/integration/user_registers_at_the_application_test.rb
1 require_relative "../test_helper" 1 require_relative "../test_helper"
2 2
3 -class UserRegistersAtTheApplicationTest < ActionController::IntegrationTest 3 +class UserRegistersAtTheApplicationTest < ActionDispatch::IntegrationTest
4 fixtures :users, :environments, :profiles 4 fixtures :users, :environments, :profiles
5 5
6 def test_successfull_registration 6 def test_successfull_registration
@@ -11,7 +11,7 @@ class UserRegistersAtTheApplicationTest &lt; ActionController::IntegrationTest @@ -11,7 +11,7 @@ class UserRegistersAtTheApplicationTest &lt; ActionController::IntegrationTest
11 get '/account/signup' 11 get '/account/signup'
12 12
13 assert_response :success 13 assert_response :success
14 - 14 +
15 post '/account/signup', :user => { :login => 'mylogin', :password => 'mypassword', :password_confirmation => 'mypassword', :email => 'mylogin@example.com' } 15 post '/account/signup', :user => { :login => 'mylogin', :password => 'mypassword', :password_confirmation => 'mypassword', :email => 'mylogin@example.com' }
16 assert_response :success 16 assert_response :success
17 17
@@ -32,7 +32,7 @@ class UserRegistersAtTheApplicationTest &lt; ActionController::IntegrationTest @@ -32,7 +32,7 @@ class UserRegistersAtTheApplicationTest &lt; ActionController::IntegrationTest
32 get '/account/signup' 32 get '/account/signup'
33 33
34 assert_response :success 34 assert_response :success
35 - 35 +
36 post '/account/signup', :user => { :login => 'ze', :password => 'mypassword', :password_confirmation => 'mypassword', :email => 'mylogin@example.com' } 36 post '/account/signup', :user => { :login => 'ze', :password => 'mypassword', :password_confirmation => 'mypassword', :email => 'mylogin@example.com' }
37 assert_response :success 37 assert_response :success
38 assert_tag :tag => 'div', :attributes => { :id => 'errorExplanation', :class => 'errorExplanation' } 38 assert_tag :tag => 'div', :attributes => { :id => 'errorExplanation', :class => 'errorExplanation' }
test/integration/varnish_conf_test.rb
1 -require 'test/unit' 1 +require 'test_helper'
2 2
3 -class VarnishConfTest < Test::Unit::TestCase 3 +class VarnishConfTest < ActiveSupport::TestCase
4 4
5 def test_not_use_return_in_varnish_noosfero 5 def test_not_use_return_in_varnish_noosfero
6 assert !system('grep "return.*pass" etc/noosfero/varnish-noosfero.vcl') 6 assert !system('grep "return.*pass" etc/noosfero/varnish-noosfero.vcl')
test/noosfero_doc_test.rb
@@ -1,50 +0,0 @@ @@ -1,50 +0,0 @@
1 -# encoding: UTF-8  
2 -require 'mocha'  
3 -  
4 -module Noosfero::DocTest  
5 -  
6 - unless defined?(ROOT)  
7 - ROOT = Rails.root.join("test", "tmp", "doc")  
8 - end  
9 -  
10 - def create_doc(section, topic, language, title, body = nil)  
11 - dir = File.join(ROOT, section)  
12 - FileUtils.mkdir_p(dir)  
13 - File.open("#{dir}/#{topic}.#{language}.xhtml", "w") do |f|  
14 - f.puts "<h1>#{title}</h1>"  
15 - f.puts body  
16 - end  
17 - end  
18 -  
19 - def setup_doc_test  
20 - FileUtils.mkdir_p(ROOT)  
21 -  
22 - # root  
23 - create_doc('', 'index', 'en', 'Noosfero online manual')  
24 - create_doc('', 'toc', 'en', '', '<ul><li><a href="/doc/user">User features</a></li><li><a href="/doc/cms">Content Management</a></li></ul>')  
25 - # cms  
26 - create_doc('cms', 'index', 'en', 'Content Management')  
27 - create_doc('cms', 'index', 'pt', 'Gerenciamento de conteúdo')  
28 - create_doc('cms', 'toc', 'en', '')  
29 - create_doc('cms', 'toc', 'pt', '')  
30 - create_doc('cms', 'adding-pictures', 'en', 'Adding pictures to gallery')  
31 - create_doc('cms', 'adding-pictures', 'pt', 'Adicionando fotos na galeria')  
32 - create_doc('cms', 'creating-a-blog', 'en', 'Creating a blog')  
33 - create_doc('cms', 'creating-a-blog', 'pt', 'Criando um blog')  
34 - # user  
35 - create_doc('user', 'index', 'en', 'User features')  
36 - create_doc('user', 'index', 'pt', 'Funcionalidades de Usuário')  
37 - create_doc('user', 'toc', 'en', '<ul><li><a href="/doc/user/commenting-articles">Commenting articles</a></li><li><a href="/doc/user/acceptins-friends">Accepting friends</a></li></ul>')  
38 - create_doc('user', 'toc', 'pt', '')  
39 - create_doc('user', 'accepting-friends', 'en', 'Accepting friends')  
40 - create_doc('user', 'accepting-friends', 'pt', 'Aceitando amigos')  
41 - create_doc('user', 'commenting-articles', 'en', 'Commenting articles', 'How to access')  
42 - create_doc('user', 'commenting-articles', 'pt', 'Comentando artigos')  
43 -  
44 - DocSection.stubs(:root_dir).returns(ROOT)  
45 - end  
46 -  
47 - def tear_down_doc_test  
48 - FileUtils.rm_rf(ROOT)  
49 - end  
50 -end  
test/support/action_tracker_test_helper.rb 0 → 100644
@@ -0,0 +1,16 @@ @@ -0,0 +1,16 @@
  1 +class UserStampSweeper < ActionController::Caching::Sweeper
  2 + private
  3 + def current_user
  4 + Person.first
  5 + end
  6 +end
  7 +
  8 +module ActionTracker
  9 + class Record
  10 + def back_in_time(time = 25.hours)
  11 + self.updated_at = Time.now.ago(time)
  12 + self.send :update_without_callbacks
  13 + self
  14 + end
  15 + end
  16 +end
test/support/authenticated_test_helper.rb 0 → 100644
@@ -0,0 +1,99 @@ @@ -0,0 +1,99 @@
  1 +module AuthenticatedTestHelper
  2 +
  3 + # Sets the current user in the session from the user fixtures.
  4 + def login_as(user)
  5 + @request.session[:user] = User.find_by_login(user.to_s).id
  6 + end
  7 +
  8 + def logout
  9 + @request.session.delete(:user)
  10 + end
  11 +
  12 + def content_type(type)
  13 + @request.env['Content-Type'] = type
  14 + end
  15 +
  16 + def accept(accept)
  17 + @request.env["HTTP_ACCEPT"] = accept
  18 + end
  19 +
  20 + def authorize_as(user)
  21 + if user
  22 + @request.env["HTTP_AUTHORIZATION"] = "Basic #{Base64.encode64("#{users(user).login}:test")}"
  23 + accept 'application/xml'
  24 + content_type 'application/xml'
  25 + else
  26 + @request.env["HTTP_AUTHORIZATION"] = nil
  27 + accept nil
  28 + content_type nil
  29 + end
  30 + end
  31 +
  32 + # Assert the block redirects to the login
  33 + #
  34 + # assert_requires_login(:bob) { |c| c.get :edit, :id => 1 }
  35 + #
  36 + def assert_requires_login(login = nil)
  37 + yield HttpLoginProxy.new(self, login)
  38 + end
  39 +
  40 + def assert_http_authentication_required(login = nil)
  41 + yield XmlLoginProxy.new(self, login)
  42 + end
  43 +
  44 + def reset!(*instance_vars)
  45 + instance_vars = [:controller, :request, :response] unless instance_vars.any?
  46 + instance_vars.collect! { |v| "@#{v}".to_sym }
  47 + instance_vars.each do |var|
  48 + instance_variable_set(var, instance_variable_get(var).class.new)
  49 + end
  50 + end
  51 +end
  52 +
  53 +class BaseLoginProxy
  54 + attr_reader :controller
  55 + attr_reader :options
  56 + def initialize(controller, login)
  57 + @controller = controller
  58 + @login = login
  59 + end
  60 +
  61 + private
  62 + def authenticated
  63 + raise NotImplementedError
  64 + end
  65 +
  66 + def check
  67 + raise NotImplementedError
  68 + end
  69 +
  70 + def method_missing(method, *args)
  71 + @controller.reset!
  72 + authenticate
  73 + @controller.send(method, *args)
  74 + check
  75 + end
  76 +end
  77 +
  78 +class HttpLoginProxy < BaseLoginProxy
  79 + protected
  80 + def authenticate
  81 + @controller.login_as @login if @login
  82 + end
  83 +
  84 + def check
  85 + @controller.assert_redirected_to :controller => 'account', :action => 'login'
  86 + end
  87 +end
  88 +
  89 +class XmlLoginProxy < BaseLoginProxy
  90 + protected
  91 + def authenticate
  92 + @controller.accept 'application/xml'
  93 + @controller.authorize_as @login if @login
  94 + end
  95 +
  96 + def check
  97 + @controller.assert_response 401
  98 + end
  99 +end
test/support/controller_test_case.rb 0 → 100644
@@ -0,0 +1,16 @@ @@ -0,0 +1,16 @@
  1 +
  2 +class ActionController::TestCase
  3 +
  4 + class_attribute :default_params
  5 + self.default_params = {}
  6 +
  7 + def get path, parameters = nil, session = nil, flash = nil
  8 + super path, if parameters then self.default_params.merge parameters else self.default_params end, session, flash
  9 + end
  10 +
  11 + def post path, parameters = nil, session = nil, flash = nil
  12 + super path, if parameters then self.default_params.merge parameters else self.default_params end, session, flash
  13 + end
  14 +
  15 +end
  16 +
test/support/factories.rb 0 → 100644
@@ -0,0 +1,496 @@ @@ -0,0 +1,496 @@
  1 +module Noosfero::Factory
  2 +
  3 + def fast_create(name, attrs = {}, options = {})
  4 + defaults = defaults_for(name)
  5 + attrs[:slug] = attrs[:name].to_slug if attrs[:name].present? && attrs[:slug].blank? && defaults[:slug].present?
  6 + data = defaults_for(name.to_s.gsub('::','')).merge(attrs)
  7 + klass = name.to_s.camelize.constantize
  8 + if klass.superclass != ActiveRecord::Base
  9 + data[:type] = klass.to_s
  10 + end
  11 + if options[:timestamps]
  12 + fast_insert_with_timestamps(klass, data)
  13 + else
  14 + fast_insert(klass, data)
  15 + end
  16 + obj = klass.last(:order => "id")
  17 + if options[:category]
  18 + categories = options[:category]
  19 + unless categories.is_a?(Array)
  20 + categories = [categories]
  21 + end
  22 + categories.each do |category|
  23 + obj.add_category(category)
  24 + end
  25 + end
  26 + obj
  27 + end
  28 +
  29 + def create(name, attrs = {})
  30 + target = 'create_' + name.to_s
  31 + if respond_to?(target)
  32 + send(target, attrs)
  33 + else
  34 + obj = build name
  35 + attrs.each{ |a, v| obj.send "#{a}=", v }
  36 + obj.save!
  37 + obj
  38 + end
  39 + end
  40 +
  41 + def build(name, attrs = {})
  42 + defaults = defaults_for(name)
  43 + attrs[:slug] = attrs[:name].to_slug if attrs[:name].present? && attrs[:slug].blank? && defaults[:slug].present?
  44 + data = defaults_for(name).merge(attrs)
  45 + object = name.to_s.camelize.constantize.new
  46 + if object.respond_to?(:assign_attributes)
  47 + object.assign_attributes(data, :without_protection => true)
  48 + else
  49 + data.each { |attribute, value| object.send(attribute.to_s+'=', value) }
  50 + end
  51 + object
  52 + end
  53 +
  54 + def defaults_for(name)
  55 + send('defaults_for_' + name.to_s.underscore)
  56 + rescue
  57 + {}
  58 + end
  59 +
  60 + def self.num_seq
  61 + @num_seq ||= 0
  62 + @num_seq += 1
  63 + @num_seq
  64 + end
  65 +
  66 + ###### old stuff to be rearranged
  67 + def create_admin_user(env)
  68 + admin_user = User.find_by_login('adminuser') || create_user('adminuser', :email => 'adminuser@noosfero.org', :password => 'adminuser', :password_confirmation => 'adminuser', :environment => env)
  69 + admin_role = Role.find_by_name('admin_role') || Role.create!(:name => 'admin_role', :permissions => ['view_environment_admin_panel','edit_environment_features', 'edit_environment_design', 'manage_environment_categories', 'manage_environment_roles', 'manage_environment_trusted_sites', 'manage_environment_validators', 'manage_environment_users', 'manage_environment_organizations', 'manage_environment_templates', 'manage_environment_licenses', 'edit_appearance'])
  70 + create(RoleAssignment, :accessor => admin_user.person, :role => admin_role, :resource => env) unless admin_user.person.role_assignments.map{|ra|[ra.role, ra.accessor, ra.resource]}.include?([admin_role, admin_user, env])
  71 + admin_user.login
  72 + end
  73 +
  74 + def create_environment(domainname)
  75 + environment = fast_create(Environment)
  76 + fast_create(Domain, :name => domainname, :owner_type => 'Environment', :owner_id => environment.id)
  77 + environment
  78 + end
  79 +
  80 + # Old version of create user. Use it if you need to create an user for
  81 + # testing that passes through the actual user creation process.
  82 + #
  83 + # Be aware that this is slow, though.
  84 + def create_user_full(name = nil, options = {}, person_options = {})
  85 + name ||= 'user' + factory_num_seq.to_s
  86 + data = {
  87 + :login => name,
  88 + :email => name + '@noosfero.org',
  89 + :password => name.underscore,
  90 + :password_confirmation => name.underscore
  91 + }.merge(options)
  92 + user = build(User, data)
  93 + user.person_data = person_options
  94 + user.save!
  95 + user
  96 + end
  97 +
  98 + def person_data
  99 + {}
  100 + end
  101 +
  102 + # This method knows way too much about the model. But since creating an
  103 + # actual user is really expensive, for tests we need a fast alternative.
  104 + def create_user(name = nil, options = {}, person_options = {})
  105 + name ||= 'user' + factory_num_seq.to_s
  106 + environment_id = options.delete(:environment_id) || (options.delete(:environment) || Environment.default).id
  107 +
  108 + password = options.delete(:password)
  109 + password_confirmation = options.delete(:password_confirmation)
  110 + raise build(Exception, "Passwords don't match") if (password && password_confirmation && password != password_confirmation)
  111 + crypted_password = (password || name).crypt('xy')
  112 +
  113 + data = {
  114 + :login => name,
  115 + :email => name + '@noosfero.org',
  116 + :crypted_password => crypted_password,
  117 + :password_type => 'crypt',
  118 + :salt => 'xy',
  119 + :environment_id => environment_id,
  120 + }.merge(options)
  121 + user = fast_insert_with_timestamps(User, data)
  122 + person = fast_insert_with_timestamps(Person, { :type => 'Person', :identifier => name, :name => name, :user_id => user.id, :environment_id => environment_id }.merge(person_options))
  123 + homepage = fast_insert_with_timestamps(TextileArticle, { :type => 'TextileArticle', :name => 'homepage', :slug => 'homepage', :path => 'homepage', :profile_id => person.id })
  124 + fast_update(person, {:home_page_id => homepage.id})
  125 + box = fast_insert(Box, { :owner_type => "Profile", :owner_id => person.id, :position => 1})
  126 + block = fast_insert(Block, { :box_id => box.id, :type => 'MainBlock', :position => 0})
  127 + user
  128 + end
  129 +
  130 + def fast_insert(klass, data)
  131 + names = data.keys
  132 + values = names.map {|k| ActiveRecord::Base.send(:sanitize_sql_array, ['?', data[k]]) }
  133 + sql = 'insert into %s(%s) values (%s)' % [klass.table_name, names.join(','), values.join(',')]
  134 + klass.connection.execute(sql)
  135 + klass.last(:order => 'id')
  136 + end
  137 +
  138 + def fast_insert_with_timestamps(klass, data)
  139 + now = Time.now
  140 + fast_insert(klass, { :created_at => now, :updated_at => now}.merge(data))
  141 + end
  142 +
  143 + def fast_update(obj, data)
  144 + obj.class.connection.execute('update %s set %s where id = %d' % [obj.class.table_name, obj.class.send(:sanitize_sql_for_assignment, data), obj.id])
  145 + end
  146 +
  147 + def give_permission(user, permission, target)
  148 + user = Person.find_by_identifier(user) if user.kind_of?(String)
  149 + target ||= user
  150 + i = 0
  151 + while Role.find_by_name('test_role' + i.to_s)
  152 + i+=1
  153 + end
  154 +
  155 + role = create(Role, :name => 'test_role' + i.to_s, :permissions => [permission])
  156 + assert user.add_role(role, target)
  157 + assert user.has_permission?(permission, target)
  158 + user
  159 + end
  160 +
  161 + def create_user_with_permission(name, permission, target= nil)
  162 + user = create_user(name).person
  163 + give_permission(user, permission, target)
  164 + end
  165 +
  166 +
  167 + protected
  168 +
  169 + def factory_num_seq
  170 + Noosfero::Factory.num_seq
  171 + end
  172 +
  173 + ###############################################
  174 + # Environment
  175 + ###############################################
  176 +
  177 + def defaults_for_environment
  178 + seq = factory_num_seq
  179 + {
  180 + :name => "Environment %d" % seq,
  181 + :contact_email => "environment%d@example.com" % seq
  182 + }
  183 + end
  184 +
  185 + ###############################################
  186 + # Enterprise
  187 + ###############################################
  188 +
  189 + def defaults_for_enterprise
  190 + n = factory_num_seq.to_s
  191 + defaults_for_profile.merge({ :identifier => "enterprise-" + n, :name => 'Enterprise ' + n })
  192 + end
  193 +
  194 + ###############################################
  195 + # Community
  196 + ###############################################
  197 +
  198 + def defaults_for_community
  199 + n = factory_num_seq.to_s
  200 + defaults_for_profile.merge({ :identifier => "community-" + n, :name => 'Community ' + n })
  201 + end
  202 +
  203 + ###############################################
  204 + # Person
  205 + ###############################################
  206 +
  207 + def defaults_for_person
  208 + n = factory_num_seq.to_s
  209 + defaults_for_profile.merge({ :identifier => "person-" + n, :name => 'Person ' + n, :created_at => DateTime.now })
  210 + end
  211 +
  212 + ###############################################
  213 + # Profile
  214 + ###############################################
  215 +
  216 + def defaults_for_profile
  217 + n = factory_num_seq.to_s
  218 + { :public_profile => true, :identifier => 'profile-' + n, :name => 'Profile ' + n, :environment_id => 1 }
  219 + end
  220 +
  221 + ###############################################
  222 + # Organization
  223 + ###############################################
  224 +
  225 + def defaults_for_organization
  226 + n = factory_num_seq.to_s
  227 + defaults_for_profile.merge({:identifier => 'organization-' + n, :name => 'Organization ' + n})
  228 + end
  229 +
  230 + ###############################################
  231 + # Article (and friends)
  232 + ###############################################
  233 +
  234 + def defaults_for_article
  235 + name = 'My article ' + factory_num_seq.to_s
  236 + { :name => name, :slug => name.to_slug, :path => name.to_slug }
  237 + end
  238 +
  239 + alias :defaults_for_text_article :defaults_for_article
  240 + alias :defaults_for_textile_article :defaults_for_article
  241 + alias :defaults_for_tiny_mce_article :defaults_for_article
  242 + alias :defaults_for_rss_feed :defaults_for_article
  243 + alias :defaults_for_published_article :defaults_for_article
  244 + alias :defaults_for_folder :defaults_for_article
  245 +
  246 + ###############################################
  247 + # Event
  248 + ###############################################
  249 +
  250 + def defaults_for_event
  251 + num = factory_num_seq.to_s
  252 + {
  253 + :name => 'My event ' + num,
  254 + :slug => 'my-event-' + num,
  255 + :path => '/my-event-' + num,
  256 + :start_date => Date.today
  257 + }
  258 + end
  259 +
  260 + ###############################################
  261 + # UploadedFile
  262 + ###############################################
  263 +
  264 + def defaults_for_uploaded_file
  265 + name = 'My uploaded file ' + factory_num_seq.to_s
  266 + { :name => name, :abstract => name }
  267 + end
  268 +
  269 + ###############################################
  270 + # Blog
  271 + ###############################################
  272 + def defaults_for_blog
  273 + name = 'My blog ' + factory_num_seq.to_s
  274 + { :name => name, :slug => name.to_slug, :path => name.to_slug }
  275 + end
  276 +
  277 + def create_blog
  278 + profile = create(Profile, :identifier => 'testuser' + factory_num_seq.to_s, :name => 'Test user')
  279 + create(Blog, :name => 'blog', :profile => profile)
  280 + end
  281 +
  282 + ###############################################
  283 + # ExternalFeed
  284 + ###############################################
  285 + def defaults_for_external_feed
  286 + { :address => Rails.root.join('test', 'fixtures', 'files', 'feed.xml'), :blog_id => factory_num_seq }
  287 + end
  288 +
  289 + def create_external_feed(attrs = {})
  290 + feed = build(:external_feed, attrs)
  291 + feed.blog = create_blog
  292 + feed.save!
  293 + feed
  294 + end
  295 +
  296 + ###############################################
  297 + # FeedReaderBlock
  298 + ###############################################
  299 + def defaults_for_feed_reader_block
  300 + { :address => Rails.root.join('test/fixtures/files/feed.xml') }
  301 + end
  302 +
  303 + ###############################################
  304 + # Domain
  305 + ###############################################
  306 + def defaults_for_domain
  307 + { :name => 'example' + factory_num_seq.to_s + '.com' }
  308 + end
  309 +
  310 + ###############################################
  311 + # Category
  312 + ###############################################
  313 + def defaults_for_category
  314 + name = 'category' + factory_num_seq.to_s
  315 + { :environment_id => 1, :name => name, :slug => name.to_slug, :path => name.to_slug }
  316 + end
  317 +
  318 + alias :defaults_for_region :defaults_for_category
  319 + alias :defaults_for_product_category :defaults_for_category
  320 +
  321 + ###############################################
  322 + # Box
  323 + ###############################################
  324 + def defaults_for_box
  325 + { }
  326 + end
  327 +
  328 + ###############################################
  329 + # Block
  330 + ###############################################
  331 + def defaults_for_block
  332 + { }
  333 + end
  334 +
  335 + alias :defaults_for_blog_archives_block :defaults_for_block
  336 + alias :defaults_for_profile_list_block :defaults_for_block
  337 +
  338 + ###############################################
  339 + # Task
  340 + ###############################################
  341 + def defaults_for_task
  342 + { :code => "task_for_test_#{factory_num_seq.to_s}" }
  343 + end
  344 +
  345 + alias :defaults_for_add_friend :defaults_for_task
  346 + alias :defaults_for_add_member :defaults_for_task
  347 + alias :defaults_for_create_community :defaults_for_task
  348 + alias :defaults_for_email_activation :defaults_for_task
  349 +
  350 + ###############################################
  351 + # Product
  352 + ###############################################
  353 +
  354 + def defaults_for_product
  355 + { :name => 'Product ' + factory_num_seq.to_s }
  356 + end
  357 +
  358 + ###############################################
  359 + # Input
  360 + ###############################################
  361 +
  362 + def defaults_for_input
  363 + { }
  364 + end
  365 +
  366 + ###############################################
  367 + # Contact
  368 + ###############################################
  369 +
  370 + def defaults_for_contact
  371 + { :subject => 'hello there', :message => 'here I come to SPAM you' }
  372 + end
  373 +
  374 + ###############################################
  375 + # Qualifier
  376 + ###############################################
  377 +
  378 + def defaults_for_qualifier
  379 + { :name => 'Qualifier ' + factory_num_seq.to_s, :environment_id => 1 }
  380 + end
  381 +
  382 + ###############################################
  383 + # Certifier
  384 + ###############################################
  385 +
  386 + def defaults_for_certifier
  387 + defaults_for_qualifier.merge({ :name => 'Certifier ' + factory_num_seq.to_s })
  388 + end
  389 +
  390 + ###############################################
  391 + # Scrap
  392 + ###############################################
  393 +
  394 + def defaults_for_scrap(params = {})
  395 + { :content => 'some content ', :sender_id => 1, :receiver_id => 1, :created_at => DateTime.now }.merge(params)
  396 + end
  397 +
  398 + ###############################################
  399 + # ActionTrackerNotification
  400 + ###############################################
  401 +
  402 + def defaults_for_action_tracker_notification(params = {})
  403 + { :action_tracker_id => 1, :profile_id => 1 }.merge(params)
  404 + end
  405 +
  406 + ###############################################
  407 + # ActionTracker
  408 + ###############################################
  409 +
  410 + def defaults_for_action_tracker_record(params = {})
  411 + { :created_at => DateTime.now, :verb => 'add_member_in_community', :user_type => 'Profile', :user_id => 1 }.merge(params)
  412 + end
  413 +
  414 + ###############################################
  415 + # Friendship
  416 + ###############################################
  417 +
  418 + def defaults_for_friendship(params = {})
  419 + { :created_at => DateTime.now, :person_id => 1, :friend_id => 2 }.merge(params)
  420 + end
  421 +
  422 + ###############################################
  423 + # RoleAssignment
  424 + ###############################################
  425 +
  426 + def defaults_for_role_assignment(params = {})
  427 + { :role_id => 1, :accessor_id => 1, :accessor_type => 'Profile', :resource_id => 2, :resource_type => 'Profile' }.merge(params)
  428 + end
  429 +
  430 + ###############################################
  431 + # User
  432 + ###############################################
  433 +
  434 + def defaults_for_user(params = {})
  435 + username = "user_#{rand(1000)}"
  436 + { :login => username, :email => username + '@noosfero.colivre', :crypted_password => 'test'}.merge(params)
  437 + end
  438 +
  439 + ###############################################
  440 + # Forum
  441 + ###############################################
  442 +
  443 + def defaults_for_forum(params = {})
  444 + name = "forum_#{rand(1000)}"
  445 + { :profile_id => 1, :path => name.to_slug, :name => name, :slug => name.to_slug }.merge(params)
  446 + end
  447 +
  448 + ###############################################
  449 + # Gallery
  450 + ###############################################
  451 +
  452 + def defaults_for_gallery(params = {})
  453 + name = "gallery_#{rand(1000)}"
  454 + { :profile_id => 1, :path => name.to_slug, :name => name, :slug => name.to_slug }.merge(params)
  455 + end
  456 +
  457 + def defaults_for_suggest_article
  458 + { :name => 'Sender', :email => 'sender@example.com', :article => {:name => 'Some title', :body => 'some body text', :abstract => 'some abstract text'}}
  459 + end
  460 +
  461 + def defaults_for_comment(params = {})
  462 + name = "comment_#{rand(1000)}"
  463 + { :title => name, :body => "my own comment", :source_id => 1, :source_type => 'Article' }.merge(params)
  464 + end
  465 +
  466 + ###############################################
  467 + # Unit
  468 + ###############################################
  469 +
  470 + def defaults_for_unit
  471 + { :singular => 'Litre', :plural => 'Litres', :environment_id => 1 }
  472 + end
  473 +
  474 + ###############################################
  475 + # Production Cost
  476 + ###############################################
  477 +
  478 + def defaults_for_production_cost
  479 + { :name => 'Production cost ' + factory_num_seq.to_s }
  480 + end
  481 +
  482 + ###############################################
  483 + # National Region
  484 + ###############################################
  485 +
  486 + def defaults_for_national_region
  487 + { :name => 'National region ' + factory_num_seq.to_s }
  488 + end
  489 +
  490 + def defaults_for_license
  491 + name = "License #{rand(1000)}"
  492 + slug = name.to_slug
  493 + { :name => name, :url => "#{slug}.org", :slug => slug, :environment_id => 1}
  494 + end
  495 +
  496 +end
test/support/integration_test.rb 0 → 100644
@@ -0,0 +1,23 @@ @@ -0,0 +1,23 @@
  1 +
  2 +class ActionDispatch::IntegrationTest
  3 +
  4 + extend Test::Should
  5 +
  6 + def assert_can_login
  7 + assert_tag :tag => 'a', :attributes => { :id => 'link_login' }
  8 + end
  9 +
  10 + def assert_can_signup
  11 + assert_tag :tag => 'a', :attributes => { :href => '/account/signup'}
  12 + end
  13 +
  14 + def login(username, password)
  15 + ActionDispatch::Integration::Session.any_instance.stubs(:https?).returns(true)
  16 +
  17 + post '/account/login', :user => { :login => username, :password => password }
  18 + assert_response :redirect
  19 + follow_redirect!
  20 + assert_not_equal '/account/login', path
  21 + end
  22 +
  23 +end
test/support/noosfero_doc_test.rb 0 → 100644
@@ -0,0 +1,50 @@ @@ -0,0 +1,50 @@
  1 +# encoding: UTF-8
  2 +require 'mocha'
  3 +
  4 +module Noosfero::DocTest
  5 +
  6 + unless defined?(ROOT)
  7 + ROOT = Rails.root.join("test", "tmp", "doc")
  8 + end
  9 +
  10 + def create_doc(section, topic, language, title, body = nil)
  11 + dir = File.join(ROOT, section)
  12 + FileUtils.mkdir_p(dir)
  13 + File.open("#{dir}/#{topic}.#{language}.xhtml", "w") do |f|
  14 + f.puts "<h1>#{title}</h1>"
  15 + f.puts body
  16 + end
  17 + end
  18 +
  19 + def setup_doc_test
  20 + FileUtils.mkdir_p(ROOT)
  21 +
  22 + # root
  23 + create_doc('', 'index', 'en', 'Noosfero online manual')
  24 + create_doc('', 'toc', 'en', '', '<ul><li><a href="/doc/user">User features</a></li><li><a href="/doc/cms">Content Management</a></li></ul>')
  25 + # cms
  26 + create_doc('cms', 'index', 'en', 'Content Management')
  27 + create_doc('cms', 'index', 'pt', 'Gerenciamento de conteúdo')
  28 + create_doc('cms', 'toc', 'en', '')
  29 + create_doc('cms', 'toc', 'pt', '')
  30 + create_doc('cms', 'adding-pictures', 'en', 'Adding pictures to gallery')
  31 + create_doc('cms', 'adding-pictures', 'pt', 'Adicionando fotos na galeria')
  32 + create_doc('cms', 'creating-a-blog', 'en', 'Creating a blog')
  33 + create_doc('cms', 'creating-a-blog', 'pt', 'Criando um blog')
  34 + # user
  35 + create_doc('user', 'index', 'en', 'User features')
  36 + create_doc('user', 'index', 'pt', 'Funcionalidades de Usuário')
  37 + create_doc('user', 'toc', 'en', '<ul><li><a href="/doc/user/commenting-articles">Commenting articles</a></li><li><a href="/doc/user/acceptins-friends">Accepting friends</a></li></ul>')
  38 + create_doc('user', 'toc', 'pt', '')
  39 + create_doc('user', 'accepting-friends', 'en', 'Accepting friends')
  40 + create_doc('user', 'accepting-friends', 'pt', 'Aceitando amigos')
  41 + create_doc('user', 'commenting-articles', 'en', 'Commenting articles', 'How to access')
  42 + create_doc('user', 'commenting-articles', 'pt', 'Comentando artigos')
  43 +
  44 + DocSection.stubs(:root_dir).returns(ROOT)
  45 + end
  46 +
  47 + def tear_down_doc_test
  48 + FileUtils.rm_rf(ROOT)
  49 + end
  50 +end
test/support/noosfero_test_helper.rb 0 → 100644
@@ -0,0 +1,70 @@ @@ -0,0 +1,70 @@
  1 +module NoosferoTestHelper
  2 +
  3 + def link_to(content, url, options = {})
  4 + "<a href='#{url.inspect}'>#{content}</a>"
  5 + end
  6 +
  7 + def content_tag(tag, content, options = {})
  8 + tag_attr = options.blank? ? '' : ' ' + options.collect{ |o| "#{o[0]}=\"#{o[1]}\"" }.join(' ')
  9 + "<#{tag}#{tag_attr}>#{content}</#{tag}>"
  10 + end
  11 +
  12 + def submit_tag(content, options = {})
  13 + content
  14 + end
  15 +
  16 + def remote_function(options = {})
  17 + ''
  18 + end
  19 +
  20 + def tag(tag, args = {})
  21 + attrs = args.map{|k,v| "#{k}='#{v}'"}.join(' ')
  22 + "<#{tag} #{attrs} />"
  23 + end
  24 +
  25 + def options_from_collection_for_select(collection, value_method, content_method)
  26 + "<option value='fake value'>fake content</option>"
  27 + end
  28 +
  29 + def select_tag(id, collection, options = {})
  30 + "<select id='#{id}'>fake content</select>"
  31 + end
  32 +
  33 + def options_for_select(collection, selected = nil)
  34 + collection.map{|item| "<option value='#{item[1]}'>#{item[0]}</option>"}.join("\n")
  35 + end
  36 +
  37 + def params
  38 + {}
  39 + end
  40 +
  41 + def ui_icon(icon)
  42 + icon
  43 + end
  44 +
  45 + def will_paginate(arg1, arg2)
  46 + end
  47 +
  48 + def javascript_tag(any)
  49 + ''
  50 + end
  51 + def javascript_include_tag(any)
  52 + ''
  53 + end
  54 + def check_box_tag(name, value = 1, checked = false, options = {})
  55 + name
  56 + end
  57 + def stylesheet_link_tag(arg)
  58 + arg
  59 + end
  60 +
  61 + def strip_tags(html)
  62 + html.gsub(/<[^>]+>/, '')
  63 + end
  64 +
  65 + def icon_for_article(article)
  66 + ''
  67 + end
  68 +
  69 +end
  70 +
test/support/should.rb 0 → 100644
@@ -0,0 +1,27 @@ @@ -0,0 +1,27 @@
  1 +
  2 +module Test
  3 +
  4 + module Should
  5 +
  6 + def should name, &block
  7 + @shoulds ||= []
  8 +
  9 + destname = 'test_should_' + name.gsub(/[^a-zA-z0-9]+/, '_')
  10 + if @shoulds.include?(destname)
  11 + raise "there is already a test named \"#{destname}\""
  12 + end
  13 +
  14 + @shoulds << destname
  15 + if block_given?
  16 + self.send(:define_method, destname, &block)
  17 + else
  18 + self.send(:define_method, destname) do
  19 + flunk 'pending: should ' + name
  20 + end
  21 + end
  22 +
  23 + end
  24 +
  25 + end
  26 +
  27 +end
test/test_helper.rb
@@ -9,10 +9,14 @@ require &#39;mocha/mini_test&#39; @@ -9,10 +9,14 @@ require &#39;mocha/mini_test&#39;
9 require "minitest/reporters" 9 require "minitest/reporters"
10 Minitest::Reporters.use! Minitest::Reporters::ProgressReporter.new, ENV, Minitest.backtrace_filter 10 Minitest::Reporters.use! Minitest::Reporters::ProgressReporter.new, ENV, Minitest.backtrace_filter
11 11
12 -require 'authenticated_test_helper'  
13 -require_relative 'factories'  
14 -require_relative 'noosfero_doc_test'  
15 -require_relative 'action_tracker_test_helper' 12 +require_relative 'support/should'
  13 +require_relative 'support/factories'
  14 +require_relative 'support/integration_test'
  15 +require_relative 'support/controller_test_case'
  16 +require_relative 'support/authenticated_test_helper'
  17 +require_relative 'support/action_tracker_test_helper'
  18 +require_relative 'support/noosfero_doc_test'
  19 +require_relative 'support/noosfero_test_helper'
16 20
17 FileUtils.rm_rf(Rails.root.join('index', 'test')) 21 FileUtils.rm_rf(Rails.root.join('index', 'test'))
18 22
@@ -53,6 +57,8 @@ class ActiveSupport::TestCase @@ -53,6 +57,8 @@ class ActiveSupport::TestCase
53 57
54 include AuthenticatedTestHelper 58 include AuthenticatedTestHelper
55 59
  60 + extend Test::Should
  61 +
56 fixtures :environments, :roles 62 fixtures :environments, :roles
57 63
58 def self.all_fixtures 64 def self.all_fixtures
@@ -61,25 +67,6 @@ class ActiveSupport::TestCase @@ -61,25 +67,6 @@ class ActiveSupport::TestCase
61 end 67 end
62 end 68 end
63 69
64 - def self.should(name, &block)  
65 - @shoulds ||= []  
66 -  
67 - destname = 'test_should_' + name.gsub(/[^a-zA-z0-9]+/, '_')  
68 - if @shoulds.include?(destname)  
69 - raise "there is already a test named \"#{destname}\""  
70 - end  
71 -  
72 - @shoulds << destname  
73 - if block_given?  
74 - self.send(:define_method, destname, &block)  
75 - else  
76 - self.send(:define_method, destname) do  
77 - flunk 'pending: should ' + name  
78 - end  
79 - end  
80 -  
81 - end  
82 -  
83 # deprecated on minitest 70 # deprecated on minitest
84 def assert_block message=nil 71 def assert_block message=nil
85 assert message || 'yield' do 72 assert message || 'yield' do
@@ -214,108 +201,3 @@ class ActiveSupport::TestCase @@ -214,108 +201,3 @@ class ActiveSupport::TestCase
214 201
215 end 202 end
216 203
217 -module NoosferoTestHelper  
218 - def link_to(content, url, options = {})  
219 - "<a href='#{url.inspect}'>#{content}</a>"  
220 - end  
221 -  
222 - def content_tag(tag, content, options = {})  
223 - tag_attr = options.blank? ? '' : ' ' + options.collect{ |o| "#{o[0]}=\"#{o[1]}\"" }.join(' ')  
224 - "<#{tag}#{tag_attr}>#{content}</#{tag}>"  
225 - end  
226 -  
227 - def submit_tag(content, options = {})  
228 - content  
229 - end  
230 -  
231 - def remote_function(options = {})  
232 - ''  
233 - end  
234 -  
235 - def tag(tag, args = {})  
236 - attrs = args.map{|k,v| "#{k}='#{v}'"}.join(' ')  
237 - "<#{tag} #{attrs} />"  
238 - end  
239 -  
240 - def options_from_collection_for_select(collection, value_method, content_method)  
241 - "<option value='fake value'>fake content</option>"  
242 - end  
243 -  
244 - def select_tag(id, collection, options = {})  
245 - "<select id='#{id}'>fake content</select>"  
246 - end  
247 -  
248 - def options_for_select(collection, selected = nil)  
249 - collection.map{|item| "<option value='#{item[1]}'>#{item[0]}</option>"}.join("\n")  
250 - end  
251 -  
252 - def params  
253 - {}  
254 - end  
255 -  
256 - def ui_icon(icon)  
257 - icon  
258 - end  
259 -  
260 - def will_paginate(arg1, arg2)  
261 - end  
262 -  
263 - def javascript_tag(any)  
264 - ''  
265 - end  
266 - def javascript_include_tag(any)  
267 - ''  
268 - end  
269 - def check_box_tag(name, value = 1, checked = false, options = {})  
270 - name  
271 - end  
272 - def stylesheet_link_tag(arg)  
273 - arg  
274 - end  
275 -  
276 - def strip_tags(html)  
277 - html.gsub(/<[^>]+>/, '')  
278 - end  
279 -  
280 - def icon_for_article(article)  
281 - ''  
282 - end  
283 -  
284 -end  
285 -  
286 -class ActionController::TestCase  
287 -  
288 - class_attribute :default_params  
289 - self.default_params = {}  
290 -  
291 - def get path, parameters = nil, session = nil, flash = nil  
292 - super path, if parameters then self.default_params.merge parameters else self.default_params end, session, flash  
293 - end  
294 -  
295 - def post path, parameters = nil, session = nil, flash = nil  
296 - super path, if parameters then self.default_params.merge parameters else self.default_params end, session, flash  
297 - end  
298 -  
299 -end  
300 -  
301 -class ActionController::IntegrationTest  
302 - def assert_can_login  
303 - assert_tag :tag => 'a', :attributes => { :id => 'link_login' }  
304 - end  
305 -  
306 - def assert_can_signup  
307 - assert_tag :tag => 'a', :attributes => { :href => '/account/signup'}  
308 - end  
309 -  
310 - def login(username, password)  
311 - ActionController::Integration::Session.any_instance.stubs(:https?).returns(true)  
312 -  
313 - post '/account/login', :user => { :login => username, :password => password }  
314 - assert_response :redirect  
315 - follow_redirect!  
316 - assert_not_equal '/account/login', path  
317 - end  
318 -  
319 -end  
320 -  
321 -Profile