formtastic 3.1.2 → 4.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (135) hide show
  1. checksums.yaml +7 -0
  2. data/.gitattributes +1 -0
  3. data/.github/workflows/test.yml +61 -0
  4. data/.gitignore +3 -2
  5. data/CHANGELOG.md +52 -0
  6. data/Gemfile.lock +105 -0
  7. data/MIT-LICENSE +1 -1
  8. data/{README.textile → README.md} +178 -167
  9. data/RELEASE_PROCESS +3 -1
  10. data/Rakefile +20 -1
  11. data/app/assets/stylesheets/formtastic.css +1 -1
  12. data/bin/appraisal +8 -0
  13. data/formtastic.gemspec +10 -16
  14. data/gemfiles/rails_5.2/Gemfile +5 -0
  15. data/gemfiles/rails_6.0/Gemfile +5 -0
  16. data/gemfiles/rails_6.1/Gemfile +5 -0
  17. data/gemfiles/rails_edge/Gemfile +13 -0
  18. data/lib/formtastic.rb +9 -11
  19. data/lib/formtastic/actions.rb +6 -3
  20. data/lib/formtastic/deprecation.rb +1 -38
  21. data/lib/formtastic/engine.rb +3 -1
  22. data/lib/formtastic/form_builder.rb +11 -24
  23. data/lib/formtastic/helpers.rb +1 -1
  24. data/lib/formtastic/helpers/action_helper.rb +1 -48
  25. data/lib/formtastic/helpers/enum.rb +13 -0
  26. data/lib/formtastic/helpers/errors_helper.rb +2 -2
  27. data/lib/formtastic/helpers/fieldset_wrapper.rb +13 -9
  28. data/lib/formtastic/helpers/form_helper.rb +1 -1
  29. data/lib/formtastic/helpers/input_helper.rb +23 -77
  30. data/lib/formtastic/helpers/inputs_helper.rb +27 -22
  31. data/lib/formtastic/i18n.rb +1 -1
  32. data/lib/formtastic/inputs.rb +32 -29
  33. data/lib/formtastic/inputs/base/choices.rb +1 -1
  34. data/lib/formtastic/inputs/base/collections.rb +43 -10
  35. data/lib/formtastic/inputs/base/database.rb +7 -2
  36. data/lib/formtastic/inputs/base/errors.rb +4 -4
  37. data/lib/formtastic/inputs/base/hints.rb +1 -1
  38. data/lib/formtastic/inputs/base/html.rb +7 -6
  39. data/lib/formtastic/inputs/base/naming.rb +4 -4
  40. data/lib/formtastic/inputs/base/options.rb +2 -3
  41. data/lib/formtastic/inputs/base/timeish.rb +5 -1
  42. data/lib/formtastic/inputs/base/validations.rb +38 -12
  43. data/lib/formtastic/inputs/check_boxes_input.rb +13 -5
  44. data/lib/formtastic/inputs/color_input.rb +0 -1
  45. data/lib/formtastic/inputs/country_input.rb +3 -1
  46. data/lib/formtastic/inputs/radio_input.rb +20 -0
  47. data/lib/formtastic/inputs/select_input.rb +29 -1
  48. data/lib/formtastic/inputs/time_zone_input.rb +16 -6
  49. data/lib/formtastic/localizer.rb +20 -22
  50. data/lib/formtastic/namespaced_class_finder.rb +1 -1
  51. data/lib/formtastic/version.rb +1 -1
  52. data/lib/generators/formtastic/form/form_generator.rb +1 -1
  53. data/lib/generators/formtastic/input/input_generator.rb +46 -0
  54. data/lib/generators/templates/formtastic.rb +14 -13
  55. data/lib/generators/templates/input.rb +19 -0
  56. data/sample/basic_inputs.html +1 -1
  57. data/script/integration-template.rb +74 -0
  58. data/script/integration.sh +19 -0
  59. data/spec/action_class_finder_spec.rb +1 -1
  60. data/spec/actions/button_action_spec.rb +8 -8
  61. data/spec/actions/generic_action_spec.rb +60 -60
  62. data/spec/actions/input_action_spec.rb +7 -7
  63. data/spec/actions/link_action_spec.rb +10 -10
  64. data/spec/builder/custom_builder_spec.rb +37 -21
  65. data/spec/builder/error_proc_spec.rb +4 -4
  66. data/spec/builder/semantic_fields_for_spec.rb +27 -27
  67. data/spec/fast_spec_helper.rb +12 -0
  68. data/spec/generators/formtastic/form/form_generator_spec.rb +25 -25
  69. data/spec/generators/formtastic/input/input_generator_spec.rb +124 -0
  70. data/spec/generators/formtastic/install/install_generator_spec.rb +9 -9
  71. data/spec/helpers/action_helper_spec.rb +328 -10
  72. data/spec/helpers/actions_helper_spec.rb +17 -17
  73. data/spec/helpers/form_helper_spec.rb +37 -37
  74. data/spec/helpers/input_helper_spec.rb +975 -2
  75. data/spec/helpers/inputs_helper_spec.rb +120 -105
  76. data/spec/helpers/reflection_helper_spec.rb +3 -3
  77. data/spec/helpers/semantic_errors_helper_spec.rb +22 -22
  78. data/spec/i18n_spec.rb +26 -26
  79. data/spec/input_class_finder_spec.rb +1 -1
  80. data/spec/inputs/base/collections_spec.rb +76 -0
  81. data/spec/inputs/base/validations_spec.rb +480 -0
  82. data/spec/inputs/boolean_input_spec.rb +55 -55
  83. data/spec/inputs/check_boxes_input_spec.rb +155 -108
  84. data/spec/inputs/color_input_spec.rb +51 -63
  85. data/spec/inputs/country_input_spec.rb +20 -20
  86. data/spec/inputs/custom_input_spec.rb +2 -6
  87. data/spec/inputs/datalist_input_spec.rb +1 -1
  88. data/spec/inputs/date_picker_input_spec.rb +42 -42
  89. data/spec/inputs/date_select_input_spec.rb +51 -37
  90. data/spec/inputs/datetime_picker_input_spec.rb +46 -46
  91. data/spec/inputs/datetime_select_input_spec.rb +53 -37
  92. data/spec/inputs/email_input_spec.rb +5 -5
  93. data/spec/inputs/file_input_spec.rb +6 -6
  94. data/spec/inputs/hidden_input_spec.rb +18 -18
  95. data/spec/inputs/include_blank_spec.rb +8 -8
  96. data/spec/inputs/label_spec.rb +20 -20
  97. data/spec/inputs/number_input_spec.rb +112 -112
  98. data/spec/inputs/password_input_spec.rb +5 -5
  99. data/spec/inputs/phone_input_spec.rb +5 -5
  100. data/spec/inputs/placeholder_spec.rb +5 -5
  101. data/spec/inputs/radio_input_spec.rb +84 -58
  102. data/spec/inputs/range_input_spec.rb +66 -66
  103. data/spec/inputs/readonly_spec.rb +50 -0
  104. data/spec/inputs/search_input_spec.rb +5 -5
  105. data/spec/inputs/select_input_spec.rb +149 -93
  106. data/spec/inputs/string_input_spec.rb +23 -23
  107. data/spec/inputs/text_input_spec.rb +16 -16
  108. data/spec/inputs/time_picker_input_spec.rb +43 -43
  109. data/spec/inputs/time_select_input_spec.rb +67 -54
  110. data/spec/inputs/time_zone_input_spec.rb +54 -28
  111. data/spec/inputs/url_input_spec.rb +5 -5
  112. data/spec/inputs/with_options_spec.rb +7 -7
  113. data/spec/localizer_spec.rb +17 -17
  114. data/spec/namespaced_class_finder_spec.rb +2 -2
  115. data/spec/schema.rb +21 -0
  116. data/spec/spec_helper.rb +165 -253
  117. data/spec/support/custom_macros.rb +72 -75
  118. data/spec/support/shared_examples.rb +0 -1232
  119. data/spec/support/test_environment.rb +23 -9
  120. metadata +69 -176
  121. data/.travis.yml +0 -29
  122. data/Appraisals +0 -29
  123. data/CHANGELOG +0 -31
  124. data/DEPRECATIONS +0 -49
  125. data/gemfiles/rails_3.2.gemfile +0 -7
  126. data/gemfiles/rails_4.0.4.gemfile +0 -7
  127. data/gemfiles/rails_4.1.gemfile +0 -7
  128. data/gemfiles/rails_4.2.gemfile +0 -7
  129. data/gemfiles/rails_4.gemfile +0 -7
  130. data/gemfiles/rails_edge.gemfile +0 -10
  131. data/lib/formtastic/util.rb +0 -57
  132. data/spec/helpers/namespaced_action_helper_spec.rb +0 -43
  133. data/spec/helpers/namespaced_input_helper_spec.rb +0 -36
  134. data/spec/support/deferred_garbage_collection.rb +0 -21
  135. data/spec/util_spec.rb +0 -66
