corey-facebooker 1.0.28.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (126) hide show
  1. data/CHANGELOG.rdoc +17 -0
  2. data/COPYING.rdoc +19 -0
  3. data/README.rdoc +104 -0
  4. data/Rakefile +86 -0
  5. data/TODO.rdoc +4 -0
  6. data/generators/facebook/facebook_generator.rb +14 -0
  7. data/generators/facebook/templates/config/facebooker.yml +49 -0
  8. data/generators/facebook/templates/public/javascripts/facebooker.js +99 -0
  9. data/generators/facebook_controller/USAGE +33 -0
  10. data/generators/facebook_controller/facebook_controller_generator.rb +40 -0
  11. data/generators/facebook_controller/templates/controller.rb +7 -0
  12. data/generators/facebook_controller/templates/functional_test.rb +11 -0
  13. data/generators/facebook_controller/templates/helper.rb +2 -0
  14. data/generators/facebook_controller/templates/view.fbml.erb +2 -0
  15. data/generators/facebook_controller/templates/view.html.erb +2 -0
  16. data/generators/facebook_publisher/facebook_publisher_generator.rb +14 -0
  17. data/generators/facebook_publisher/templates/create_facebook_templates.rb +15 -0
  18. data/generators/facebook_publisher/templates/publisher.rb +3 -0
  19. data/generators/facebook_scaffold/USAGE +27 -0
  20. data/generators/facebook_scaffold/facebook_scaffold_generator.rb +118 -0
  21. data/generators/facebook_scaffold/templates/controller.rb +93 -0
  22. data/generators/facebook_scaffold/templates/facebook_style.css +2579 -0
  23. data/generators/facebook_scaffold/templates/functional_test.rb +89 -0
  24. data/generators/facebook_scaffold/templates/helper.rb +2 -0
  25. data/generators/facebook_scaffold/templates/layout.fbml.erb +6 -0
  26. data/generators/facebook_scaffold/templates/layout.html.erb +17 -0
  27. data/generators/facebook_scaffold/templates/style.css +74 -0
  28. data/generators/facebook_scaffold/templates/view_edit.fbml.erb +13 -0
  29. data/generators/facebook_scaffold/templates/view_edit.html.erb +18 -0
  30. data/generators/facebook_scaffold/templates/view_index.fbml.erb +24 -0
  31. data/generators/facebook_scaffold/templates/view_index.html.erb +24 -0
  32. data/generators/facebook_scaffold/templates/view_new.fbml.erb +12 -0
  33. data/generators/facebook_scaffold/templates/view_new.html.erb +17 -0
  34. data/generators/facebook_scaffold/templates/view_show.fbml.erb +10 -0
  35. data/generators/facebook_scaffold/templates/view_show.html.erb +10 -0
  36. data/generators/publisher/publisher_generator.rb +14 -0
  37. data/generators/xd_receiver/templates/xd_receiver.html +10 -0
  38. data/generators/xd_receiver/xd_receiver_generator.rb +9 -0
  39. data/init.rb +23 -0
  40. data/install.rb +12 -0
  41. data/lib/facebooker.rb +181 -0
  42. data/lib/facebooker/adapters/adapter_base.rb +90 -0
  43. data/lib/facebooker/adapters/bebo_adapter.rb +75 -0
  44. data/lib/facebooker/adapters/facebook_adapter.rb +52 -0
  45. data/lib/facebooker/admin.rb +42 -0
  46. data/lib/facebooker/batch_request.rb +44 -0
  47. data/lib/facebooker/data.rb +57 -0
  48. data/lib/facebooker/feed.rb +78 -0
  49. data/lib/facebooker/logging.rb +51 -0
  50. data/lib/facebooker/mobile.rb +20 -0
  51. data/lib/facebooker/mock/service.rb +50 -0
  52. data/lib/facebooker/mock/session.rb +18 -0
  53. data/lib/facebooker/model.rb +137 -0
  54. data/lib/facebooker/models/affiliation.rb +10 -0
  55. data/lib/facebooker/models/album.rb +11 -0
  56. data/lib/facebooker/models/applicationproperties.rb +39 -0
  57. data/lib/facebooker/models/applicationrestrictions.rb +10 -0
  58. data/lib/facebooker/models/cookie.rb +10 -0
  59. data/lib/facebooker/models/education_info.rb +11 -0
  60. data/lib/facebooker/models/event.rb +28 -0
  61. data/lib/facebooker/models/friend_list.rb +16 -0
  62. data/lib/facebooker/models/group.rb +36 -0
  63. data/lib/facebooker/models/info_item.rb +10 -0
  64. data/lib/facebooker/models/info_section.rb +10 -0
  65. data/lib/facebooker/models/location.rb +8 -0
  66. data/lib/facebooker/models/notifications.rb +17 -0
  67. data/lib/facebooker/models/page.rb +27 -0
  68. data/lib/facebooker/models/photo.rb +12 -0
  69. data/lib/facebooker/models/tag.rb +12 -0
  70. data/lib/facebooker/models/user.rb +471 -0
  71. data/lib/facebooker/models/video.rb +9 -0
  72. data/lib/facebooker/models/work_info.rb +9 -0
  73. data/lib/facebooker/parser.rb +610 -0
  74. data/lib/facebooker/rails/controller.rb +307 -0
  75. data/lib/facebooker/rails/cucumber.rb +28 -0
  76. data/lib/facebooker/rails/cucumber/world.rb +46 -0
  77. data/lib/facebooker/rails/extensions/action_controller.rb +48 -0
  78. data/lib/facebooker/rails/extensions/rack_setup.rb +2 -0
  79. data/lib/facebooker/rails/extensions/routing.rb +15 -0
  80. data/lib/facebooker/rails/facebook_form_builder.rb +112 -0
  81. data/lib/facebooker/rails/facebook_pretty_errors.rb +22 -0
  82. data/lib/facebooker/rails/facebook_request_fix.rb +24 -0
  83. data/lib/facebooker/rails/facebook_session_handling.rb +69 -0
  84. data/lib/facebooker/rails/facebook_url_helper.rb +192 -0
  85. data/lib/facebooker/rails/facebook_url_rewriting.rb +52 -0
  86. data/lib/facebooker/rails/helpers.rb +772 -0
  87. data/lib/facebooker/rails/helpers/fb_connect.rb +99 -0
  88. data/lib/facebooker/rails/integration_session.rb +38 -0
  89. data/lib/facebooker/rails/profile_publisher_extensions.rb +42 -0
  90. data/lib/facebooker/rails/publisher.rb +530 -0
  91. data/lib/facebooker/rails/routing.rb +49 -0
  92. data/lib/facebooker/rails/test_helpers.rb +68 -0
  93. data/lib/facebooker/rails/utilities.rb +22 -0
  94. data/lib/facebooker/server_cache.rb +24 -0
  95. data/lib/facebooker/service.rb +94 -0
  96. data/lib/facebooker/session.rb +596 -0
  97. data/lib/facebooker/version.rb +9 -0
  98. data/lib/net/http_multipart_post.rb +123 -0
  99. data/lib/rack/facebook.rb +77 -0
  100. data/lib/tasks/facebooker.rake +18 -0
  101. data/lib/tasks/tunnel.rake +46 -0
  102. data/rails/init.rb +1 -0
  103. data/setup.rb +1585 -0
  104. data/templates/layout.erb +24 -0
  105. data/test/facebooker/adapters_test.rb +96 -0
  106. data/test/facebooker/admin_test.rb +102 -0
  107. data/test/facebooker/batch_request_test.rb +83 -0
  108. data/test/facebooker/data_test.rb +86 -0
  109. data/test/facebooker/logging_test.rb +43 -0
  110. data/test/facebooker/mobile_test.rb +45 -0
  111. data/test/facebooker/model_test.rb +123 -0
  112. data/test/facebooker/models/event_test.rb +15 -0
  113. data/test/facebooker/models/user_test.rb +331 -0
  114. data/test/facebooker/rails/publisher_test.rb +468 -0
  115. data/test/facebooker/rails_integration_test.rb +1349 -0
  116. data/test/facebooker/server_cache_test.rb +44 -0
  117. data/test/facebooker/session_test.rb +614 -0
  118. data/test/facebooker_test.rb +925 -0
  119. data/test/fixtures/multipart_post_body_with_only_parameters.txt +33 -0
  120. data/test/fixtures/multipart_post_body_with_single_file.txt +38 -0
  121. data/test/fixtures/multipart_post_body_with_single_file_that_has_nil_key.txt +38 -0
  122. data/test/net/http_multipart_post_test.rb +52 -0
  123. data/test/rack/facebook_test.rb +62 -0
  124. data/test/rails_test_helper.rb +13 -0
  125. data/test/test_helper.rb +66 -0
  126. metadata +219 -0