@@ -1,7 +1,7 @@
1
1
  # encoding: utf-8
2
2
  require 'spec_helper'
3
3
 
4
- describe 'InputAction::Base' do
4
+ RSpec.describe 'InputAction::Base' do
5
5
 
6
6
  # Most basic Action class to test Base
7
7
  class ::GenericAction
@@ -36,15 +36,15 @@ describe 'InputAction::Base' do
36
36
  end
37
37
 
38
38
  it 'should add the #foo id to the li' do
39
- output_buffer.should have_tag('li#post_submit_action')
39
+ expect(output_buffer).to have_tag('li#post_submit_action')
40
40
  end
41
41
 
42
42
  it 'should add the .action and .generic_action classes to the li' do
43
- output_buffer.should have_tag('li.action.generic_action')
43
+ expect(output_buffer).to have_tag('li.action.generic_action')
44
44
  end
45
45
 
46
46
  it 'should pass :wrapper_html HTML attributes to the wrapper' do
47
- output_buffer.should have_tag('li.action.generic_action[@foo="bah"]')
47
+ expect(output_buffer).to have_tag('li.action.generic_action[@foo="bah"]')
48
48
  end
49
49
 
50
50
  context "when a custom :id is provided" do
@@ -58,7 +58,7 @@ describe 'InputAction::Base' do
58
58
  end
59
59
 
60
60
  it "should use the custom id" do
61
- output_buffer.should have_tag('li#foo_bah_bing')
61
+ expect(output_buffer).to have_tag('li#foo_bah_bing')
62
62
  end
63
63
 
64
64
  end
@@ -74,7 +74,7 @@ describe 'InputAction::Base' do
74
74
  end
75
75
 
76
76
  it "should add the custom class strng to the existing classes" do
77
- output_buffer.should have_tag('li.action.generic_action.foo_bah_bing')
77
+ expect(output_buffer).to have_tag('li.action.generic_action.foo_bah_bing')
78
78
  end
79
79
 
80
80
  end
@@ -90,7 +90,7 @@ describe 'InputAction::Base' do
90
90
  end
91
91
 
92
92
  it "should add the custom class strng to the existing classes" do
93
- output_buffer.should have_tag('li.action.generic_action.foo_bah_bing.zing_boo')
93
+ expect(output_buffer).to have_tag('li.action.generic_action.foo_bah_bing.zing_boo')
94
94
  end
95
95
 
96
96
  end
@@ -108,7 +108,7 @@ describe 'InputAction::Base' do
108
108
  end
109
109
 
110
110
  it 'should pass :button_html HTML attributes to the button' do
111
- output_buffer.should have_tag('li.action.generic_action input[@foo="bah"]')
111
+ expect(output_buffer).to have_tag('li.action.generic_action input[@foo="bah"]')
112
112
  end
113
113
 
114
114
  it 'should respect a default_commit_button_accesskey configuration with nil' do
@@ -116,7 +116,7 @@ describe 'InputAction::Base' do
116
116
  concat(semantic_form_for(@new_post) do |builder|
117
117
  concat(builder.action(:submit, :as => :generic))
118
118
  end)
119
- output_buffer.should_not have_tag('li.action input[@accesskey]')
119
+ expect(output_buffer).not_to have_tag('li.action input[@accesskey]')
120
120
  end
121
121
  end
122
122
 
@@ -125,7 +125,7 @@ describe 'InputAction::Base' do
125
125
  concat(semantic_form_for(@new_post) do |builder|
126
126
  concat(builder.action(:submit, :as => :generic))
127
127
  end)
128
- output_buffer.should have_tag('li.action input[@accesskey="s"]')
128
+ expect(output_buffer).to have_tag('li.action input[@accesskey="s"]')
129
129
  end
130
130
  end
131
131
 
@@ -134,8 +134,8 @@ describe 'InputAction::Base' do
134
134
  concat(semantic_form_for(@new_post) do |builder|
135
135
  concat(builder.action(:submit, :as => :generic, :accesskey => 'o'))
136
136
  end)
137
- output_buffer.should_not have_tag('li.action input[@accesskey="s"]')
138
- output_buffer.should have_tag('li.action input[@accesskey="o"]')
137
+ expect(output_buffer).not_to have_tag('li.action input[@accesskey="s"]')
138
+ expect(output_buffer).to have_tag('li.action input[@accesskey="o"]')
139
139
  end