@@ -0,0 +1,1349 @@
1
+ require File.expand_path(File.dirname(__FILE__) + '/../rails_test_helper')
2
+
3
+ ActionController::Routing::Routes.draw do |map|
4
+ map.connect '', :controller=>"facebook",:conditions=>{:canvas=>true}
5
+ map.connect '', :controller=>"plain_old_rails"
6
+ map.resources :comments, :controller=>"plain_old_rails"
7
+ map.connect 'require_auth/:action', :controller => "controller_which_requires_facebook_authentication"
8
+ map.connect 'require_install/:action', :controller => "controller_which_requires_application_installation"
9
+ map.connect ':controller/:action/:id', :controller => "plain_old_rails"
10
+ end
11
+
12
+ module FBConnectTestHelpers
13
+ def setup_fb_connect_cookies(params=cookie_hash_for_auth)
14
+ params.each {|k,v| @request.cookies[ENV['FACEBOOK_API_KEY']+k] = CGI::Cookie.new(ENV['FACEBOOK_API_KEY']+k,v)}
15
+ end
16
+
17
+ def expired_cookie_hash_for_auth
18
+ {"_ss" => "not_used", "_session_key"=> "whatever", "_user"=>"77777", "_expires"=>"#{1.day.ago.to_i}"}
19
+ end
20
+
21
+ def cookie_hash_for_auth
22
+ {"_ss" => "not_used", "_session_key"=> "whatever", "_user"=>"77777", "_expires"=>"#{1.day.from_now.to_i}"}
23
+ end
24
+ end
25
+ class NoisyController < ActionController::Base
26
+ include Facebooker::Rails::Controller
27
+ def rescue_action(e) raise e end
28
+ end
29
+
30
+
31
+ class ControllerWhichRequiresExtendedPermissions< NoisyController
32
+ ensure_authenticated_to_facebook
33
+ before_filter :ensure_has_status_update
34
+ before_filter :ensure_has_photo_upload
35
+ before_filter :ensure_has_video_upload
36
+ before_filter :ensure_has_create_listing
37
+ def index
38
+ render :text => 'score!'
39
+ end
40
+ end
41
+
42
+ class FBConnectController < NoisyController
43
+ before_filter :create_facebook_session
44
+ def index
45
+ render :text => 'score!'
46
+ end
47
+ end
48
+
49
+ class ControllerWhichRequiresFacebookAuthentication < NoisyController
50
+ ensure_authenticated_to_facebook
51
+ def index
52
+ render :text => 'score!'
53
+ end
54
+ def link_test
55
+ options = {}
56
+ options[:canvas] = true if params[:canvas] == true
57
+ options[:canvas] = false if params[:canvas] == false
58
+ render :text=>url_for(options)
59
+ end
60
+
61
+ def named_route_test
62
+ render :text=>comments_url()
63
+ end
64
+
65
+ def image_test
66
+ render :inline=>"<%=image_tag 'image.png'%>"
67
+ end
68
+
69
+ def fb_params_test
70
+ render :text=>facebook_params['user']
71
+ end
72
+
73
+ def publisher_test
74
+ if wants_interface?
75
+ render :text=>"interface"
76
+ else
77
+ render :text=>"not interface"
78
+ end
79
+ end
80
+
81
+ def publisher_test_interface
82
+ render_publisher_interface("This is a test",false,true)
83
+ end
84
+
85
+ def publisher_test_response
86
+ ua=Facebooker::Rails::Publisher::UserAction.new
87
+ ua.data = {:params=>true}
88
+ ua.template_name = "template_name"
89
+ ua.template_id = 1234
90
+ render_publisher_response(ua)
91
+ end
92
+
93
+ def publisher_test_error
94
+ render_publisher_error("Title","Body")
95
+ end
96
+
97
+ end
98
+ class ControllerWhichRequiresApplicationInstallation < NoisyController
99
+ ensure_application_is_installed_by_facebook_user
100
+ def index
101
+ render :text => 'installed!'
102
+ end
103
+ end
104
+ class FacebookController < ActionController::Base
105
+ def index
106
+ end
107
+ end
108
+
109
+ class PlainOldRailsController < ActionController::Base
110
+ def index
111
+ end
112
+ def link_test
113
+ options = {}
114
+ options[:canvas] = true if params[:canvas] == true
115
+ options[:canvas] = false if params[:canvas] == false
116
+ render :text => url_for(options)
117
+ end
118
+
119
+ def named_route_test
120
+ render :text=>comments_url()
121
+ end
122
+ def canvas_false_test
123
+ render :text=>comments_url(:canvas=>false)
124
+ end
125
+ def canvas_true_test
126
+ render :text=>comments_url(:canvas=>true)
127
+ end
128
+ end
129
+
130
+ class Test::Unit::TestCase
131
+ include Facebooker::Rails::TestHelpers
132
+ end
133
+
134
+
135
+ # you can't use asset_recognize, because it can't pass parameters in to the requests
136
+ class UrlRecognitionTests < Test::Unit::TestCase
137
+ def test_detects_in_canvas
138
+ if Rails.version < '2.3'
139
+ request = ActionController::TestRequest.new({"fb_sig_in_canvas"=>"1"}, {}, nil)
140
+ else
141
+ request = ActionController::TestRequest.new
142
+ request.query_parameters[:fb_sig_in_canvas] = "1"
143
+ end
144
+ request.path = "/"
145
+ ActionController::Routing::Routes.recognize(request)
146
+ assert_equal({"controller"=>"facebook","action"=>"index"},request.path_parameters)
147
+ end
148
+
149
+ def test_routes_when_not_in_canvas
150
+ if Rails.version < '2.3'
151
+ request = ActionController::TestRequest.new({}, {}, nil)
152
+ else
153
+ request = ActionController::TestRequest.new
154
+ end
155
+ request.path = "/"
156
+ ActionController::Routing::Routes.recognize(request)
157
+ assert_equal({"controller"=>"plain_old_rails","action"=>"index"},request.path_parameters)
158
+ end
159
+ end
160
+
161
+ class RailsIntegrationTestForFBConnect < Test::Unit::TestCase
162
+ include FBConnectTestHelpers
163
+
164
+ def setup
165
+ ENV['FACEBOOK_CANVAS_PATH'] ='facebook_app_name'
166
+ ENV['FACEBOOK_API_KEY'] = '1234567'
167
+ ENV['FACEBOOK_SECRET_KEY'] = '7654321'
168
+ @controller = FBConnectController.new
169
+ @request = ActionController::TestRequest.new
170
+ @response = ActionController::TestResponse.new
171
+ @controller.stubs(:verify_signature).returns(true)
172
+
173
+ end
174
+
175
+ def test_doesnt_set_cookie_but_facebook_session_is_available
176
+ setup_fb_connect_cookies
177
+ get :index
178
+ assert_not_nil @controller.facebook_session
179
+ assert_nil @response.cookies[:facebook_session]
180
+
181
+ end
182
+ end
183
+
184
+ class RailsIntegrationTestForNonFacebookControllers < Test::Unit::TestCase
185
+ def setup
186
+ ENV['FACEBOOK_CANVAS_PATH'] ='facebook_app_name'
187
+ ENV['FACEBOOK_API_KEY'] = '1234567'
188
+ ENV['FACEBOOK_SECRET_KEY'] = '7654321'
189
+ @controller = PlainOldRailsController.new
190
+ @request = ActionController::TestRequest.new
191
+ @response = ActionController::TestResponse.new
192
+ end
193
+
194
+ def test_url_for_links_to_callback_if_canvas_is_false_and_in_canvas
195
+ get :link_test
196
+ assert_match /test.host/,@response.body
197
+ end
198
+
199
+ def test_named_route_doesnt_include_canvas_path_when_not_in_canvas
200
+ get :named_route_test
201
+ assert_equal "http://test.host/comments",@response.body
202
+ end
203
+ def test_named_route_includes_canvas_path_when_in_canvas
204
+ get :named_route_test, facebook_params
205
+ assert_equal "http://apps.facebook.com/facebook_app_name/comments",@response.body
206
+ end
207
+
208
+ def test_named_route_doesnt_include_canvas_path_when_in_canvas_with_canvas_equals_false
209
+ get :canvas_false_test, facebook_params
210
+ assert_equal "http://test.host/comments",@response.body
211
+ end
212
+ def test_named_route_does_include_canvas_path_when_not_in_canvas_with_canvas_equals_true
213
+ get :canvas_true_test
214
+ assert_equal "http://apps.facebook.com/facebook_app_name/comments",@response.body
215
+ end
216
+
217
+ end
218
+
219
+ class RailsIntegrationTestForExtendedPermissions < Test::Unit::TestCase
220
+ def setup
221
+ ENV['FACEBOOK_API_KEY'] = '1234567'
222
+ ENV['FACEBOOK_SECRET_KEY'] = '7654321'
223
+ @controller = ControllerWhichRequiresExtendedPermissions.new
224
+ @request = ActionController::TestRequest.new
225
+ @response = ActionController::TestResponse.new
226
+ @controller.stubs(:verify_signature).returns(true)
227
+ end
228
+
229
+ def test_redirects_without_set_status
230
+ post :index, facebook_params
231
+ assert_response :success
232
+ assert_equal("<fb:redirect url=\"http://www.facebook.com/authorize.php?api_key=1234567&v=1.0&ext_perm=status_update\" />", @response.body)
233
+ end
234
+ def test_redirects_without_photo_upload
235
+ post :index, facebook_params(:fb_sig_ext_perms=>"status_update")
236
+ assert_response :success
237
+ assert_equal("<fb:redirect url=\"http://www.facebook.com/authorize.php?api_key=1234567&v=1.0&ext_perm=photo_upload\" />", @response.body)
238
+ end
239
+ def test_redirects_without_video_upload
240
+ post :index, facebook_params(:fb_sig_ext_perms=>"status_update,photo_upload")
241
+ assert_response :success
242
+ assert_equal("<fb:redirect url=\"http://www.facebook.com/authorize.php?api_key=1234567&v=1.0&ext_perm=video_upload\" />", @response.body)
243
+ end
244
+ def test_redirects_without_create_listing
245
+ post :index, facebook_params(:fb_sig_ext_perms=>"status_update,photo_upload,video_upload")
246
+ assert_response :success
247
+ assert_equal("<fb:redirect url=\"http://www.facebook.com/authorize.php?api_key=1234567&v=1.0&ext_perm=create_listing\" />", @response.body)
248
+ end
249
+
250
+ def test_renders_with_permission
251
+ post :index, facebook_params(:fb_sig_ext_perms=>"status_update,photo_upload,create_listing,video_upload")
252
+ assert_response :success
253
+ assert_equal("score!", @response.body)
254
+
255
+ end
256
+ end
257
+
258
+ class RailsIntegrationTestForApplicationInstallation < Test::Unit::TestCase
259
+ def setup
260
+ ENV['FACEBOOK_API_KEY'] = '1234567'
261
+ ENV['FACEBOOK_SECRET_KEY'] = '7654321'
262
+ @controller = ControllerWhichRequiresApplicationInstallation.new
263
+ @request = ActionController::TestRequest.new
264
+ @response = ActionController::TestResponse.new
265
+ @controller.stubs(:verify_signature).returns(true)
266
+ end
267
+
268
+ def test_if_controller_requires_application_installation_unauthenticated_requests_will_redirect_to_install_page
269
+ get :index
270
+ assert_response :redirect
271
+ assert_equal("http://www.facebook.com/install.php?api_key=1234567&v=1.0", @response.headers['Location'])
272
+ end
273
+
274
+ def test_if_controller_requires_application_installation_authenticated_requests_without_installation_will_redirect_to_install_page
275
+ get :index, facebook_params(:fb_sig_added => nil)
276
+ assert_response :success
277
+ assert_equal("<fb:redirect url=\"http://www.facebook.com/install.php?api_key=1234567&v=1.0\" />", @response.body)
278
+ end
279
+
280
+ def test_if_controller_requires_application_installation_authenticated_requests_with_installation_will_render
281
+ get :index, facebook_params('fb_sig_added' => "1")
282
+ assert_response :success
283
+ assert_equal("installed!", @response.body)
284
+ end
285
+ end
286
+
287
+ class RailsIntegrationTest < Test::Unit::TestCase
288
+ include FBConnectTestHelpers
289
+ def setup
290
+ ENV['FACEBOOK_CANVAS_PATH'] ='root'
291
+ ENV['FACEBOOK_API_KEY'] = '1234567'
292
+ ENV['FACEBOOK_SECRET_KEY'] = '7654321'
293
+ ActionController::Base.asset_host="http://root.example.com"
294
+ @controller = ControllerWhichRequiresFacebookAuthentication.new
295
+ @request = ActionController::TestRequest.new
296
+ @response = ActionController::TestResponse.new
297
+ @controller.stubs(:verify_signature).returns(true)
298
+
299
+ end
300
+
301
+ def test_named_route_includes_new_canvas_path_when_in_new_canvas
302
+ get :named_route_test, facebook_params("fb_sig_in_new_facebook"=>"1")
303
+ assert_equal "http://apps.facebook.com/root/comments",@response.body
304
+ end
305
+
306
+ def test_if_controller_requires_facebook_authentication_unauthenticated_requests_will_redirect
307
+ get :index
308
+ assert_response :redirect
309
+ assert_equal("http://www.facebook.com/login.php?api_key=1234567&v=1.0", @response.headers['Location'])
310
+ end
311
+
312
+ def test_facebook_params_are_parsed_into_a_separate_hash
313
+ get :index, facebook_params(:fb_sig_user => '9')
314
+ assert_not_nil @controller.facebook_params['time']
315
+ end
316
+
317
+ def test_facebook_params_convert_in_canvas_to_boolean
318
+ get :index, facebook_params
319
+ assert_equal(true, @controller.facebook_params['in_canvas'])
320
+ end
321
+
322
+ def test_facebook_params_convert_added_to_boolean_false
323
+ get :index, facebook_params(:fb_sig_added => '0')
324
+ assert_equal(false, @controller.facebook_params['added'])
325
+ end
326
+
327
+ def test_facebook_params_convert_added_to_boolean_true
328
+ get :index, facebook_params('fb_sig_added' => "1")
329
+ assert_equal(true, @controller.facebook_params['added'])
330
+ end
331
+
332
+ def test_facebook_params_convert_expirey_into_nil
333
+ get :index, facebook_params(:fb_sig_expires => '0')
334
+ assert_nil(@controller.facebook_params['expires'])
335
+ end
336
+
337
+ def test_facebook_params_convert_expirey_into_time
338
+ get :index, facebook_params(:fb_sig_expires => 5.minutes.from_now.to_f)
339
+ assert_instance_of Time, @controller.facebook_params['expires']
340
+ end
341
+
342
+ def test_facebook_params_convert_friend_list_to_parsed_array_of_friend_ids
343
+ get :index, facebook_params(:fb_sig_friends => '1,2,3,4,5')
344
+ assert_kind_of(Array, @controller.facebook_params['friends'])
345
+ assert_equal(5, @controller.facebook_params['friends'].size)
346
+ end
347
+
348
+ def test_session_can_be_resecured_from_facebook_params
349
+ get :index, facebook_params(:fb_sig_user => 10)
350
+ assert_equal(10, @controller.facebook_session.user.id)
351
+ end
352
+
353
+ def test_existing_secured_session_is_used_if_available
354
+ session = Facebooker::Session.create(Facebooker::Session.api_key, Facebooker::Session.secret_key)
355
+ session.secure_with!("session_key", "111", Time.now.to_i + 60)
356
+ get :index, facebook_params(:fb_sig_session_key => 'session_key', :fb_sig_user => '987'), {:facebook_session => session}
357
+ assert_equal(111, @controller.facebook_session.user.id)
358
+ end
359
+
360
+ def test_facebook_params_used_if_existing_secured_session_key_does_not_match
361
+ session = Facebooker::Session.create(Facebooker::Session.api_key, Facebooker::Session.secret_key)
362
+ session.secure_with!("different session key", "111", Time.now.to_i + 60)
363
+ get :index, facebook_params(:fb_sig_session_key => '', :fb_sig_user => '123'), {:facebook_session => session}
364
+ assert_equal(123, @controller.facebook_session.user.id)
365
+ end
366
+
367
+ def test_existing_secured_session_is_NOT_used_if_available_and_facebook_params_session_key_is_nil_and_in_canvas
368
+ session = Facebooker::Session.create(Facebooker::Session.api_key, Facebooker::Session.secret_key)
369
+ session.secure_with!("session_key", "111", Time.now.to_i + 60)
370
+ session.secure_with!("a session key", "1111111", Time.now.to_i + 60)
371
+ get :index, facebook_params(:fb_sig_session_key => '', :fb_sig_user => '987'), {:facebook_session => session}
372
+ assert_equal(987, @controller.facebook_session.user.id)
373
+ end
374
+
375
+ def test_existing_secured_session_IS_used_if_available_and_facebook_params_session_key_is_nil_and_NOT_in_canvas
376
+ @contoller = PlainOldRailsController.new
377
+ session = Facebooker::Session.create(ENV['FACEBOOK_API_KEY'], ENV['FACEBOOK_SECRET_KEY'])
378
+ session.secure_with!("a session key", "1111111", Time.now.to_i + 60)
379
+ get :index,{}, {:facebook_session => session}
380
+
381
+ assert_equal(1111111, @controller.facebook_session.user.id)
382
+ end
383
+
384
+ def test_session_can_be_secured_with_auth_token
385
+ auth_token = 'ohaiauthtokenhere111'
386
+ modified_params = facebook_params
387
+ modified_params.delete('fb_sig_session_key')
388
+ modified_params['auth_token'] = auth_token
389
+ session_mock = flexmock(session = Facebooker::Session.create(ENV['FACEBOOK_API_KEY'], ENV['FACEBOOK_SECRET_KEY']))
390
+ session_params = { 'session_key' => '123', 'uid' => '321' }
391
+ session_mock.should_receive(:post).with('facebook.auth.getSession', :auth_token => auth_token).once.and_return(session_params).ordered
392
+ flexmock(@controller).should_receive(:new_facebook_session).once.and_return(session).ordered
393
+ get :index, modified_params
394
+ end
395
+
396
+ def test_session_secured_with_auth_token_if_cookies_expired
397
+ auth_token = 'ohaiauthtokenhere111'
398
+ modified_params = facebook_params
399
+ modified_params.delete('fb_sig_session_key')
400
+ modified_params['auth_token'] = auth_token
401
+ session_mock = flexmock(session = Facebooker::Session.create(ENV['FACEBOOK_API_KEY'], ENV['FACEBOOK_SECRET_KEY']))
402
+ session_params = { 'session_key' => '123', 'uid' => '321' }
403
+ session_mock.should_receive(:post).with('facebook.auth.getSession', :auth_token => auth_token).once.and_return(session_params).ordered
404
+ flexmock(@controller).should_receive(:new_facebook_session).once.and_return(session).ordered
405
+ setup_fb_connect_cookies(expired_cookie_hash_for_auth)
406
+ get :index, modified_params
407
+ assert_equal(321, @controller.facebook_session.user.id)
408
+ end
409
+
410
+ def test_session_can_be_secured_with_cookies
411
+ setup_fb_connect_cookies
412
+ get :index
413
+ assert_equal(77777, @controller.facebook_session.user.id)
414
+ end
415
+
416
+ def test_session_does_NOT_secure_with_expired_cookies
417
+ setup_fb_connect_cookies(expired_cookie_hash_for_auth)
418
+ get :index
419
+ assert_nil(@controller.facebook_session)
420
+ end
421
+
422
+ def test_user_friends_can_be_populated_from_facebook_params_if_available
423
+ get :index, facebook_params(:fb_sig_friends => '1,2,3,4')
424
+ friends = @controller.facebook_session.user.friends
425
+ assert_not_nil(friends)
426
+ assert_equal(4, friends.size)
427
+ end
428
+
429
+ def test_fbml_redirect_tag_handles_hash_parameters_correctly
430
+ get :index, facebook_params
431
+ assert_equal "<fb:redirect url=\"http://apps.facebook.com/root/require_auth\" />", @controller.send(:fbml_redirect_tag, :action => :index,:canvas=>true)
432
+ end
433
+
434
+ def test_redirect_to_renders_fbml_redirect_tag_if_request_is_for_a_facebook_canvas
435
+ get :index, facebook_params(:fb_sig_user => nil)
436
+ assert_response :success
437
+ assert_equal("<fb:redirect url=\"http://www.facebook.com/login.php?api_key=1234567&v=1.0\" />", @response.body)
438
+ end
439
+
440
+ def test_url_for_links_to_canvas_if_canvas_is_true_and_not_in_canvas
441
+ get :link_test, facebook_params(:fb_sig_in_canvas=>0,:canvas=>true)
442
+ assert_match /apps.facebook.com/,@response.body
443
+ end
444
+
445
+ def test_includes_relative_url_root_when_linked_to_canvas
446
+ get :link_test,facebook_params(:fb_sig_in_canvas=>0,:canvas=>true)
447
+ assert_match /root/,@response.body
448
+ end
449
+
450
+ def test_url_for_links_to_callback_if_canvas_is_false_and_in_canvas
451
+ get :link_test,facebook_params(:fb_sig_in_canvas=>0,:canvas=>false)
452
+ assert_match /test.host/,@response.body
453
+ end
454
+
455
+ def test_url_for_doesnt_include_url_root_when_not_linked_to_canvas
456
+ get :link_test,facebook_params(:fb_sig_in_canvas=>0,:canvas=>false)
457
+ assert !@response.body.match(/root/)
458
+ end
459
+
460
+ def test_url_for_links_to_canvas_if_canvas_is_not_set
461
+ get :link_test,facebook_params
462
+ assert_match /apps.facebook.com/,@response.body
463
+ end
464
+
465
+ def test_image_tag
466
+ get :image_test, facebook_params
467
+ assert_equal "<img alt=\"Image\" src=\"http://root.example.com/images/image.png\" />",@response.body
468
+ end
469
+
470
+ def test_wants_interface_is_available_and_detects_method
471
+ get :publisher_test, facebook_params(:method=>"publisher_getInterface")
472
+ assert_equal "interface",@response.body
473
+ end
474
+ def test_wants_interface_is_available_and_detects_not_interface
475
+ get :publisher_test, facebook_params(:method=>"publisher_getFeedStory")
476
+ assert_equal "not interface",@response.body
477
+ end
478
+
479
+ def test_publisher_test_error
480
+ get :publisher_test_error, facebook_params
481
+ assert_equal Facebooker.json_decode("{\"errorCode\": 1, \"errorTitle\": \"Title\", \"errorMessage\": \"Body\"}"), Facebooker.json_decode(@response.body)
482
+ end
483
+
484
+ def test_publisher_test_interface
485
+ get :publisher_test_interface, facebook_params
486
+ assert_equal Facebooker.json_decode("{\"method\": \"publisher_getInterface\", \"content\": {\"fbml\": \"This is a test\", \"publishEnabled\": false, \"commentEnabled\": true}}"), Facebooker.json_decode(@response.body)
487
+ end
488
+
489
+ def test_publisher_test_reponse
490
+ get :publisher_test_response, facebook_params
491
+ assert_equal Facebooker.json_decode("{\"method\": \"publisher_getFeedStory\", \"content\": {\"feed\": {\"template_data\": {\"params\": true}, \"template_id\": 1234}}}"), Facebooker.json_decode(@response.body)
492
+
493
+ end
494
+
495
+ private
496
+
497
+ def expired_cookie_hash_for_auth
498
+ {"_ss" => "not_used", "_session_key"=> "whatever", "_user"=>"77777", "_expires"=>"#{1.day.ago.to_i}"}
499
+ end
500
+
501
+ def cookie_hash_for_auth
502
+ {"_ss" => "not_used", "_session_key"=> "whatever", "_user"=>"77777", "_expires"=>"#{1.day.from_now.to_i}"}
503
+ end
504
+
505
+ end
506
+
507
+
508
+ class RailsSignatureTest < Test::Unit::TestCase
509
+ def setup
510
+ ENV['FACEBOOKER_RELATIVE_URL_ROOT'] ='root'
511
+ ENV['FACEBOOK_API_KEY'] = '1234567'
512
+ ENV['FACEBOOK_SECRET_KEY'] = '7654321'
513
+ @controller = ControllerWhichRequiresFacebookAuthentication.new
514
+ @request = ActionController::TestRequest.new
515
+ @response = ActionController::TestResponse.new
516
+
517
+ end
518
+
519
+ def test_should_raise_too_old_for_replayed_session
520
+ begin
521
+ get :fb_params_test, facebook_params('fb_sig_time' => Time.now.to_i - 49.hours)
522
+ fail "No SignatureTooOld raised"
523
+ rescue Facebooker::Session::SignatureTooOld=>e
524
+ end
525
+ end
526
+
527
+ def test_should_raise_on_bad_sig
528
+ begin
529
+ get :fb_params_test, facebook_params.merge('fb_sig' => 'incorrect')
530
+ fail "No IncorrectSignature raised"
531
+ rescue Facebooker::Session::IncorrectSignature=>e
532
+ end
533
+ end
534
+
535
+ def test_valid_signature
536
+ @controller.expects(:earliest_valid_session).returns(Time.at(1186588275.5988)-1)
537
+ get :fb_params_test, facebook_params
538
+
539
+ end
540
+
541
+ end
542
+ class RailsHelperTest < Test::Unit::TestCase
543
+ class HelperClass
544
+ include ActionView::Helpers::TextHelper
545
+ include ActionView::Helpers::CaptureHelper
546
+ include ActionView::Helpers::TagHelper
547
+ include ActionView::Helpers::AssetTagHelper
548
+ include ActionView::Helpers::JavaScriptHelper
549
+ include Facebooker::Rails::Helpers
550
+ attr_accessor :flash, :output_buffer
551
+ def initialize
552
+ @flash={}
553
+ @template = self
554
+ @content_for_test_param="Test Param"
555
+ @output_buffer = ""
556
+ end
557
+ #used for stubbing out the form builder
558
+ def url_for(arg)
559
+ arg
560
+ end
561
+ def request
562
+ ActionController::TestRequest.new
563
+ end
564
+ def fields_for(*args)
565
+ ""
566
+ end
567
+
568
+ end
569
+
570
+ # used for capturing the contents of some of the helper tests
571
+ # this duplicates the rails template system
572
+ attr_accessor :_erbout
573
+
574
+ def setup
575
+ ENV['FACEBOOK_CANVAS_PATH'] ='facebook'
576
+ ENV['FACEBOOK_API_KEY'] = '1234567'
577
+ ENV['FACEBOOK_SECRET_KEY'] = '7654321'
578
+
579
+ @_erbout = ""
580
+ @h = HelperClass.new
581
+ #use an asset path where the canvas path equals the hostname to make sure we handle that case right
582
+ ActionController::Base.asset_host='http://facebook.host.com'
583
+ end
584
+
585
+ def test_fb_profile_pic
586
+ assert_equal "<fb:profile-pic uid=\"1234\"></fb:profile-pic>", @h.fb_profile_pic("1234")
587
+ end
588
+
589
+ def test_fb_profile_pic_with_valid_size
590
+ assert_equal "<fb:profile-pic size=\"small\" uid=\"1234\"></fb:profile-pic>", @h.fb_profile_pic("1234", :size => :small)
591
+ end
592
+
593
+ def test_fb_profile_pic_with_width_and_height
594
+ assert_equal "<fb:profile-pic height=\"200\" uid=\"1234\" width=\"100\"></fb:profile-pic>", @h.fb_profile_pic("1234", :width => 100, :height => 200)
595
+ end
596
+
597
+ def test_fb_profile_pic_with_invalid_size
598
+ assert_raises(ArgumentError) {@h.fb_profile_pic("1234", :size => :mediumm)}
599
+ end
600
+
601
+ def test_fb_photo
602
+ assert_equal "<fb:photo pid=\"1234\"></fb:photo>",@h.fb_photo("1234")
603
+ end
604
+
605
+ def test_fb_photo_with_object_responding_to_photo_id
606
+ photo = flexmock("photo", :photo_id => "5678")
607
+ assert_equal "<fb:photo pid=\"5678\"></fb:photo>", @h.fb_photo(photo)
608
+ end
609
+
610
+ def test_fb_photo_with_invalid_size
611
+ assert_raises(ArgumentError) {@h.fb_photo("1234", :size => :medium)}
612
+ end
613
+
614
+ def test_fb_photo_with_invalid_size_value
615
+ assert_raises(ArgumentError) {@h.fb_photo("1234", :size => :mediumm)}
616
+ end
617
+
618
+ def test_fb_photo_with_invalid_align_value
619
+ assert_raises(ArgumentError) {@h.fb_photo("1234", :align => :rightt)}
620
+ end
621
+
622
+ def test_fb_photo_with_valid_align_value
623
+ assert_equal "<fb:photo align=\"right\" pid=\"1234\"></fb:photo>",@h.fb_photo("1234", :align => :right)
624
+ end
625
+
626
+ def test_fb_photo_with_class
627
+ assert_equal "<fb:photo class=\"picky\" pid=\"1234\"></fb:photo>",@h.fb_photo("1234", :class => :picky)
628
+ end
629
+ def test_fb_photo_with_style
630
+ assert_equal "<fb:photo pid=\"1234\" style=\"some=css;put=here;\"></fb:photo>",@h.fb_photo("1234", :style => "some=css;put=here;")
631
+ end
632
+
633
+ def test_fb_prompt_permission_valid_no_callback
634
+ assert_equal "<fb:prompt-permission perms=\"email\">Can I email you?</fb:prompt-permission>",@h.fb_prompt_permission("email","Can I email you?")
635
+ end
636
+
637
+ def test_fb_prompt_permission_valid_with_callback
638
+ assert_equal "<fb:prompt-permission next_fbjs=\"do_stuff()\" perms=\"email\">a message</fb:prompt-permission>",@h.fb_prompt_permission("email","a message","do_stuff()")
639
+ end
640
+
641
+ def test_fb_prompt_permission_invalid_option
642
+ assert_raises(ArgumentError) {@h.fb_prompt_permission("invliad", "a message")}
643
+
644
+ end
645
+
646
+ def test_fb_add_profile_section
647
+ assert_equal "<fb:add-section-button section=\"profile\" />",@h.fb_add_profile_section
648
+ end
649
+
650
+ def test_fb_add_info_section
651
+ assert_equal "<fb:add-section-button section=\"info\" />",@h.fb_add_info_section
652
+ end
653
+
654
+ def test_fb_name_with_invalid_key
655
+ assert_raises(ArgumentError) {@h.fb_name(1234, :sizee => false)}
656
+ end
657
+
658
+ def test_fb_name
659
+ assert_equal "<fb:name uid=\"1234\"></fb:name>",@h.fb_name("1234")
660
+ end
661
+
662
+ def test_fb_name_with_transformed_key
663
+ assert_equal "<fb:name uid=\"1234\" useyou=\"true\"></fb:name>", @h.fb_name(1234, :use_you => true)
664
+ end
665
+
666
+ def test_fb_name_with_user_responding_to_facebook_id
667
+ user = flexmock("user", :facebook_id => "5678")
668
+ assert_equal "<fb:name uid=\"5678\"></fb:name>", @h.fb_name(user)
669
+ end
670
+
671
+ def test_fb_name_with_invalid_key
672
+ assert_raises(ArgumentError) {@h.fb_name(1234, :linkd => false)}
673
+ end
674
+
675
+ def test_fb_tabs
676
+ assert_equal "<fb:tabs></fb:tabs>", @h.fb_tabs{}
677
+ end
678
+
679
+ def test_fb_tab_item
680
+ assert_equal "<fb:tab-item href=\"http://www.google.com\" title=\"Google\" />", @h.fb_tab_item("Google", "http://www.google.com")
681
+ end
682
+
683
+ def test_fb_tab_item_raises_exception_for_invalid_option
684
+ assert_raises(ArgumentError) {@h.fb_tab_item("Google", "http://www.google.com", :alignn => :right)}
685
+ end
686
+
687
+ def test_fb_tab_item_raises_exception_for_invalid_align_value
688
+ assert_raises(ArgumentError) {@h.fb_tab_item("Google", "http://www.google.com", :align => :rightt)}
689
+ end
690
+
691
+ def test_fb_req_choice
692
+ assert_equal "<fb:req-choice label=\"label\" url=\"url\" />", @h.fb_req_choice("label","url")
693
+ end
694
+
695
+ def test_fb_multi_friend_selector
696
+ assert_equal "<fb:multi-friend-selector actiontext=\"This is a message\" max=\"20\" showborder=\"false\" />", @h.fb_multi_friend_selector("This is a message")
697
+ end
698
+ def test_fb_multi_friend_selector_with_options
699
+ assert_equal "<fb:multi-friend-selector actiontext=\"This is a message\" exclude_ids=\"1,2\" max=\"20\" showborder=\"false\" />", @h.fb_multi_friend_selector("This is a message",:exclude_ids=>"1,2")
700
+ end
701
+
702
+ def test_fb_comments
703
+ assert_equal "<fb:comments candelete=\"false\" canpost=\"true\" numposts=\"7\" showform=\"true\" xid=\"a:1\" />", @h.fb_comments("a:1",true,false,7,:showform=>true)
704
+ end
705
+
706
+ def test_fb_title
707
+ assert_equal "<fb:title>This is the canvas page window title</fb:title>", @h.fb_title("This is the canvas page window title")
708
+ end
709
+
710
+ def test_fb_google_analytics
711
+ assert_equal "<fb:google-analytics uacct=\"UA-9999999-99\" />", @h.fb_google_analytics("UA-9999999-99")
712
+ end
713
+
714
+ def test_fb_if_is_user_with_single_object
715
+ user = flexmock("user", :facebook_id => "5678")
716
+ assert_equal "<fb:if-is-user uid=\"5678\"></fb:if-is-user>", @h.fb_if_is_user(user){}
717
+ end
718
+
719
+ def test_fb_if_is_user_with_array
720
+ user1 = flexmock("user", :facebook_id => "5678")
721
+ user2 = flexmock("user", :facebook_id => "1234")
722
+ assert_equal "<fb:if-is-user uid=\"5678,1234\"></fb:if-is-user>", @h.fb_if_is_user([user1,user2]){}
723
+ end
724
+
725
+ def test_fb_else
726
+ assert_equal "<fb:else></fb:else>", @h.fb_else{}
727
+ end
728
+
729
+ def test_fb_about_url
730
+ ENV["FACEBOOK_API_KEY"]="1234"
731
+ assert_equal "http://www.facebook.com/apps/application.php?api_key=1234", @h.fb_about_url
732
+ end
733
+
734
+ def test_fb_ref_with_url
735
+ assert_equal "<fb:ref url=\"A URL\" />", @h.fb_ref(:url => "A URL")
736
+ end
737
+
738
+ def test_fb_ref_with_handle
739
+ assert_equal "<fb:ref handle=\"A Handle\" />", @h.fb_ref(:handle => "A Handle")
740
+ end
741
+
742
+ def test_fb_ref_with_invalid_attribute
743
+ assert_raises(ArgumentError) {@h.fb_ref(:handlee => "A HANLDE")}
744
+ end
745
+
746
+ def test_fb_ref_with_handle_and_url
747
+ assert_raises(ArgumentError) {@h.fb_ref(:url => "URL", :handle => "HANDLE")}
748
+ end
749
+
750
+ def test_facebook_messages_notice
751
+ @h.flash[:notice]="A message"
752
+ assert_equal "<fb:success message=\"A message\" />",@h.facebook_messages
753
+ end
754
+
755
+ def test_facebook_messages_error
756
+ @h.flash[:error]="An error"
757
+ assert_equal "<fb:error message=\"An error\" />",@h.facebook_messages
758
+ end
759
+ def test_fb_wall_post
760
+ assert_equal "<fb:wallpost uid=\"1234\">A wall post</fb:wallpost>",@h.fb_wall_post("1234","A wall post")
761
+ end
762
+
763
+ def test_fb_pronoun
764
+ assert_equal "<fb:pronoun uid=\"1234\"></fb:pronoun>", @h.fb_pronoun(1234)
765
+ end
766
+
767
+ def test_fb_pronoun_with_transformed_key
768
+ assert_equal "<fb:pronoun uid=\"1234\" usethey=\"true\"></fb:pronoun>", @h.fb_pronoun(1234, :use_they => true)
769
+ end
770
+
771
+ def test_fb_pronoun_with_user_responding_to_facebook_id
772
+ user = flexmock("user", :facebook_id => "5678")
773
+ assert_equal "<fb:pronoun uid=\"5678\"></fb:pronoun>", @h.fb_pronoun(user)
774
+ end
775
+
776
+ def test_fb_pronoun_with_invalid_key
777
+ assert_raises(ArgumentError) {@h.fb_pronoun(1234, :posessive => true)}
778
+ end
779
+
780
+ def test_fb_wall
781
+ @h.expects(:capture).returns("wall content")
782
+ @h.fb_wall do
783
+ end
784
+ assert_equal "<fb:wall>wall content</fb:wall>",@h.output_buffer
785
+ end
786
+
787
+ def test_fb_multi_friend_request
788
+ @h.expects(:capture).returns("body")
789
+ @h.expects(:protect_against_forgery?).returns(false)
790
+ @h.expects(:fb_multi_friend_selector).returns("friend selector")
791
+ assert_equal "<fb:request-form action=\"action\" content=\"body\" invite=\"true\" method=\"post\" type=\"invite\">friend selector</fb:request-form>",
792
+ (@h.fb_multi_friend_request("invite","ignored","action") {})
793
+ end
794
+
795
+ def test_fb_multi_friend_request_with_protection_against_forgery
796
+ @h.expects(:capture).returns("body")
797
+ @h.expects(:protect_against_forgery?).returns(true)
798
+ @h.expects(:request_forgery_protection_token).returns('forgery_token')
799
+ @h.expects(:form_authenticity_token).returns('form_token')
800
+
801
+ @h.expects(:fb_multi_friend_selector).returns("friend selector")
802
+ assert_equal "<fb:request-form action=\"action\" content=\"body\" invite=\"true\" method=\"post\" type=\"invite\">friend selector<input name=\"forgery_token\" type=\"hidden\" value=\"form_token\" /></fb:request-form>",
803
+ (@h.fb_multi_friend_request("invite","ignored","action") {})
804
+ end
805
+
806
+ def test_fb_dialog
807
+ @h.expects(:capture).returns("dialog content")
808
+ @h.fb_dialog( "my_dialog", "1" ) do
809
+ end
810
+ assert_equal '<fb:dialog cancel_button="1" id="my_dialog">dialog content</fb:dialog>', @h.output_buffer
811
+ end
812
+ def test_fb_dialog_title
813
+ assert_equal '<fb:dialog-title>My Little Dialog</fb:dialog-title>', @h.fb_dialog_title("My Little Dialog")
814
+ end
815
+ def test_fb_dialog_content
816
+ @h.expects(:capture).returns("dialog content content")
817
+ @h.fb_dialog_content do
818
+ end
819
+ assert_equal '<fb:dialog-content>dialog content content</fb:dialog-content>', @h.output_buffer
820
+ end
821
+ def test_fb_dialog_button
822
+ assert_equal '<fb:dialog-button clickrewriteform="my_form" clickrewriteid="my_dialog" clickrewriteurl="http://www.some_url_here.com/dialog_return.php" type="submit" value="Yes" />',
823
+ @h.fb_dialog_button("submit", "Yes", {:clickrewriteurl => "http://www.some_url_here.com/dialog_return.php",
824
+ :clickrewriteid => "my_dialog", :clickrewriteform => "my_form" } )
825
+ end
826
+
827
+ def test_fb_request_form
828
+ @h.expects(:capture).returns("body")
829
+ @h.expects(:protect_against_forgery?).returns(false)
830
+ assert_equal "<fb:request-form action=\"action\" content=\"Test Param\" invite=\"true\" method=\"post\" type=\"invite\">body</fb:request-form>",
831
+ (@h.fb_request_form("invite","test_param","action") {})
832
+ end
833
+
834
+ def test_fb_request_form_with_protect_against_forgery
835
+ @h.expects(:capture).returns("body")
836
+ @h.expects(:protect_against_forgery?).returns(true)
837
+ @h.expects(:request_forgery_protection_token).returns('forgery_token')
838
+ @h.expects(:form_authenticity_token).returns('form_token')
839
+ assert_equal "<fb:request-form action=\"action\" content=\"Test Param\" invite=\"true\" method=\"post\" type=\"invite\">body<input name=\"forgery_token\" type=\"hidden\" value=\"form_token\" /></fb:request-form>",
840
+ (@h.fb_request_form("invite","test_param","action") {})
841
+ end
842
+
843
+ def test_fb_error_with_only_message
844
+ assert_equal "<fb:error message=\"Errors have occurred!!\" />", @h.fb_error("Errors have occurred!!")
845
+ end
846
+
847
+ def test_fb_error_with_message_and_text
848
+ assert_equal "<fb:error><fb:message>Errors have occurred!!</fb:message>Label can't be blank!!</fb:error>", @h.fb_error("Errors have occurred!!", "Label can't be blank!!")
849
+ end
850
+
851
+ def test_fb_explanation_with_only_message
852
+ assert_equal "<fb:explanation message=\"This is an explanation\" />", @h.fb_explanation("This is an explanation")
853
+ end
854
+
855
+ def test_fb_explanation_with_message_and_text
856
+ assert_equal "<fb:explanation><fb:message>This is an explanation</fb:message>You have a match</fb:explanation>", @h.fb_explanation("This is an explanation", "You have a match")
857
+ end
858
+
859
+ def test_fb_success_with_only_message
860
+ assert_equal "<fb:success message=\"Woot!!\" />", @h.fb_success("Woot!!")
861
+ end
862
+
863
+ def test_fb_success_with_message_and_text
864
+ assert_equal "<fb:success><fb:message>Woot!!</fb:message>You Rock!!</fb:success>", @h.fb_success("Woot!!", "You Rock!!")
865
+ end
866
+
867
+ def test_facebook_form_for
868
+ @h.expects(:protect_against_forgery?).returns(false)
869
+ form_body=@h.facebook_form_for(:model,:url=>"action") do
870
+ end
871
+ assert_equal "<fb:editor action=\"action\"></fb:editor>",form_body
872
+ end
873
+
874
+ def test_facebook_form_for_with_authenticity_token
875
+ @h.expects(:protect_against_forgery?).returns(true)
876
+ @h.expects(:request_forgery_protection_token).returns('forgery_token')
877
+ @h.expects(:form_authenticity_token).returns('form_token')
878
+ assert_equal "<fb:editor action=\"action\"><input name=\"forgery_token\" type=\"hidden\" value=\"form_token\" /></fb:editor>",
879
+ (@h.facebook_form_for(:model, :url => "action") {})
880
+ end
881
+
882
+ def test_fb_friend_selector
883
+ assert_equal("<fb:friend-selector />",@h.fb_friend_selector)
884
+ end
885
+
886
+ def test_fb_request_form_submit
887
+ assert_equal("<fb:request-form-submit />",@h.fb_request_form_submit)
888
+ end
889
+
890
+ def test_fb_request_form_submit_with_uid
891
+ assert_equal("<fb:request-form-submit uid=\"123456789\" />",@h.fb_request_form_submit({:uid => "123456789"}))
892
+ end
893
+
894
+ def test_fb_request_form_submit_with_label
895
+ assert_equal("<fb:request-form-submit label=\"Send Invite to Joel\" />",@h.fb_request_form_submit({:label => "Send Invite to Joel"}))
896
+ end
897
+
898
+ def test_fb_request_form_submit_with_uid_and_label
899
+ assert_equal("<fb:request-form-submit label=\"Send Invite to Joel\" uid=\"123456789\" />",@h.fb_request_form_submit({:uid =>"123456789", :label => "Send Invite to Joel"}))
900
+ end
901
+
902
+ def test_fb_action
903
+ assert_equal "<fb:action href=\"/growingpets/rub\">Rub my pet</fb:action>", @h.fb_action("Rub my pet", "/growingpets/rub")
904
+ end
905
+
906
+ def test_fb_help
907
+ assert_equal "<fb:help href=\"http://www.facebook.com/apps/application.php?id=6236036681\">Help</fb:help>", @h.fb_help("Help", "http://www.facebook.com/apps/application.php?id=6236036681")
908
+ end
909
+
910
+ def test_fb_create_button
911
+ assert_equal "<fb:create-button href=\"/growingpets/invite\">Invite Friends</fb:create-button>", @h.fb_create_button('Invite Friends', '/growingpets/invite')
912
+ end
913
+ def test_fb_comments
914
+ assert_equal "<fb:comments candelete=\"false\" canpost=\"true\" numposts=\"4\" optional=\"false\" xid=\"xxx\"></fb:comments>", @h.fb_comments("xxx",true,false,4,:optional=>false)
915
+ end
916
+ def test_fb_comments_with_title
917
+ assert_equal "<fb:comments candelete=\"false\" canpost=\"true\" numposts=\"4\" optional=\"false\" xid=\"xxx\"><fb:title>TITLE</fb:title></fb:comments>", @h.fb_comments("xxx",true,false,4,:optional=>false, :title => "TITLE")
918
+ end
919
+ def test_fb_board
920
+ assert_equal "<fb:board optional=\"false\" xid=\"xxx\"></fb:board>", @h.fb_board("xxx",:optional => false)
921
+ end
922
+ def test_fb_board_with_title
923
+ assert_equal "<fb:board optional=\"false\" xid=\"xxx\"><fb:title>TITLE</fb:title></fb:board>", @h.fb_board("xxx",:optional=>false, :title => "TITLE")
924
+ end
925
+
926
+ def test_fb_dashboard
927
+ @h.expects(:capture).returns("dashboard content")
928
+ @h.fb_dashboard do
929
+ end
930
+ assert_equal "<fb:dashboard>dashboard content</fb:dashboard>", @h.output_buffer
931
+ end
932
+ def test_fb_dashboard_non_block
933
+ assert_equal "<fb:dashboard></fb:dashboard>", @h.fb_dashboard
934
+ end
935
+
936
+ def test_fb_wide
937
+ @h.expects(:capture).returns("wide profile content")
938
+ @h.fb_wide do
939
+ end
940
+ assert_equal "<fb:wide>wide profile content</fb:wide>", @h.output_buffer
941
+ end
942
+
943
+ def test_fb_narrow
944
+ @h.expects(:capture).returns("narrow profile content")
945
+ @h.fb_narrow do
946
+ end
947
+ assert_equal "<fb:narrow>narrow profile content</fb:narrow>", @h.output_buffer
948
+ end
949
+
950
+ def test_fb_login_button
951
+ assert_equal "<fb:login-button onlogin=\"somejs\"></fb:login-button>",@h.fb_login_button("somejs")
952
+ end
953
+
954
+ def test_init_fb_connect_no_features
955
+ assert ! @h.init_fb_connect.match(/XFBML/)
956
+ end
957
+
958
+ def test_init_fb_connect_with_features
959
+ assert @h.init_fb_connect("XFBML").match(/XFBML/)
960
+ end
961
+
962
+ def test_init_fb_connect_with_features_and_body
963
+ @h.expects(:capture).returns("Body Content")
964
+
965
+ @h.init_fb_connect("XFBML") do
966
+ end
967
+ assert @h.output_buffer =~ /Body Content/
968
+ end
969
+
970
+ def test_init_fb_connect_no_options
971
+ assert ! @h.init_fb_connect.match(/Element.observe\(window,'load',/)
972
+ end
973
+
974
+ def test_init_fb_connect_with_options_js_jquery
975
+ assert ! @h.init_fb_connect(:js => :jquery).match(/\$\(document\).ready\(/)
976
+ end
977
+
978
+ def test_init_fb_connect_with_features_and_options_js_jquery
979
+ assert @h.init_fb_connect("XFBML", :js => :jquery).match(/XFBML.*/)
980
+ assert @h.init_fb_connect("XFBML", :js => :jquery).match(/\$\(document\).ready\(/)
981
+ end
982
+
983
+
984
+ def test_fb_login_and_redirect
985
+ assert_equal @h.fb_login_and_redirect("/path"),"<fb:login-button onlogin=\"window.location.href = &quot;/path&quot;;\"></fb:login-button>"
986
+ end
987
+
988
+ def test_fb_logout_link
989
+ assert_equal @h.fb_logout_link("Logout","My URL"),"<a href=\"#\" onclick=\"FB.Connect.logoutAndRedirect(&quot;My URL&quot;);; return false;\">Logout</a>"
990
+ end
991
+ def test_fb_user_action
992
+ action = Facebooker::Rails::Publisher::UserAction.new
993
+ assert_equal @h.fb_user_action(action,"message","prompt"),"FB.Connect.showFeedDialog(null, null, null, null, null, FB.RequireConnect.promptConnect, null, \"prompt\", \"message\");"
994
+ end
995
+
996
+
997
+ def test_fb_connect_javascript_tag
998
+ assert_equal "<script src=\"http://static.ak.connect.facebook.com/js/api_lib/v0.4/FeatureLoader.js.php\" type=\"text/javascript\"></script>",
999
+ @h.fb_connect_javascript_tag
1000
+ end
1001
+
1002
+ def test_fb_container
1003
+ @h.expects(:capture).returns("Inner Stuff")
1004
+ @h.fb_container(:condition=>"somejs") do
1005
+ end
1006
+ assert_equal "<fb:container condition=\"somejs\">Inner Stuff</fb:container>",@h.output_buffer
1007
+ end
1008
+
1009
+ def test_fb_eventlink
1010
+ assert_equal '<fb:eventlink eid="21150032416"></fb:eventlink>',@h.fb_eventlink("21150032416")
1011
+ end
1012
+
1013
+ def test_fb_grouplink
1014
+ assert_equal '<fb:grouplink gid="2541896821"></fb:grouplink>',@h.fb_grouplink("2541896821")
1015
+ end
1016
+
1017
+ def test_fb_serverfbml
1018
+ @h.expects(:capture).returns("Inner Stuff")
1019
+ @h.fb_serverfbml(:condition=>"somejs") do
1020
+ end
1021
+ assert_equal "<fb:serverfbml condition=\"somejs\">Inner Stuff</fb:serverfbml>",@h.output_buffer
1022
+ end
1023
+
1024
+ def test_fb_share_button
1025
+ assert_equal "<fb:share-button class=\"url\" href=\"http://www.elevatedrails.com\"></fb:share-button>",@h.fb_share_button("http://www.elevatedrails.com")
1026
+ end
1027
+
1028
+ def test_fb_unconnected_friends_count_without_condition
1029
+ assert_equal "<fb:unconnected-friends-count></fb:unconnected-friends-count>",@h.fb_unconnected_friends_count
1030
+ end
1031
+
1032
+ def test_fb_user_status
1033
+ user=flexmock("user", :facebook_id => "5678")
1034
+ assert_equal '<fb:user-status linked="false" uid="5678"></fb:user-status>',@h.fb_user_status(user,false)
1035
+ end
1036
+
1037
+ def test_fb_time
1038
+ time = Time.now
1039
+ assert_equal %Q{<fb:time preposition="true" t="#{time.to_i}" tz="America/New York" />}, @h.fb_time(time, :tz => 'America/New York', :preposition => true)
1040
+ end
1041
+
1042
+ def test_fb_time_defaults
1043
+ time = Time.now
1044
+ assert_equal %Q{<fb:time t="#{time.to_i}" />}, @h.fb_time(time)
1045
+ end
1046
+ end
1047
+ class TestModel
1048
+ attr_accessor :name,:facebook_id
1049
+ end
1050
+
1051
+ class RailsFacebookFormbuilderTest < Test::Unit::TestCase
1052
+ class TestTemplate
1053
+ include ActionView::Helpers::TextHelper
1054
+ include ActionView::Helpers::CaptureHelper
1055
+ include ActionView::Helpers::TagHelper
1056
+ include Facebooker::Rails::Helpers
1057
+ attr_accessor :output_buffer
1058
+ def initialize
1059
+ @output_buffer=""
1060
+ end
1061
+ end
1062
+ def setup
1063
+ @_erbout = ""
1064
+ @test_model = TestModel.new
1065
+ @test_model.name="Mike"
1066
+ @template = TestTemplate.new
1067
+ @proc = Proc.new {}
1068
+ @form_builder = Facebooker::Rails::FacebookFormBuilder.new(:test_model,@test_model,@template,{},@proc)
1069
+ def @form_builder._erbout
1070
+ ""
1071
+ end
1072
+
1073
+ end
1074
+
1075
+ def test_text_field
1076
+ assert_equal "<fb:editor-text id=\"test_model_name\" label=\"Name\" name=\"test_model[name]\" value=\"Mike\"></fb:editor-text>",
1077
+ @form_builder.text_field(:name)
1078
+ end
1079
+ def test_text_area
1080
+ assert_equal "<fb:editor-textarea id=\"test_model_name\" label=\"Name\" name=\"test_model[name]\">Mike</fb:editor-textarea>",
1081
+ @form_builder.text_area(:name)
1082
+ end
1083
+
1084
+ def test_default_name_and_id
1085
+ assert_equal "<fb:editor-text id=\"different_id\" label=\"Name\" name=\"different_name\" value=\"Mike\"></fb:editor-text>",
1086
+ @form_builder.text_field(:name, {:name => 'different_name', :id => 'different_id'})
1087
+ end
1088
+
1089
+ def test_collection_typeahead
1090
+ flexmock(@form_builder) do |fb|
1091
+ fb.should_receive(:collection_typeahead_internal).with(:name,["ABC"],:size,:to_s,{})
1092
+ end
1093
+ @form_builder.collection_typeahead(:name,["ABC"],:size,:to_s)
1094
+ end
1095
+
1096
+ def test_collection_typeahead_internal
1097
+ assert_equal "<fb:typeahead-input id=\"test_model_name\" name=\"test_model[name]\" value=\"Mike\"><fb:typeahead-option value=\"3\">ABC</fb:typeahead-option></fb:typeahead-input>",
1098
+ @form_builder.collection_typeahead_internal(:name,["ABC"],:size,:to_s)
1099
+ end
1100
+
1101
+ def test_buttons
1102
+ @form_builder.expects(:create_button).with(:first).returns("first")
1103
+ @form_builder.expects(:create_button).with(:second).returns("second")
1104
+ @template.expects(:content_tag).with("fb:editor-buttonset","firstsecond")
1105
+ @form_builder.buttons(:first,:second)
1106
+ end
1107
+
1108
+ def test_create_button
1109
+ assert_equal "<fb:editor-button name=\"commit\" value=\"first\"></fb:editor-button>",@form_builder.create_button(:first)
1110
+ end
1111
+
1112
+ def test_custom
1113
+ @template.expects(:password_field).returns("password_field")
1114
+ assert_equal "<fb:editor-custom label=\"Name\">password_field</fb:editor-custom>",@form_builder.password_field(:name)
1115
+ end
1116
+
1117
+ def test_text
1118
+ assert_equal "<fb:editor-custom label=\"custom\">Mike</fb:editor-custom>",@form_builder.text("Mike",:label=>"custom")
1119
+ end
1120
+
1121
+ def test_multi_friend_input
1122
+ assert_equal "<fb:editor-custom label=\"Friends\"><fb:multi-friend-input></fb:multi-friend-input></fb:editor-custom>",@form_builder.multi_friend_input
1123
+ end
1124
+
1125
+
1126
+ end
1127
+
1128
+ class RailsPrettyErrorsTest < Test::Unit::TestCase
1129
+ class ControllerWhichFails < ActionController::Base
1130
+ def pass
1131
+ render :text=>''
1132
+ end
1133
+ def fail
1134
+ raise "I'm failing"
1135
+ end
1136
+ end
1137
+
1138
+ def setup
1139
+ Facebooker.apply_configuration('api_key'=>"1234", 'secret_key'=>"34278",'canvas_page_name'=>'mike','pretty_errors'=>true)
1140
+ @controller = ControllerWhichFails.new
1141
+ @request = ActionController::TestRequest.new
1142
+ @response = ActionController::TestResponse.new
1143
+ end
1144
+
1145
+ def test_pretty_errors_disabled_success
1146
+ post :pass, facebook_params
1147
+ assert_response 200
1148
+ end
1149
+
1150
+ def test_pretty_errors_disabled_error
1151
+ Facebooker.apply_configuration('api_key'=>"1234", 'secret_key'=>"34278",'canvas_page_name'=>'mike','pretty_errors'=>false)
1152
+ post :fail, facebook_params
1153
+ assert_response :error
1154
+ end
1155
+
1156
+ def test_pretty_errors_enabled_success
1157
+ post :pass, facebook_params
1158
+ assert_response 200
1159
+ end
1160
+ def test_pretty_errors_enabled_error
1161
+ post :fail, facebook_params
1162
+ assert_response 200
1163
+ end
1164
+ end
1165
+
1166
+ class RailsUrlHelperExtensionsTest < Test::Unit::TestCase
1167
+ class UrlHelperExtensionsClass
1168
+ include ActionView::Helpers::UrlHelper
1169
+ include ActionView::Helpers::TagHelper
1170
+ def initialize(controller)
1171
+ @controller = controller
1172
+ end
1173
+
1174
+ def protect_against_forgery?
1175
+ false
1176
+ end
1177
+
1178
+ def request_comes_from_facebook?
1179
+ @request_comes_from_facebook
1180
+ end
1181
+
1182
+ def request_comes_from_facebook=(val)
1183
+ @request_comes_from_facebook = val
1184
+ end
1185
+
1186
+ end
1187
+ class UrlHelperExtensionsController < NoisyController
1188
+ def index
1189
+ render :nothing => true
1190
+ end
1191
+ def do_it
1192
+ render :nothing => true
1193
+ end
1194
+ end
1195
+
1196
+ class FacebookRequest < ActionController::TestRequest
1197
+ end
1198
+
1199
+ def setup
1200
+ @controller = UrlHelperExtensionsController.new
1201
+ @request = FacebookRequest.new
1202
+ @response = ActionController::TestResponse.new
1203
+
1204
+ @u = UrlHelperExtensionsClass.new(@controller)
1205
+ @u.request_comes_from_facebook = true
1206
+
1207
+ @non_canvas_u = UrlHelperExtensionsClass.new(@controller)
1208
+ @non_canvas_u.request_comes_from_facebook = false
1209
+
1210
+ @label = "Testing"
1211
+ @url = "test.host"
1212
+ @prompt = "Are you sure?"
1213
+ @default_title = "Please Confirm"
1214
+ @title = "Confirm Request"
1215
+ @style = {:color => 'black', :background => 'white'}
1216
+ @verbose_style = "{background: 'white', color: 'black'}"
1217
+ @default_okay = "Okay"
1218
+ @default_cancel = "Cancel"
1219
+ @default_style = "" #"'width','200px'"
1220
+ end
1221
+
1222
+ def test_link_to
1223
+ assert_equal "<a href=\"#{@url}\">Testing</a>", @u.link_to(@label, @url)
1224
+ end
1225
+
1226
+ def test_link_to_with_popup
1227
+ assert_raises(ActionView::ActionViewError) {@u.link_to(@label,@url, :popup=>true)}
1228
+ end
1229
+
1230
+ def test_link_to_with_confirm
1231
+ assert_dom_equal( "<a href=\"#{@url}\" onclick=\"var dlg = new Dialog().showChoice(\'#{@default_title}\',\'#{@prompt}\',\'#{@default_okay}\',\'#{@default_cancel}\').setStyle(#{@default_style});"+
1232
+ "var a=this;dlg.onconfirm = function() { " +
1233
+ "document.setLocation(a.getHref()); };return false;\">#{@label}</a>",
1234
+ @u.link_to(@label, @url, :confirm => @prompt) )
1235
+ end
1236
+ def test_link_to_with_confirm_with_title
1237
+ assert_dom_equal( "<a href=\"#{@url}\" onclick=\"var dlg = new Dialog().showChoice(\'#{@title}\',\'#{@prompt}\',\'#{@default_okay}\',\'#{@default_cancel}\').setStyle(#{@default_style});"+
1238
+ "var a=this;dlg.onconfirm = function() { " +
1239
+ "document.setLocation(a.getHref()); };return false;\">#{@label}</a>",
1240
+ @u.link_to(@label, @url, :confirm => {:title=>@title,:content=>@prompt}) )
1241
+ end
1242
+ def test_link_to_with_confirm_with_title_and_style
1243
+ assert_dom_equal( "<a href=\"#{@url}\" onclick=\"var dlg = new Dialog().showChoice(\'#{@title}\',\'#{@prompt}\',\'#{@default_okay}\',\'#{@default_cancel}\').setStyle(#{@verbose_style});"+
1244
+ "var a=this;dlg.onconfirm = function() { " +
1245
+ "document.setLocation(a.getHref()); };return false;\">#{@label}</a>",
1246
+ @u.link_to(@label, @url, :confirm => {:title=>@title,:content=>@prompt}.merge!(@style)) )
1247
+ end
1248
+
1249
+ def test_link_to_with_method
1250
+ assert_dom_equal( "<a href=\"#{@url}\" onclick=\"var a=this;var f = document.createElement('form'); f.setStyle('display','none'); "+
1251
+ "a.getParentNode().appendChild(f); f.setMethod('POST'); f.setAction(a.getHref());" +
1252
+ "var m = document.createElement('input'); m.setType('hidden'); "+
1253
+ "m.setName('_method'); m.setValue('delete'); f.appendChild(m);"+
1254
+ "f.submit();return false;\">#{@label}</a>", @u.link_to(@label,@url, :method=>:delete))
1255
+ end
1256
+
1257
+ def test_link_to_with_confirm_and_method
1258
+ assert_dom_equal( "<a href=\"#{@url}\" onclick=\"var dlg = new Dialog().showChoice(\'#{@default_title}\',\'#{@prompt}\',\'#{@default_okay}\',\'#{@default_cancel}\').setStyle(#{@default_style});"+
1259
+ "var a=this;dlg.onconfirm = function() { " +
1260
+ "var f = document.createElement('form'); f.setStyle('display','none'); "+
1261
+ "a.getParentNode().appendChild(f); f.setMethod('POST'); f.setAction(a.getHref());" +
1262
+ "var m = document.createElement('input'); m.setType('hidden'); "+
1263
+ "m.setName('_method'); m.setValue('delete'); f.appendChild(m);"+
1264
+ "f.submit(); };return false;\">#{@label}</a>", @u.link_to(@label,@url, :confirm=>@prompt, :method=>:delete) )
1265
+ end
1266
+ def test_link_to_with_confirm_and_method_for_non_canvas_page
1267
+ assert_dom_equal( "<a href=\"#{@url}\" onclick=\"if (confirm(\'#{@prompt}\')) { var f = document.createElement('form'); f.style.display = 'none'; "+
1268
+ "this.parentNode.appendChild(f); f.method = 'POST'; f.action = this.href;var m = document.createElement('input'); "+
1269
+ "m.setAttribute('type', 'hidden'); m.setAttribute('name', '_method'); m.setAttribute('value', 'delete'); "+
1270
+ "f.appendChild(m);f.submit(); };return false;\">#{@label}</a>",
1271
+ @non_canvas_u.link_to(@label,@url, :confirm=>@prompt, :method=>:delete) )
1272
+ end
1273
+
1274
+ def test_button_to
1275
+ assert_equal "<form method=\"post\" action=\"#{@url}\" class=\"button-to\"><div>" +
1276
+ "<input type=\"submit\" value=\"#{@label}\" /></div></form>", @u.button_to(@label,@url)
1277
+ end
1278
+
1279
+ def test_button_to_with_confirm
1280
+ assert_equal "<form method=\"post\" action=\"#{@url}\" class=\"button-to\"><div>" +
1281
+ "<input onclick=\"var dlg = new Dialog().showChoice(\'#{@default_title}\',\'#{@prompt}\',\'#{@default_okay}\',\'#{@default_cancel}\').setStyle(#{@default_style});"+
1282
+ "var a=this;dlg.onconfirm = function() { "+
1283
+ "a.getForm().submit(); };return false;\" type=\"submit\" value=\"#{@label}\" /></div></form>",
1284
+ @u.button_to(@label,@url, :confirm=>@prompt)
1285
+ end
1286
+ def test_button_to_with_confirm_for_non_canvas_page
1287
+ assert_equal "<form method=\"post\" action=\"#{@url}\" class=\"button-to\"><div>"+
1288
+ "<input onclick=\"return confirm(\'#{@prompt}\');\" type=\"submit\" value=\"#{@label}\" /></div></form>",
1289
+ @non_canvas_u.button_to(@label,@url, :confirm=>@prompt)
1290
+ end
1291
+
1292
+ def test_link_to_unless_with_true
1293
+ assert_equal @label, @u.link_to_unless(true,@label,@url)
1294
+ end
1295
+ def test_link_to_unless_with_false
1296
+ assert_equal @u.link_to(@label,@url), @u.link_to_unless(false,@label,@url)
1297
+ end
1298
+
1299
+ def test_link_to_if_with_true
1300
+ assert_equal @u.link_to(@label,@url), @u.link_to_if(true,@label,@url)
1301
+ end
1302
+ def test_link_to_if_with_false
1303
+ assert_equal @label, @u.link_to_if(false,@label,@url)
1304
+ end
1305
+
1306
+ end
1307
+
1308
+ class RailsRequestFormatTest < Test::Unit::TestCase
1309
+ class FacebookController < NoisyController
1310
+ def index
1311
+ respond_to do |format|
1312
+ format.html { render :text => 'html' }
1313
+ format.fbml { render :text => 'fbml' }
1314
+ format.fbjs { render :text => 'fbjs' }
1315
+ end
1316
+ end
1317
+ end
1318
+
1319
+ def setup
1320
+ ENV['FACEBOOK_CANVAS_PATH'] ='facebook_app_name'
1321
+ ENV['FACEBOOK_API_KEY'] = '1234567'
1322
+ ENV['FACEBOOK_SECRET_KEY'] = '7654321'
1323
+ @controller = FacebookController.new
1324
+ @request = ActionController::TestRequest.new
1325
+ @response = ActionController::TestResponse.new
1326
+ @controller.stubs(:verify_signature).returns(true)
1327
+ end
1328
+
1329
+ def test_responds_to_html_without_canvas
1330
+ get :index
1331
+ assert_equal 'html', @response.body
1332
+ end
1333
+
1334
+ def test_responds_to_fbml_in_canvas
1335
+ get :index, facebook_params(:fb_sig_in_canvas => '1')
1336
+ assert_equal 'fbml', @response.body
1337
+ end
1338
+
1339
+ def test_responds_to_fbjs_when_is_ajax
1340
+ get :index, facebook_params(:fb_sig_is_ajax => '1')
1341
+ assert_equal 'fbjs', @response.body
1342
+ end
1343
+
1344
+ def test_responds_to_html_when_iframe
1345
+ get :index, facebook_params(:fb_sig_in_iframe => '1')
1346
+ assert_equal 'html', @response.body
1347
+ end
1348
+
1349
+ end