140
140
  end
141
141
 
@@ -152,9 +152,9 @@ describe 'InputAction::Base' do
152
152
  concat(builder.action(:reset, :as => :generic, :label => "Reset!"))
153
153
  concat(builder.action(:cancel, :as => :generic, :label => "Cancel!"))
154
154
  end)
155
- output_buffer.should have_tag('li.generic_action input[@value="Click!"]')
156
- output_buffer.should have_tag('li.generic_action input[@value="Reset!"]')
157
- output_buffer.should have_tag('li.generic_action input[@value="Cancel!"]')
155
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Click!"]')
156
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Reset!"]')
157
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Cancel!"]')
158
158
  end
159
159
  end
160
160
 
@@ -185,9 +185,9 @@ describe 'InputAction::Base' do
185
185
  concat(builder.action(:reset, :as => :generic))
186
186
  concat(builder.action(:cancel, :as => :generic))
187
187
  end)
188
- output_buffer.should have_tag('li.generic_action input[@value="Submit Post"]')
189
- output_buffer.should have_tag('li.generic_action input[@value="Cancel Post"]')
190
- output_buffer.should have_tag('li.generic_action input[@value="Reset Post"]')
188
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Submit Post"]')
189
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Cancel Post"]')
190
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Reset Post"]')
191
191
  end
192
192
 
193
193
  it 'should render an input with custom resource name localized label' do
@@ -196,9 +196,9 @@ describe 'InputAction::Base' do
196
196
  concat(builder.action(:reset, :as => :generic))
197
197
  concat(builder.action(:cancel, :as => :generic))
198
198
  end)
199
- output_buffer.should have_tag('li.generic_action input[@value="Submit message"]')
200
- output_buffer.should have_tag('li.generic_action input[@value="Cancel message"]')
201
- output_buffer.should have_tag('li.generic_action input[@value="Reset message"]')
199
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Submit message"]')
200
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Cancel message"]')
201
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Reset message"]')
202
202
  end
203
203
  end
204
204
 
@@ -237,9 +237,9 @@ describe 'InputAction::Base' do
237
237
  concat(builder.action(:reset, :as => :generic))
238
238
  concat(builder.action(:cancel, :as => :generic))
239
239
  end)
240
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Submit Post"]})
241
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Reset Post"]})
242
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Cancel Post"]})
240
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Submit Post"]})
241
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Reset Post"]})
242
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Cancel Post"]})
243
243
  end
244
244
  end
245
245
 
@@ -250,9 +250,9 @@ describe 'InputAction::Base' do
250
250
  concat(builder.action(:reset, :as => :generic))
251
251
  concat(builder.action(:cancel, :as => :generic))
252
252
  end)
253
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Submit"]})
254
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Reset"]})
255
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Cancel"]})
253
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Submit"]})
254
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Reset"]})
255
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Cancel"]})
256
256
  end
257
257
  end
258
258
 
@@ -262,7 +262,7 @@ describe 'InputAction::Base' do
262
262
 
263
263
  describe 'when used on a new record' do
264
264
  before do
265
- @new_post.stub(:new_record?).and_return(true)
265
+ allow(@new_post).to receive(:new_record?).and_return(true)
266
266
  end
267
267
 
268
268
  describe 'when explicit label is provided' do
@@ -272,9 +272,9 @@ describe 'InputAction::Base' do
272
272
  concat(builder.action(:reset, :as => :generic, :label => "Reset!"))
273
273
  concat(builder.action(:cancel, :as => :generic, :label => "Cancel!"))
274
274
  end)
275
- output_buffer.should have_tag('li.generic_action input[@value="Click!"]')
276
- output_buffer.should have_tag('li.generic_action input[@value="Reset!"]')
277
- output_buffer.should have_tag('li.generic_action input[@value="Cancel!"]')
275
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Click!"]')
276
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Reset!"]')
277
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Cancel!"]')
278
278
  end
279
279
  end
280
280
 
@@ -298,9 +298,9 @@ describe 'InputAction::Base' do
298
298
  concat(builder.action(:reset, :as => :generic))
299
299
  concat(builder.action(:cancel, :as => :generic))
300
300
  end)
301
- output_buffer.should have_tag('li.generic_action input[@value="Create Post"]')
302
- output_buffer.should have_tag('li.generic_action input[@value="Reset Post"]')
303
- output_buffer.should have_tag('li.generic_action input[@value="Cancel Post"]')
301
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Create Post"]')
302
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Reset Post"]')
303
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Cancel Post"]')
304
304
  end
305
305
  end
306
306
 
@@ -337,9 +337,9 @@ describe 'InputAction::Base' do
337
337
  concat(builder.action(:reset, :as => :generic))
338
338
  concat(builder.action(:cancel, :as => :generic))
339
339
  end)
340
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Create Post"]})
341
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Reset Post"]})
342
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Cancel Post"]})
340
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Create Post"]})
341
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Reset Post"]})
342
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Cancel Post"]})
343
343
  end
344
344
  end
345
345
 
@@ -350,9 +350,9 @@ describe 'InputAction::Base' do
350
350
  concat(builder.action(:reset, :as => :generic))
351
351
  concat(builder.action(:cancel, :as => :generic))
352
352
  end)
353
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Create"]})
354
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Reset"]})
355
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Cancel"]})
353
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Create"]})
354
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Reset"]})
355
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Cancel"]})
356
356
  end
357
357
  end
358
358
 
@@ -362,7 +362,7 @@ describe 'InputAction::Base' do
362
362
 
363
363
  describe 'when used on an existing record' do
364
364
  before do
365
- @new_post.stub(:persisted?).and_return(true)
365
+ allow(@new_post).to receive(:persisted?).and_return(true)
366
366
  end
367
367
 
368
368
  describe 'when explicit label is provided' do
@@ -372,9 +372,9 @@ describe 'InputAction::Base' do
372
372
  concat(builder.action(:reset, :as => :generic, :label => "Reset!"))
373
373
  concat(builder.action(:cancel, :as => :generic, :label => "Cancel!"))
374
374
  end)
375
- output_buffer.should have_tag('li.generic_action input[@value="Click!"]')
376
- output_buffer.should have_tag('li.generic_action input[@value="Reset!"]')
377
- output_buffer.should have_tag('li.generic_action input[@value="Cancel!"]')
375
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Click!"]')
376
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Reset!"]')
377
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Cancel!"]')
378
378
  end
379
379
  end
380
380
 
@@ -405,9 +405,9 @@ describe 'InputAction::Base' do
405
405
  concat(builder.action(:reset, :as => :generic))
406
406
  concat(builder.action(:cancel, :as => :generic))
407
407
  end)
408
- output_buffer.should have_tag('li.generic_action input[@value="Save Post"]')
409
- output_buffer.should have_tag('li.generic_action input[@value="Reset Post"]')
410
- output_buffer.should have_tag('li.generic_action input[@value="Cancel Post"]')
408
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Save Post"]')
409
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Reset Post"]')
410
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Cancel Post"]')
411
411
  end
412
412
 
413
413
  it 'should render an input with custom resource name localized label' do
@@ -416,9 +416,9 @@ describe 'InputAction::Base' do
416
416
  concat(builder.action(:reset, :as => :generic))
417
417
  concat(builder.action(:cancel, :as => :generic))
418
418
  end)
419
- output_buffer.should have_tag('li.generic_action input[@value="Submit message"]')
420
- output_buffer.should have_tag('li.generic_action input[@value="Cancel message"]')
421
- output_buffer.should have_tag('li.generic_action input[@value="Reset message"]')
419
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Submit message"]')
420
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Cancel message"]')
421
+ expect(output_buffer).to have_tag('li.generic_action input[@value="Reset message"]')
422
422
  end
423
423
  end
424
424
 
@@ -456,9 +456,9 @@ describe 'InputAction::Base' do
456
456
  concat(builder.action(:reset, :as => :generic))
457
457
  concat(builder.action(:cancel, :as => :generic))
458
458
  end)
459
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Save Post"]})
460
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Reset Post"]})
461
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Cancel Post"]})
459
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Save Post"]})
460
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Reset Post"]})
461
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Cancel Post"]})
462
462
  end
463
463
  end
464
464
 
@@ -469,9 +469,9 @@ describe 'InputAction::Base' do
469
469
  concat(builder.action(:reset, :as => :generic))
470
470
  concat(builder.action(:cancel, :as => :generic))
471
471
  end)
472
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Save"]})
473
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Reset"]})
474
- output_buffer.should have_tag(%Q{li.generic_action input[@value="Custom Cancel"]})
472
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Save"]})
473
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Reset"]})
474
+ expect(output_buffer).to have_tag(%Q{li.generic_action input[@value="Custom Cancel"]})
475
475
  ::I18n.backend.store_translations :en, :formtastic => {}
476
476
  end
477
477
  end
@@ -502,7 +502,7 @@ describe 'InputAction::Base' do
502
502
  end
503
503
  @new_user_post = ::UserPost.new
504
504
 
505
- @new_user_post.stub(:new_record?).and_return(true)
505
+ allow(@new_user_post).to receive(:new_record?).and_return(true)
506
506
  concat(semantic_form_for(@new_user_post, :url => '') do |builder|
507
507
  concat(builder.action(:submit, :as => :generic))
508
508
  concat(builder.action(:reset, :as => :generic))
@@ -511,9 +511,9 @@ describe 'InputAction::Base' do
511
511
  end
512
512
 
513
513
  it "should render the string as the value of the button" do
514
- output_buffer.should have_tag('li input[@value="Create User post"]')
515
- output_buffer.should have_tag('li input[@value="Reset User post"]')
516
- output_buffer.should have_tag('li input[@value="Cancel User post"]')
514
+ expect(output_buffer).to have_tag('li input[@value="Create User post"]')
515
+ expect(output_buffer).to have_tag('li input[@value="Reset User post"]')
516
+ expect(output_buffer).to have_tag('li input[@value="Cancel User post"]')
517
517
  end
518
518
 
519
519
  end
@@ -1,7 +1,7 @@
1
1
  # encoding: utf-8
2
2
  require 'spec_helper'
3
3
 
4
- describe 'InputAction', 'when submitting' do
4
+ RSpec.describe 'InputAction', 'when submitting' do
5
5
 
6
6
  include FormtasticSpecHelper
7
7
 
@@ -15,12 +15,12 @@ describe 'InputAction', 'when submitting' do
15
15
  end
16
16
 
17
17
  it 'should render a submit type of input' do
18
- output_buffer.should have_tag('li.action.input_action input[@type="submit"]')
18
+ expect(output_buffer).to have_tag('li.action.input_action input[@type="submit"]')
19
19
  end
20
20
 
21
21
  end
22
22
 
23
- describe 'InputAction', 'when resetting' do
23
+ RSpec.describe 'InputAction', 'when resetting' do
24
24
 
25
25
  include FormtasticSpecHelper
26
26
 
@@ -34,12 +34,12 @@ describe 'InputAction', 'when resetting' do
34
34
  end
35
35
 
36
36
  it 'should render a reset type of input' do
37
- output_buffer.should have_tag('li.action.input_action input[@type="reset"]')
37
+ expect(output_buffer).to have_tag('li.action.input_action input[@type="reset"]')
38
38
  end
39
39
 
40
40
  end
41
41
 
42
- describe 'InputAction', 'when cancelling' do
42
+ RSpec.describe 'InputAction', 'when cancelling' do
43
43
 
44
44
  include FormtasticSpecHelper
45
45
 
@@ -49,11 +49,11 @@ describe 'InputAction', 'when cancelling' do
49
49
  end
50
50
 
51
51
  it 'should raise an error' do
52
- lambda {
52
+ expect {
53
53
  concat(semantic_form_for(@new_post) do |builder|
54
54
  concat(builder.action(:cancel, :as => :input))
55
55
  end)
56
- }.should raise_error(Formtastic::UnsupportedMethodForAction)
56
+ }.to raise_error(Formtastic::UnsupportedMethodForAction)
57
57
  end
58
58
 
59
59
  end
@@ -1,7 +1,7 @@
1
1
  # encoding: utf-8
2
2
  require 'spec_helper'
3
3
 
4
- describe 'LinkAction', 'when cancelling' do
4
+ RSpec.describe 'LinkAction', 'when cancelling' do
5
5
 
6
6
  include FormtasticSpecHelper
7
7
 
@@ -18,7 +18,7 @@ describe 'LinkAction', 'when cancelling' do
18
18
  end
19
19
 
20
20
  it 'should render a submit type of input' do
21
- output_buffer.should have_tag('li.action.link_action a[@href="javascript:history.back()"]')
21
+ expect(output_buffer).to have_tag('li.action.link_action a[@href="javascript:history.back()"]')
22
22
  end
23
23
 
24
24
  end
@@ -32,7 +32,7 @@ describe 'LinkAction', 'when cancelling' do
32
32
  end
33
33
 
34
34
  it 'should render a submit type of input' do
35
- output_buffer.should have_tag('li.action.link_action a[@href="http://foo.bah/baz"]')
35
+ expect(output_buffer).to have_tag('li.action.link_action a[@href="http://foo.bah/baz"]')
36
36
  end
37
37
 
38
38
  end
@@ -46,14 +46,14 @@ describe 'LinkAction', 'when cancelling' do
46
46
  end
47
47
 
48
48
  it 'should render a submit type of input' do
49
- output_buffer.should have_tag('li.action.link_action a[@href="/mock/path"]')
49
+ expect(output_buffer).to have_tag('li.action.link_action a[@href="/mock/path"]')
50
50
  end
51
51
 
52
52
  end
53
53
 
54
54
  end
55
55
 
56
- describe 'LinkAction', 'when submitting' do
56
+ RSpec.describe 'LinkAction', 'when submitting' do
57
57
 
58
58
  include FormtasticSpecHelper
59
59
 
@@ -63,16 +63,16 @@ describe 'LinkAction', 'when submitting' do
63
63
  end
64
64
 
65
65
  it 'should raise an error' do
66
- lambda {
66
+ expect {
67
67
  concat(semantic_form_for(@new_post) do |builder|
68
68
  concat(builder.action(:submit, :as => :link))
69
69
  end)
70
- }.should raise_error(Formtastic::UnsupportedMethodForAction)
70
+ }.to raise_error(Formtastic::UnsupportedMethodForAction)
71
71
  end
72
72
 
73
73
  end
74
74
 
75
- describe 'LinkAction', 'when submitting' do
75
+ RSpec.describe 'LinkAction', 'when submitting' do
76
76
 
77
77
  include FormtasticSpecHelper
78
78
 
@@ -82,11 +82,11 @@ describe 'LinkAction', 'when submitting' do
82
82
  end
83
83
 
84
84
  it 'should raise an error' do
85
- lambda {
85
+ expect {
86
86
  concat(semantic_form_for(@new_post) do |builder|
87
87
  concat(builder.action(:reset, :as => :link))
88
88
  end)
89
- }.should raise_error(Formtastic::UnsupportedMethodForAction)
89
+ }.to raise_error(Formtastic::UnsupportedMethodForAction)
90
90
  end
91
91
 
92
92
  end
@@ -1,13 +1,13 @@
1
1
  # encoding: utf-8
2
2
  require 'spec_helper'
3
3
 
4
- describe 'Formtastic::Helpers::FormHelper.builder' do
4
+ RSpec.describe 'Formtastic::Helpers::FormHelper.builder' do
5
5
 
6
6
  include FormtasticSpecHelper
7
7
 
8
8
  class MyCustomFormBuilder < Formtastic::FormBuilder
9
9
  end
10
-
10
+
11
11
  # TODO should be a separate spec for custom inputs
12
12
  class Formtastic::Inputs::AwesomeInput
13
13
  include Formtastic::Inputs::Base
@@ -22,32 +22,32 @@ describe 'Formtastic::Helpers::FormHelper.builder' do
22
22
  end
23
23
 
24
24
  it 'is the Formtastic::FormBuilder by default' do
25
- Formtastic::Helpers::FormHelper.builder.should == Formtastic::FormBuilder
25
+ expect(Formtastic::Helpers::FormHelper.builder).to eq(Formtastic::FormBuilder)
26
26
  end
27
27
 
28
28
  it 'can be configured to use your own custom form builder' do
29
29
  # Set it to a custom builder class
30
30
  Formtastic::Helpers::FormHelper.builder = MyCustomFormBuilder
31
- Formtastic::Helpers::FormHelper.builder.should == MyCustomFormBuilder
31
+ expect(Formtastic::Helpers::FormHelper.builder).to eq(MyCustomFormBuilder)
32
32
 
33
33
  # Reset it to the default
34
34
  Formtastic::Helpers::FormHelper.builder = Formtastic::FormBuilder
35
- Formtastic::Helpers::FormHelper.builder.should == Formtastic::FormBuilder
35
+ expect(Formtastic::Helpers::FormHelper.builder).to eq(Formtastic::FormBuilder)
36
36
  end
37
37
 
38
38
  it 'should allow custom settings per form builder subclass' do
39
39
  with_config(:all_fields_required_by_default, true) do
40
40
  MyCustomFormBuilder.all_fields_required_by_default = false
41
41
 
42
- MyCustomFormBuilder.all_fields_required_by_default.should be_falsey
43
- Formtastic::FormBuilder.all_fields_required_by_default.should be_truthy
42
+ expect(MyCustomFormBuilder.all_fields_required_by_default).to be_falsey
43
+ expect(Formtastic::FormBuilder.all_fields_required_by_default).to be_truthy
44
44
  end
45
45
  end
46
46
 
47
47
  describe "when using a custom builder" do
48
48
 
49
49
  before do
50
- @new_post.stub(:title)
50
+ allow(@new_post).to receive(:title)
51
51
  Formtastic::Helpers::FormHelper.builder = MyCustomFormBuilder
52
52
  end
53
53
 
@@ -59,10 +59,10 @@ describe 'Formtastic::Helpers::FormHelper.builder' do
59
59
 
60
60
  it "should yield an instance of the custom builder" do
61
61
  semantic_form_for(@new_post) do |builder|
62
- builder.class.should.kind_of?(MyCustomFormBuilder)
62
+ expect(builder.class).to be(MyCustomFormBuilder)
63
63
  end
64
64
  end
65
-
65
+
66
66
  # TODO should be a separate spec for custom inputs
67
67
  it "should allow me to call my custom input" do
68
68
  semantic_form_for(@new_post) do |builder|
@@ -70,31 +70,47 @@ describe 'Formtastic::Helpers::FormHelper.builder' do
70
70
  end
71
71
  end
72
72
 
73
- # See: https://github.com/justinfrench/formtastic/issues/657
73
+ # See: https://github.com/formtastic/formtastic/issues/657
74
74
  it "should not conflict with navigasmic" do
75
- self.class.any_instance.stub(:builder).and_return('navigasmic')
76
-
77
- lambda { semantic_form_for(@new_post) { |f| } }.should_not raise_error
75
+ allow_any_instance_of(self.class).to receive(:builder).and_return('navigasmic')
76
+
77
+ expect { semantic_form_for(@new_post) { |f| } }.not_to raise_error
78
78
  end
79
79
 
80
+ it "should use the custom builder's skipped_columns config for inputs" do
81
+ class AnotherCustomFormBuilder < Formtastic::FormBuilder
82
+ configure :skipped_columns, [:title, :created_at]
83
+ end
84
+ #AnotherCustomFormBuilder.skipped_columns = [:title, :created_at]
85
+
86
+ concat(semantic_form_for(@new_post, builder: AnotherCustomFormBuilder) do |builder|
87
+ concat(builder.inputs)
88
+ end)
89
+
90
+ expect(output_buffer).to_not have_tag('input#post_title')
91
+ expect(output_buffer).to_not have_tag('li#post_created_at_input')
92
+ expect(output_buffer).to have_tag('textarea#post_body')
93
+ end
80
94
  end
81
95
 
82
96
  describe "fields_for" do
83
97
 
84
98
  it "should yield an instance of the parent form builder" do
85
- @new_post.stub(:comment).and_return([@fred])
86
- @new_post.stub(:comment_attributes=)
99
+ allow(@new_post).to receive(:comment).and_return([@fred])
100
+ allow(@new_post).to receive(:comment_attributes=)
87
101
  semantic_form_for(@new_post, :builder => MyCustomFormBuilder) do |builder|
88
- builder.class.should.kind_of?(MyCustomFormBuilder)
89
-
102
+ expect(builder.class).to be(MyCustomFormBuilder)
103
+
90
104
  builder.fields_for(:comment) do |nested_builder|
91
- nested_builder.class.should.kind_of?(MyCustomFormBuilder)
105
+ expect(nested_builder.class).to be(MyCustomFormBuilder)
92
106
  end
93
107
  end
94
108
  end
95
109
 
96
110
  end
97
111
 
112
+
113
+
98
114
  end
99
115
 
100
116
  describe "when using a builder passed to form options" do
@@ -102,10 +118,10 @@ describe 'Formtastic::Helpers::FormHelper.builder' do
102
118
  describe "fields_for" do
103
119
 
104
120
  it "should yield an instance of the parent form builder" do
105
- @new_post.stub(:author_attributes=)
121
+ allow(@new_post).to receive(:author_attributes=)
106
122
  semantic_form_for(@new_post, :builder => MyCustomFormBuilder) do |builder|
107
123
  builder.fields_for(:author) do |nested_builder|
108
- nested_builder.class.should.kind_of?(MyCustomFormBuilder)
124
+ expect(nested_builder.class).to be(MyCustomFormBuilder)
109
125
  end
110
126
  end
111
127
  end