middleman 2.0.7 → 2.0.8
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +1 -0
- data/.travis.yml +0 -1
- data/CHANGELOG +8 -0
- data/Gemfile +1 -1
- data/features/data.feature +6 -1
- data/features/markdown.feature +7 -0
- data/features/sprockets.feature +11 -1
- data/features/sprockets_gems.feature +3 -3
- data/fixtures/sprockets-app/source/jquery_include.js +1 -0
- data/fixtures/test-app/config.rb +2 -0
- data/fixtures/test-app/source/data2.html.liquid +1 -0
- data/fixtures/test-app/source/javascripts/multiple_engines.js.coffee.erb +1 -0
- data/fixtures/test-app/source/markdown.html.markdown +1 -0
- data/lib/middleman.rb +0 -6
- data/lib/middleman/base.rb +6 -1
- data/lib/middleman/builder.rb +6 -4
- data/lib/middleman/core_extensions/data.rb +35 -5
- data/lib/middleman/core_extensions/front_matter.rb +9 -2
- data/lib/middleman/core_extensions/sprockets.rb +25 -1
- data/lib/middleman/renderers/markdown.rb +25 -2
- data/lib/middleman/version.rb +1 -1
- data/middleman.gemspec +7 -6
- metadata +112 -251
- data/lib/middleman/vendor/padrino-core-0.10.0/.document +0 -5
- data/lib/middleman/vendor/padrino-core-0.10.0/.gitignore +0 -22
- data/lib/middleman/vendor/padrino-core-0.10.0/LICENSE +0 -20
- data/lib/middleman/vendor/padrino-core-0.10.0/README.rdoc +0 -294
- data/lib/middleman/vendor/padrino-core-0.10.0/Rakefile +0 -5
- data/lib/middleman/vendor/padrino-core-0.10.0/bin/padrino +0 -9
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core.rb +0 -119
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/application.rb +0 -259
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/application/rendering.rb +0 -228
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/application/routing.rb +0 -821
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/application/showexceptions.rb +0 -18
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/caller.rb +0 -45
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/cli/adapter.rb +0 -24
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/cli/base.rb +0 -152
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/cli/console.rb +0 -20
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/cli/rake.rb +0 -24
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/cli/rake_tasks.rb +0 -59
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/command.rb +0 -27
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/images/404.png +0 -0
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/images/500.png +0 -0
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/loader.rb +0 -182
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/cz.yml +0 -30
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/da.yml +0 -30
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/de.yml +0 -30
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/en.yml +0 -30
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/es.yml +0 -30
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/fr.yml +0 -30
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/hu.yml +0 -30
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/it.yml +0 -37
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/ja.yml +0 -30
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/nl.yml +0 -30
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/no.yml +0 -31
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/pl.yml +0 -30
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/pt_br.yml +0 -37
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/ru.yml +0 -30
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/tr.yml +0 -30
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/uk.yml +0 -30
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/zh_cn.yml +0 -30
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/zh_tw.yml +0 -30
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/logger.rb +0 -344
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/mounter.rb +0 -192
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/reloader.rb +0 -247
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/router.rb +0 -79
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/server.rb +0 -70
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/support_lite.rb +0 -135
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/tasks.rb +0 -23
- data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/version.rb +0 -15
- data/lib/middleman/vendor/padrino-core-0.10.0/padrino-core.gemspec +0 -38
- data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/apps/.components +0 -6
- data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/apps/.gitignore +0 -7
- data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/apps/complex.rb +0 -27
- data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/apps/simple.rb +0 -33
- data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/dependencies/a.rb +0 -9
- data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/dependencies/b.rb +0 -4
- data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/dependencies/c.rb +0 -1
- data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/dependencies/circular/e.rb +0 -13
- data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/dependencies/circular/f.rb +0 -2
- data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/dependencies/circular/g.rb +0 -2
- data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/dependencies/d.rb +0 -4
- data/lib/middleman/vendor/padrino-core-0.10.0/test/helper.rb +0 -101
- data/lib/middleman/vendor/padrino-core-0.10.0/test/test_application.rb +0 -83
- data/lib/middleman/vendor/padrino-core-0.10.0/test/test_core.rb +0 -79
- data/lib/middleman/vendor/padrino-core-0.10.0/test/test_dependencies.rb +0 -44
- data/lib/middleman/vendor/padrino-core-0.10.0/test/test_filters.rb +0 -266
- data/lib/middleman/vendor/padrino-core-0.10.0/test/test_logger.rb +0 -91
- data/lib/middleman/vendor/padrino-core-0.10.0/test/test_mounter.rb +0 -176
- data/lib/middleman/vendor/padrino-core-0.10.0/test/test_reloader_complex.rb +0 -66
- data/lib/middleman/vendor/padrino-core-0.10.0/test/test_reloader_simple.rb +0 -97
- data/lib/middleman/vendor/padrino-core-0.10.0/test/test_rendering.rb +0 -437
- data/lib/middleman/vendor/padrino-core-0.10.0/test/test_router.rb +0 -146
- data/lib/middleman/vendor/padrino-core-0.10.0/test/test_routing.rb +0 -1491
- data/lib/middleman/vendor/padrino-helpers-0.10.0/.document +0 -5
- data/lib/middleman/vendor/padrino-helpers-0.10.0/.gitignore +0 -21
- data/lib/middleman/vendor/padrino-helpers-0.10.0/LICENSE +0 -20
- data/lib/middleman/vendor/padrino-helpers-0.10.0/README.rdoc +0 -239
- data/lib/middleman/vendor/padrino-helpers-0.10.0/Rakefile +0 -5
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers.rb +0 -51
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/asset_tag_helpers.rb +0 -288
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/form_builder/abstract_form_builder.rb +0 -220
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/form_builder/standard_form_builder.rb +0 -43
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/form_helpers.rb +0 -446
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/format_helpers.rb +0 -260
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/cz.yml +0 -103
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/da.yml +0 -91
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/de.yml +0 -78
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/en.yml +0 -103
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/es.yml +0 -103
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/fr.yml +0 -79
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/hu.yml +0 -103
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/it.yml +0 -85
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/ja.yml +0 -103
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/nl.yml +0 -78
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/no.yml +0 -91
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/pl.yml +0 -95
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/pt_br.yml +0 -103
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/ru.yml +0 -103
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/tr.yml +0 -103
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/uk.yml +0 -103
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/zh_cn.yml +0 -103
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/zh_tw.yml +0 -103
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/number_helpers.rb +0 -273
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/output_helpers.rb +0 -128
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/output_helpers/abstract_handler.rb +0 -103
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/output_helpers/erb_handler.rb +0 -79
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/output_helpers/haml_handler.rb +0 -64
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/output_helpers/slim_handler.rb +0 -82
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/render_helpers.rb +0 -40
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/tag_helpers.rb +0 -59
- data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/translation_helpers.rb +0 -21
- data/lib/middleman/vendor/padrino-helpers-0.10.0/padrino-helpers.gemspec +0 -27
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/app.rb +0 -73
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/capture_concat.erb +0 -14
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/capture_concat.haml +0 -12
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/capture_concat.slim +0 -13
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/content_for.erb +0 -11
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/content_for.haml +0 -9
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/content_for.slim +0 -9
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/content_tag.erb +0 -11
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/content_tag.haml +0 -9
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/content_tag.slim +0 -9
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/current_engine.erb +0 -5
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/current_engine.haml +0 -5
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/current_engine.slim +0 -5
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/fields_for.erb +0 -20
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/fields_for.haml +0 -15
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/fields_for.slim +0 -15
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/form_for.erb +0 -56
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/form_for.haml +0 -47
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/form_for.slim +0 -47
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/form_tag.erb +0 -56
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/form_tag.haml +0 -45
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/form_tag.slim +0 -45
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/link_to.erb +0 -5
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/link_to.haml +0 -4
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/link_to.slim +0 -4
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/mail_to.erb +0 -3
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/mail_to.haml +0 -3
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/mail_to.slim +0 -3
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/meta_tag.erb +0 -3
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/meta_tag.haml +0 -3
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/meta_tag.slim +0 -3
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/partials/_erb.erb +0 -1
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/partials/_haml.haml +0 -1
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/partials/_slim.slim +0 -1
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/simple_partial.erb +0 -1
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/simple_partial.haml +0 -1
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/simple_partial.slim +0 -1
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/app.rb +0 -45
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/current_engine.haml +0 -5
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/current_engines/_erb.erb +0 -1
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/current_engines/_haml.haml +0 -1
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/current_engines/_slim.slim +0 -1
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/erb/test.erb +0 -1
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/explicit_engine.haml +0 -5
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/haml/test.haml +0 -1
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/template/_user.haml +0 -7
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/template/haml_template.haml +0 -1
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/template/some_template.haml +0 -2
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/helper.rb +0 -78
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_asset_tag_helpers.rb +0 -320
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_form_builder.rb +0 -998
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_form_helpers.rb +0 -645
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_format_helpers.rb +0 -227
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_number_helpers.rb +0 -136
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_output_helpers.rb +0 -133
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_render_helpers.rb +0 -69
- data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_tag_helpers.rb +0 -100
@@ -1,645 +0,0 @@
|
|
1
|
-
require File.expand_path(File.dirname(__FILE__) + '/helper')
|
2
|
-
require File.expand_path(File.dirname(__FILE__) + '/fixtures/markup_app/app')
|
3
|
-
|
4
|
-
class TestFormHelpers < Test::Unit::TestCase
|
5
|
-
include Padrino::Helpers::FormHelpers
|
6
|
-
|
7
|
-
def app
|
8
|
-
MarkupDemo.tap { |app| app.set :environment, :test }
|
9
|
-
end
|
10
|
-
|
11
|
-
context 'for #form_tag method' do
|
12
|
-
should "display correct forms in ruby" do
|
13
|
-
actual_html = form_tag('/register', :"accept-charset" => "UTF-8", :class => 'test', :method => "post") { "Demo" }
|
14
|
-
assert_has_tag(:form, :"accept-charset" => "UTF-8", :class => "test") { actual_html }
|
15
|
-
assert_has_tag('form input', :type => 'hidden', :name => '_method', :count => 0) { actual_html }
|
16
|
-
end
|
17
|
-
|
18
|
-
should "display correct text inputs within form_tag" do
|
19
|
-
actual_html = form_tag('/register', :"accept-charset" => "UTF-8", :class => 'test') { text_field_tag(:username) }
|
20
|
-
assert_has_tag('form input', :type => 'text', :name => "username") { actual_html }
|
21
|
-
end
|
22
|
-
|
23
|
-
should "display correct form with remote" do
|
24
|
-
actual_html = form_tag('/update', :"accept-charset" => "UTF-8", :class => 'put-form', :remote => true) { "Demo" }
|
25
|
-
assert_has_tag(:form, :class => "put-form", :"accept-charset" => "UTF-8", :"data-remote" => 'true') { actual_html }
|
26
|
-
assert_has_no_tag(:form, "data-method" => 'post') { actual_html }
|
27
|
-
end
|
28
|
-
|
29
|
-
should "display correct form with remote and method is put" do
|
30
|
-
actual_html = form_tag('/update', :"accept-charset" => "UTF-8", :method => 'put', :remote => true) { "Demo" }
|
31
|
-
assert_has_tag(:form, "data-remote" => 'true', :"accept-charset" => "UTF-8", :"data-method" => 'put') { actual_html }
|
32
|
-
assert_has_tag('form input', :type => 'hidden', :name => "_method", :value => 'put') { actual_html }
|
33
|
-
end
|
34
|
-
|
35
|
-
should "display correct form with method :put" do
|
36
|
-
actual_html = form_tag('/update', :"accept-charset" => "UTF-8", :class => 'put-form', :method => "put") { "Demo" }
|
37
|
-
assert_has_tag(:form, :class => "put-form", :"accept-charset" => "UTF-8", :method => 'post') { actual_html }
|
38
|
-
assert_has_tag('form input', :type => 'hidden', :name => "_method", :value => 'put') { actual_html }
|
39
|
-
end
|
40
|
-
|
41
|
-
should "display correct form with method :delete and charset" do
|
42
|
-
actual_html = form_tag('/remove', :"accept-charset" => "UTF-8", :class => 'delete-form', :method => "delete") { "Demo" }
|
43
|
-
assert_has_tag(:form, :class => "delete-form", :"accept-charset" => "UTF-8", :method => 'post') { actual_html }
|
44
|
-
assert_has_tag('form input', :type => 'hidden', :name => "_method", :value => 'delete') { actual_html }
|
45
|
-
end
|
46
|
-
|
47
|
-
should "display correct form with charset" do
|
48
|
-
actual_html = form_tag('/charset', :"accept-charset" => "UTF-8", :class => 'charset-form') { "Demo" }
|
49
|
-
assert_has_tag(:form, :class => "charset-form", :"accept-charset" => "UTF-8", :method => 'post') { actual_html }
|
50
|
-
end
|
51
|
-
|
52
|
-
should "display correct form with multipart encoding" do
|
53
|
-
actual_html = form_tag('/remove', :"accept-charset" => "UTF-8", :multipart => true) { "Demo" }
|
54
|
-
assert_has_tag(:form, :enctype => "multipart/form-data") { actual_html }
|
55
|
-
end
|
56
|
-
|
57
|
-
should "display correct forms in erb" do
|
58
|
-
visit '/erb/form_tag'
|
59
|
-
assert_have_selector 'form.simple-form', :action => '/simple'
|
60
|
-
assert_have_selector 'form.advanced-form', :action => '/advanced', :id => 'advanced', :method => 'get'
|
61
|
-
end
|
62
|
-
|
63
|
-
should "display correct forms in haml" do
|
64
|
-
visit '/haml/form_tag'
|
65
|
-
assert_have_selector 'form.simple-form', :action => '/simple'
|
66
|
-
assert_have_selector 'form.advanced-form', :action => '/advanced', :id => 'advanced', :method => 'get'
|
67
|
-
end
|
68
|
-
|
69
|
-
should "display correct forms in slim" do
|
70
|
-
visit '/slim/form_tag'
|
71
|
-
assert_have_selector 'form.simple-form', :action => '/simple'
|
72
|
-
assert_have_selector 'form.advanced-form', :action => '/advanced', :id => 'advanced', :method => 'get'
|
73
|
-
end
|
74
|
-
end
|
75
|
-
|
76
|
-
context 'for #field_set_tag method' do
|
77
|
-
should "display correct field_sets in ruby" do
|
78
|
-
actual_html = field_set_tag("Basic", :class => 'basic') { "Demo" }
|
79
|
-
assert_has_tag(:fieldset, :class => 'basic') { actual_html }
|
80
|
-
assert_has_tag('fieldset legend', :content => "Basic") { actual_html }
|
81
|
-
end
|
82
|
-
|
83
|
-
should "display correct field_sets in erb" do
|
84
|
-
visit '/erb/form_tag'
|
85
|
-
assert_have_selector 'form.simple-form fieldset', :count => 1
|
86
|
-
assert_have_no_selector 'form.simple-form fieldset legend'
|
87
|
-
assert_have_selector 'form.advanced-form fieldset', :count => 1, :class => 'advanced-field-set'
|
88
|
-
assert_have_selector 'form.advanced-form fieldset legend', :content => "Advanced"
|
89
|
-
end
|
90
|
-
|
91
|
-
should "display correct field_sets in haml" do
|
92
|
-
visit '/haml/form_tag'
|
93
|
-
assert_have_selector 'form.simple-form fieldset', :count => 1
|
94
|
-
assert_have_no_selector 'form.simple-form fieldset legend'
|
95
|
-
assert_have_selector 'form.advanced-form fieldset', :count => 1, :class => 'advanced-field-set'
|
96
|
-
assert_have_selector 'form.advanced-form fieldset legend', :content => "Advanced"
|
97
|
-
end
|
98
|
-
|
99
|
-
should "display correct field_sets in slim" do
|
100
|
-
visit '/slim/form_tag'
|
101
|
-
assert_have_selector 'form.simple-form fieldset', :count => 1
|
102
|
-
assert_have_no_selector 'form.simple-form fieldset legend'
|
103
|
-
assert_have_selector 'form.advanced-form fieldset', :count => 1, :class => 'advanced-field-set'
|
104
|
-
assert_have_selector 'form.advanced-form fieldset legend', :content => "Advanced"
|
105
|
-
end
|
106
|
-
end
|
107
|
-
|
108
|
-
context 'for #error_messages_for method' do
|
109
|
-
should "display correct error messages list in ruby" do
|
110
|
-
user = mock_model("User", :errors => { :a => "1", :b => "2" }, :blank? => false)
|
111
|
-
actual_html = error_messages_for(user)
|
112
|
-
assert_has_tag('div.field-errors') { actual_html }
|
113
|
-
assert_has_tag('div.field-errors h2', :content => "2 errors prohibited this User from being saved") { actual_html }
|
114
|
-
assert_has_tag('div.field-errors p', :content => "There were problems with the following fields:") { actual_html }
|
115
|
-
assert_has_tag('div.field-errors ul') { actual_html }
|
116
|
-
assert_has_tag('div.field-errors ul li', :count => 2) { actual_html }
|
117
|
-
end
|
118
|
-
|
119
|
-
should "display correct error messages list in erb" do
|
120
|
-
visit '/erb/form_tag'
|
121
|
-
assert_have_no_selector 'form.simple-form .field-errors'
|
122
|
-
assert_have_selector 'form.advanced-form .field-errors'
|
123
|
-
assert_have_selector 'form.advanced-form .field-errors h2', :content => "There are problems with saving user!"
|
124
|
-
assert_have_selector 'form.advanced-form .field-errors p', :content => "There were problems with the following fields:"
|
125
|
-
assert_have_selector 'form.advanced-form .field-errors ul'
|
126
|
-
assert_have_selector 'form.advanced-form .field-errors ul li', :count => 4
|
127
|
-
assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Email must be a email"
|
128
|
-
assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Fake must be valid"
|
129
|
-
assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Second must be present"
|
130
|
-
assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Third must be a number"
|
131
|
-
end
|
132
|
-
|
133
|
-
should "display correct error messages list in haml" do
|
134
|
-
visit '/haml/form_tag'
|
135
|
-
assert_have_no_selector 'form.simple-form .field-errors'
|
136
|
-
assert_have_selector 'form.advanced-form .field-errors'
|
137
|
-
assert_have_selector 'form.advanced-form .field-errors h2', :content => "There are problems with saving user!"
|
138
|
-
assert_have_selector 'form.advanced-form .field-errors p', :content => "There were problems with the following fields:"
|
139
|
-
assert_have_selector 'form.advanced-form .field-errors ul'
|
140
|
-
assert_have_selector 'form.advanced-form .field-errors ul li', :count => 4
|
141
|
-
assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Email must be a email"
|
142
|
-
assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Fake must be valid"
|
143
|
-
assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Second must be present"
|
144
|
-
assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Third must be a number"
|
145
|
-
end
|
146
|
-
|
147
|
-
should "display correct error messages list in slim" do
|
148
|
-
visit '/slim/form_tag'
|
149
|
-
assert_have_no_selector 'form.simple-form .field-errors'
|
150
|
-
assert_have_selector 'form.advanced-form .field-errors'
|
151
|
-
assert_have_selector 'form.advanced-form .field-errors h2', :content => "There are problems with saving user!"
|
152
|
-
assert_have_selector 'form.advanced-form .field-errors p', :content => "There were problems with the following fields:"
|
153
|
-
assert_have_selector 'form.advanced-form .field-errors ul'
|
154
|
-
assert_have_selector 'form.advanced-form .field-errors ul li', :count => 4
|
155
|
-
assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Email must be a email"
|
156
|
-
assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Fake must be valid"
|
157
|
-
assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Second must be present"
|
158
|
-
assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Third must be a number"
|
159
|
-
end
|
160
|
-
end
|
161
|
-
|
162
|
-
context 'for #error_message_on method' do
|
163
|
-
should "display correct error message on specified model name in ruby" do
|
164
|
-
@user = mock_model("User", :errors => { :a => "1", :b => "2" }, :blank? => false)
|
165
|
-
actual_html = error_message_on(:user, :a, :prepend => "foo", :append => "bar")
|
166
|
-
assert_has_tag('span.error', :content => "foo 1 bar") { actual_html }
|
167
|
-
end
|
168
|
-
|
169
|
-
should "display correct error message on specified object in ruby" do
|
170
|
-
@bob = mock_model("User", :errors => { :a => "1", :b => "2" }, :blank? => false)
|
171
|
-
actual_html = error_message_on(@bob, :a, :prepend => "foo", :append => "bar")
|
172
|
-
assert_has_tag('span.error', :content => "foo 1 bar") { actual_html }
|
173
|
-
end
|
174
|
-
|
175
|
-
should "display no message when error isn't present" do
|
176
|
-
@user = mock_model("User", :errors => { :a => "1", :b => "2" }, :blank? => false)
|
177
|
-
actual_html = error_message_on(:user, :fake, :prepend => "foo", :append => "bar")
|
178
|
-
assert actual_html.blank?
|
179
|
-
end
|
180
|
-
end
|
181
|
-
|
182
|
-
context 'for #label_tag method' do
|
183
|
-
should "display label tag in ruby" do
|
184
|
-
actual_html = label_tag(:username, :class => 'long-label', :caption => "Nickname")
|
185
|
-
assert_has_tag(:label, :for => 'username', :class => 'long-label', :content => "Nickname") { actual_html }
|
186
|
-
end
|
187
|
-
|
188
|
-
should "display label tag in ruby with required" do
|
189
|
-
actual_html = label_tag(:username, :caption => "Nickname", :required => true)
|
190
|
-
assert_has_tag(:label, :for => 'username', :content => 'Nickname') { actual_html }
|
191
|
-
assert_has_tag('label[for=username] span.required', :content => "*") { actual_html }
|
192
|
-
end
|
193
|
-
|
194
|
-
should "display label tag in erb for simple form" do
|
195
|
-
visit '/erb/form_tag'
|
196
|
-
assert_have_selector 'form.simple-form label', :count => 4
|
197
|
-
assert_have_selector 'form.simple-form label', :content => "Username", :for => 'username'
|
198
|
-
assert_have_selector 'form.simple-form label', :content => "Password", :for => 'password'
|
199
|
-
assert_have_selector 'form.simple-form label', :content => "Gender", :for => 'gender'
|
200
|
-
end
|
201
|
-
should "display label tag in erb for advanced form" do
|
202
|
-
visit '/erb/form_tag'
|
203
|
-
assert_have_selector 'form.advanced-form label', :count => 6
|
204
|
-
assert_have_selector 'form.advanced-form label.first', :content => "Nickname", :for => 'username'
|
205
|
-
assert_have_selector 'form.advanced-form label.first', :content => "Password", :for => 'password'
|
206
|
-
assert_have_selector 'form.advanced-form label.about', :content => "About Me", :for => 'about'
|
207
|
-
assert_have_selector 'form.advanced-form label.photo', :content => "Photo" , :for => 'photo'
|
208
|
-
assert_have_selector 'form.advanced-form label.gender', :content => "Gender" , :for => 'gender'
|
209
|
-
end
|
210
|
-
|
211
|
-
should "display label tag in haml for simple form" do
|
212
|
-
visit '/haml/form_tag'
|
213
|
-
assert_have_selector 'form.simple-form label', :count => 4
|
214
|
-
assert_have_selector 'form.simple-form label', :content => "Username", :for => 'username'
|
215
|
-
assert_have_selector 'form.simple-form label', :content => "Password", :for => 'password'
|
216
|
-
assert_have_selector 'form.simple-form label', :content => "Gender", :for => 'gender'
|
217
|
-
end
|
218
|
-
|
219
|
-
should "display label tag in haml for advanced form" do
|
220
|
-
visit '/haml/form_tag'
|
221
|
-
assert_have_selector 'form.advanced-form label', :count => 6
|
222
|
-
assert_have_selector 'form.advanced-form label.first', :content => "Nickname", :for => 'username'
|
223
|
-
assert_have_selector 'form.advanced-form label.first', :content => "Password", :for => 'password'
|
224
|
-
assert_have_selector 'form.advanced-form label.about', :content => "About Me", :for => 'about'
|
225
|
-
assert_have_selector 'form.advanced-form label.photo', :content => "Photo" , :for => 'photo'
|
226
|
-
assert_have_selector 'form.advanced-form label.gender', :content => "Gender" , :for => 'gender'
|
227
|
-
end
|
228
|
-
|
229
|
-
should "display label tag in slim for simple form" do
|
230
|
-
visit '/slim/form_tag'
|
231
|
-
assert_have_selector 'form.simple-form label', :count => 4
|
232
|
-
assert_have_selector 'form.simple-form label', :content => "Username", :for => 'username'
|
233
|
-
assert_have_selector 'form.simple-form label', :content => "Password", :for => 'password'
|
234
|
-
assert_have_selector 'form.simple-form label', :content => "Gender", :for => 'gender'
|
235
|
-
end
|
236
|
-
|
237
|
-
should "display label tag in slim for advanced form" do
|
238
|
-
visit '/slim/form_tag'
|
239
|
-
assert_have_selector 'form.advanced-form label', :count => 6
|
240
|
-
assert_have_selector 'form.advanced-form label.first', :content => "Nickname", :for => 'username'
|
241
|
-
assert_have_selector 'form.advanced-form label.first', :content => "Password", :for => 'password'
|
242
|
-
assert_have_selector 'form.advanced-form label.about', :content => "About Me", :for => 'about'
|
243
|
-
assert_have_selector 'form.advanced-form label.photo', :content => "Photo" , :for => 'photo'
|
244
|
-
assert_have_selector 'form.advanced-form label.gender', :content => "Gender" , :for => 'gender'
|
245
|
-
end
|
246
|
-
end
|
247
|
-
|
248
|
-
context 'for #hidden_field_tag method' do
|
249
|
-
should "display hidden field in ruby" do
|
250
|
-
actual_html = hidden_field_tag(:session_key, :id => 'session_id', :value => '56768')
|
251
|
-
assert_has_tag(:input, :type => 'hidden', :id => "session_id", :name => 'session_key', :value => '56768') { actual_html }
|
252
|
-
end
|
253
|
-
|
254
|
-
should "display hidden field in erb" do
|
255
|
-
visit '/erb/form_tag'
|
256
|
-
assert_have_selector 'form.simple-form input[type=hidden]', :count => 1, :name => 'session_id', :value => "__secret__"
|
257
|
-
assert_have_selector 'form.advanced-form input[type=hidden]', :count => 1, :name => 'session_id', :value => "__secret__"
|
258
|
-
end
|
259
|
-
|
260
|
-
should "display hidden field in haml" do
|
261
|
-
visit '/haml/form_tag'
|
262
|
-
assert_have_selector 'form.simple-form input[type=hidden]', :count => 1, :name => 'session_id', :value => "__secret__"
|
263
|
-
assert_have_selector 'form.advanced-form input[type=hidden]', :count => 1, :name => 'session_id', :value => "__secret__"
|
264
|
-
end
|
265
|
-
|
266
|
-
should "display hidden field in slim" do
|
267
|
-
visit '/slim/form_tag'
|
268
|
-
assert_have_selector 'form.simple-form input[type=hidden]', :count => 1, :name => 'session_id', :value => "__secret__"
|
269
|
-
assert_have_selector 'form.advanced-form input[type=hidden]', :count => 1, :name => 'session_id', :value => "__secret__"
|
270
|
-
end
|
271
|
-
end
|
272
|
-
|
273
|
-
context 'for #text_field_tag method' do
|
274
|
-
should "display text field in ruby" do
|
275
|
-
actual_html = text_field_tag(:username, :class => 'long')
|
276
|
-
assert_has_tag(:input, :type => 'text', :class => "long", :name => 'username') { actual_html }
|
277
|
-
end
|
278
|
-
|
279
|
-
should "display text field in erb" do
|
280
|
-
visit '/erb/form_tag'
|
281
|
-
assert_have_selector 'form.simple-form input[type=text]', :count => 1, :name => 'username'
|
282
|
-
assert_have_selector 'form.advanced-form fieldset input[type=text]', :count => 1, :name => 'username', :id => 'the_username'
|
283
|
-
end
|
284
|
-
|
285
|
-
should "display text field in haml" do
|
286
|
-
visit '/haml/form_tag'
|
287
|
-
assert_have_selector 'form.simple-form input[type=text]', :count => 1, :name => 'username'
|
288
|
-
assert_have_selector 'form.advanced-form fieldset input[type=text]', :count => 1, :name => 'username', :id => 'the_username'
|
289
|
-
end
|
290
|
-
|
291
|
-
should "display text field in slim" do
|
292
|
-
visit '/slim/form_tag'
|
293
|
-
assert_have_selector 'form.simple-form input[type=text]', :count => 1, :name => 'username'
|
294
|
-
assert_have_selector 'form.advanced-form fieldset input[type=text]', :count => 1, :name => 'username', :id => 'the_username'
|
295
|
-
end
|
296
|
-
end
|
297
|
-
|
298
|
-
context 'for #text_area_tag method' do
|
299
|
-
should "display text area in ruby" do
|
300
|
-
actual_html = text_area_tag(:about, :class => 'long')
|
301
|
-
assert_has_tag(:textarea, :class => "long", :name => 'about', :rows => '', :cols => '') { actual_html }
|
302
|
-
end
|
303
|
-
|
304
|
-
should "display text area in ruby with specified content" do
|
305
|
-
actual_html = text_area_tag(:about, :value => "a test", :rows => 5, :cols => 6)
|
306
|
-
assert_has_tag(:textarea, :content => "a test", :name => 'about', :rows => "5", :cols => "6") { actual_html }
|
307
|
-
end
|
308
|
-
|
309
|
-
should "display text area in erb" do
|
310
|
-
visit '/erb/form_tag'
|
311
|
-
assert_have_selector 'form.advanced-form textarea', :count => 1, :name => 'about', :class => 'large'
|
312
|
-
end
|
313
|
-
|
314
|
-
should "display text area in haml" do
|
315
|
-
visit '/haml/form_tag'
|
316
|
-
assert_have_selector 'form.advanced-form textarea', :count => 1, :name => 'about', :class => 'large'
|
317
|
-
end
|
318
|
-
|
319
|
-
should "display text area in slim" do
|
320
|
-
visit '/slim/form_tag'
|
321
|
-
assert_have_selector 'form.advanced-form textarea', :count => 1, :name => 'about', :class => 'large'
|
322
|
-
end
|
323
|
-
end
|
324
|
-
|
325
|
-
context 'for #password_field_tag method' do
|
326
|
-
should "display password field in ruby" do
|
327
|
-
actual_html = password_field_tag(:password, :class => 'long')
|
328
|
-
assert_has_tag(:input, :type => 'password', :class => "long", :name => 'password') { actual_html }
|
329
|
-
end
|
330
|
-
|
331
|
-
should "display password field in erb" do
|
332
|
-
visit '/erb/form_tag'
|
333
|
-
assert_have_selector 'form.simple-form input[type=password]', :count => 1, :name => 'password'
|
334
|
-
assert_have_selector 'form.advanced-form input[type=password]', :count => 1, :name => 'password'
|
335
|
-
end
|
336
|
-
|
337
|
-
should "display password field in haml" do
|
338
|
-
visit '/haml/form_tag'
|
339
|
-
assert_have_selector 'form.simple-form input[type=password]', :count => 1, :name => 'password'
|
340
|
-
assert_have_selector 'form.advanced-form input[type=password]', :count => 1, :name => 'password'
|
341
|
-
end
|
342
|
-
|
343
|
-
should "display password field in slim" do
|
344
|
-
visit '/slim/form_tag'
|
345
|
-
assert_have_selector 'form.simple-form input[type=password]', :count => 1, :name => 'password'
|
346
|
-
assert_have_selector 'form.advanced-form input[type=password]', :count => 1, :name => 'password'
|
347
|
-
end
|
348
|
-
end
|
349
|
-
|
350
|
-
context 'for #file_field_tag method' do
|
351
|
-
should "display file field in ruby" do
|
352
|
-
actual_html = file_field_tag(:photo, :class => 'photo')
|
353
|
-
assert_has_tag(:input, :type => 'file', :class => "photo", :name => 'photo') { actual_html }
|
354
|
-
end
|
355
|
-
|
356
|
-
should "display file field in erb" do
|
357
|
-
visit '/erb/form_tag'
|
358
|
-
assert_have_selector 'form.advanced-form input[type=file]', :count => 1, :name => 'photo', :class => 'upload'
|
359
|
-
end
|
360
|
-
|
361
|
-
should "display file field in haml" do
|
362
|
-
visit '/haml/form_tag'
|
363
|
-
assert_have_selector 'form.advanced-form input[type=file]', :count => 1, :name => 'photo', :class => 'upload'
|
364
|
-
end
|
365
|
-
|
366
|
-
should "display file field in slim" do
|
367
|
-
visit '/slim/form_tag'
|
368
|
-
assert_have_selector 'form.advanced-form input[type=file]', :count => 1, :name => 'photo', :class => 'upload'
|
369
|
-
end
|
370
|
-
end
|
371
|
-
|
372
|
-
context "for #check_box_tag method" do
|
373
|
-
should "display check_box tag in ruby" do
|
374
|
-
actual_html = check_box_tag("clear_session")
|
375
|
-
assert_has_tag(:input, :type => 'checkbox', :value => '1', :name => 'clear_session') { actual_html }
|
376
|
-
assert_has_no_tag(:input, :type => 'hidden') { actual_html }
|
377
|
-
end
|
378
|
-
|
379
|
-
should "display check_box tag in ruby with extended attributes" do
|
380
|
-
actual_html = check_box_tag("clear_session", :disabled => true, :checked => true)
|
381
|
-
assert_has_tag(:input, :type => 'checkbox', :disabled => 'disabled', :checked => 'checked') { actual_html }
|
382
|
-
end
|
383
|
-
|
384
|
-
should "display check_box tag in erb" do
|
385
|
-
visit '/erb/form_tag'
|
386
|
-
assert_have_selector 'form.simple-form input[type=checkbox]', :count => 1
|
387
|
-
assert_have_selector 'form.advanced-form input[type=checkbox]', :value => "1", :checked => 'checked'
|
388
|
-
end
|
389
|
-
|
390
|
-
should "display check_box tag in haml" do
|
391
|
-
visit '/haml/form_tag'
|
392
|
-
assert_have_selector 'form.simple-form input[type=checkbox]', :count => 1
|
393
|
-
assert_have_selector 'form.advanced-form input[type=checkbox]', :value => "1", :checked => 'checked'
|
394
|
-
end
|
395
|
-
|
396
|
-
should "display check_box tag in slim" do
|
397
|
-
visit '/slim/form_tag'
|
398
|
-
assert_have_selector 'form.simple-form input[type=checkbox]', :count => 1
|
399
|
-
assert_have_selector 'form.advanced-form input[type=checkbox]', :value => "1", :checked => 'checked'
|
400
|
-
end
|
401
|
-
end
|
402
|
-
|
403
|
-
context "for #radio_button_tag method" do
|
404
|
-
should "display radio_button tag in ruby" do
|
405
|
-
actual_html = radio_button_tag("gender", :value => 'male')
|
406
|
-
assert_has_tag(:input, :type => 'radio', :value => 'male', :name => 'gender') { actual_html }
|
407
|
-
end
|
408
|
-
|
409
|
-
should "display radio_button tag in ruby with extended attributes" do
|
410
|
-
actual_html = radio_button_tag("gender", :disabled => true, :checked => true)
|
411
|
-
assert_has_tag(:input, :type => 'radio', :disabled => 'disabled', :checked => 'checked') { actual_html }
|
412
|
-
end
|
413
|
-
|
414
|
-
should "display radio_button tag in erb" do
|
415
|
-
visit '/erb/form_tag'
|
416
|
-
assert_have_selector 'form.simple-form input[type=radio]', :count => 1, :value => 'male'
|
417
|
-
assert_have_selector 'form.simple-form input[type=radio]', :count => 1, :value => 'female'
|
418
|
-
assert_have_selector 'form.advanced-form input[type=radio]', :value => "male", :checked => 'checked'
|
419
|
-
assert_have_selector 'form.advanced-form input[type=radio]', :value => "female"
|
420
|
-
end
|
421
|
-
|
422
|
-
should "display radio_button tag in haml" do
|
423
|
-
visit '/haml/form_tag'
|
424
|
-
assert_have_selector 'form.simple-form input[type=radio]', :count => 1, :value => 'male'
|
425
|
-
assert_have_selector 'form.simple-form input[type=radio]', :count => 1, :value => 'female'
|
426
|
-
assert_have_selector 'form.advanced-form input[type=radio]', :value => "male", :checked => 'checked'
|
427
|
-
assert_have_selector 'form.advanced-form input[type=radio]', :value => "female"
|
428
|
-
end
|
429
|
-
|
430
|
-
should "display radio_button tag in slim" do
|
431
|
-
visit '/slim/form_tag'
|
432
|
-
assert_have_selector 'form.simple-form input[type=radio]', :count => 1, :value => 'male'
|
433
|
-
assert_have_selector 'form.simple-form input[type=radio]', :count => 1, :value => 'female'
|
434
|
-
assert_have_selector 'form.advanced-form input[type=radio]', :value => "male", :checked => 'checked'
|
435
|
-
assert_have_selector 'form.advanced-form input[type=radio]', :value => "female"
|
436
|
-
end
|
437
|
-
end
|
438
|
-
|
439
|
-
context "for #select_tag method" do
|
440
|
-
should "display select tag in ruby" do
|
441
|
-
actual_html = select_tag(:favorite_color, :options => ['green', 'blue', 'black'], :include_blank => true)
|
442
|
-
assert_has_tag(:select, :name => 'favorite_color') { actual_html }
|
443
|
-
assert_has_tag('select option:first-child', :content => '') { actual_html }
|
444
|
-
assert_has_tag('select option', :content => 'green', :value => 'green') { actual_html }
|
445
|
-
assert_has_tag('select option', :content => 'blue', :value => 'blue') { actual_html }
|
446
|
-
assert_has_tag('select option', :content => 'black', :value => 'black') { actual_html }
|
447
|
-
end
|
448
|
-
|
449
|
-
should "display select tag in ruby with extended attributes" do
|
450
|
-
actual_html = select_tag(:favorite_color, :disabled => true, :options => ['only', 'option'])
|
451
|
-
assert_has_tag(:select, :disabled => 'disabled') { actual_html }
|
452
|
-
end
|
453
|
-
|
454
|
-
should "take a range as a collection for options" do
|
455
|
-
actual_html = select_tag(:favorite_color, :options => (1..3))
|
456
|
-
assert_has_tag(:select) { actual_html }
|
457
|
-
assert_has_tag('select option', :value => '1') { actual_html }
|
458
|
-
assert_has_tag('select option', :value => '2') { actual_html }
|
459
|
-
assert_has_tag('select option', :value => '3') { actual_html }
|
460
|
-
end
|
461
|
-
|
462
|
-
should "include blank for grouped options" do
|
463
|
-
opts = { "Red" => ["Rose","Fire"], "Blue" => ["Sky","Sea"] }
|
464
|
-
actual_html = select_tag( 'color', :grouped_options => opts, :include_blank => true )
|
465
|
-
assert_has_tag('select option:first-child', :value => "", :content => "") { actual_html }
|
466
|
-
end
|
467
|
-
|
468
|
-
should "return a select tag with grouped options for an nested array" do
|
469
|
-
opts = [
|
470
|
-
["Friends",["Yoda",["Obiwan",2]]],
|
471
|
-
["Enemies", ["Palpatine",['Darth Vader',3]]]
|
472
|
-
]
|
473
|
-
actual_html = select_tag( 'name', :grouped_options => opts )
|
474
|
-
assert_has_tag(:select, :name => "name") { actual_html }
|
475
|
-
assert_has_tag(:optgroup, :label => "Friends") { actual_html }
|
476
|
-
assert_has_tag(:option, :value => "Yoda", :content => "Yoda") { actual_html }
|
477
|
-
assert_has_tag(:option, :value => "2", :content => "Obiwan") { actual_html }
|
478
|
-
assert_has_tag(:optgroup, :label => "Enemies") { actual_html }
|
479
|
-
assert_has_tag(:option, :value => "Palpatine", :content => "Palpatine") { actual_html }
|
480
|
-
assert_has_tag(:option, :value => "3", :content => "Darth Vader") { actual_html }
|
481
|
-
end
|
482
|
-
|
483
|
-
should "return a select tag with grouped options for a hash" do
|
484
|
-
opts = {
|
485
|
-
"Friends" => ["Yoda",["Obiwan",2]],
|
486
|
-
"Enemies" => ["Palpatine",['Darth Vader',3]]
|
487
|
-
}
|
488
|
-
actual_html = select_tag( 'name', :grouped_options => opts )
|
489
|
-
assert_has_tag(:select, :name => "name") { actual_html }
|
490
|
-
assert_has_tag(:optgroup, :label => "Friends") { actual_html }
|
491
|
-
assert_has_tag(:option, :value => "Yoda", :content => "Yoda") { actual_html }
|
492
|
-
assert_has_tag(:option, :value => "2", :content => "Obiwan") { actual_html }
|
493
|
-
assert_has_tag(:optgroup, :label => "Enemies") { actual_html }
|
494
|
-
assert_has_tag(:option, :value => "Palpatine", :content => "Palpatine") { actual_html }
|
495
|
-
assert_has_tag(:option, :value => "3", :content => "Darth Vader") { actual_html }
|
496
|
-
end
|
497
|
-
|
498
|
-
should "display select tag in ruby with multiple attribute" do
|
499
|
-
actual_html = select_tag(:favorite_color, :multiple => true, :options => ['only', 'option'])
|
500
|
-
assert_has_tag(:select, :multiple => 'multiple', :name => 'favorite_color[]') { actual_html }
|
501
|
-
end
|
502
|
-
|
503
|
-
should "display options with values and single selected" do
|
504
|
-
options = [['Green', 'green1'], ['Blue', 'blue1'], ['Black', "black1"]]
|
505
|
-
actual_html = select_tag(:favorite_color, :options => options, :selected => 'green1')
|
506
|
-
assert_has_tag(:select, :name => 'favorite_color') { actual_html }
|
507
|
-
assert_has_tag('select option', :selected => 'selected', :count => 1) { actual_html }
|
508
|
-
assert_has_tag('select option', :content => 'Green', :value => 'green1', :selected => 'selected') { actual_html }
|
509
|
-
assert_has_tag('select option', :content => 'Blue', :value => 'blue1') { actual_html }
|
510
|
-
assert_has_tag('select option', :content => 'Black', :value => 'black1') { actual_html }
|
511
|
-
end
|
512
|
-
|
513
|
-
should "display option with values and multiple selected" do
|
514
|
-
options = [['Green', 'green1'], ['Blue', 'blue1'], ['Black', "black1"]]
|
515
|
-
actual_html = select_tag(:favorite_color, :options => options, :selected => ['green1', 'Black'])
|
516
|
-
assert_has_tag(:select, :name => 'favorite_color') { actual_html }
|
517
|
-
assert_has_tag('select option', :selected => 'selected', :count => 2) { actual_html }
|
518
|
-
assert_has_tag('select option', :content => 'Green', :value => 'green1', :selected => 'selected') { actual_html }
|
519
|
-
assert_has_tag('select option', :content => 'Blue', :value => 'blue1') { actual_html }
|
520
|
-
assert_has_tag('select option', :content => 'Black', :value => 'black1', :selected => 'selected') { actual_html }
|
521
|
-
end
|
522
|
-
|
523
|
-
should "display options selected only for exact match" do
|
524
|
-
options = [['One', '1'], ['1', '10'], ['Two', "-1"]]
|
525
|
-
actual_html = select_tag(:range, :options => options, :selected => '-1')
|
526
|
-
assert_has_tag(:select, :name => 'range') { actual_html }
|
527
|
-
assert_has_tag('select option', :selected => 'selected', :count => 1) { actual_html }
|
528
|
-
assert_has_tag('select option', :content => 'Two', :value => '-1', :selected => 'selected') { actual_html }
|
529
|
-
end
|
530
|
-
|
531
|
-
should "display select tag in erb" do
|
532
|
-
visit '/erb/form_tag'
|
533
|
-
assert_have_selector 'form.simple-form select', :count => 1, :name => 'color'
|
534
|
-
assert_have_selector('select option', :content => 'green', :value => 'green')
|
535
|
-
assert_have_selector('select option', :content => 'orange', :value => 'orange')
|
536
|
-
assert_have_selector('select option', :content => 'purple', :value => 'purple')
|
537
|
-
assert_have_selector 'form.advanced-form select', :name => 'fav_color'
|
538
|
-
assert_have_selector('select option', :content => 'green', :value => '1')
|
539
|
-
assert_have_selector('select option', :content => 'orange', :value => '2', :selected => 'selected')
|
540
|
-
assert_have_selector('select option', :content => 'purple', :value => '3')
|
541
|
-
end
|
542
|
-
|
543
|
-
should "display select tag in haml" do
|
544
|
-
visit '/haml/form_tag'
|
545
|
-
assert_have_selector 'form.simple-form select', :count => 1, :name => 'color'
|
546
|
-
assert_have_selector('select option', :content => 'green', :value => 'green')
|
547
|
-
assert_have_selector('select option', :content => 'orange', :value => 'orange')
|
548
|
-
assert_have_selector('select option', :content => 'purple', :value => 'purple')
|
549
|
-
assert_have_selector 'form.advanced-form select', :name => 'fav_color'
|
550
|
-
assert_have_selector('select option', :content => 'green', :value => '1')
|
551
|
-
assert_have_selector('select option', :content => 'orange', :value => '2', :selected => 'selected')
|
552
|
-
assert_have_selector('select option', :content => 'purple', :value => '3')
|
553
|
-
end
|
554
|
-
|
555
|
-
should "display select tag in slim" do
|
556
|
-
visit '/slim/form_tag'
|
557
|
-
assert_have_selector 'form.simple-form select', :count => 1, :name => 'color'
|
558
|
-
assert_have_selector('select option', :content => 'green', :value => 'green')
|
559
|
-
assert_have_selector('select option', :content => 'orange', :value => 'orange')
|
560
|
-
assert_have_selector('select option', :content => 'purple', :value => 'purple')
|
561
|
-
assert_have_selector 'form.advanced-form select', :name => 'fav_color'
|
562
|
-
assert_have_selector('select option', :content => 'green', :value => '1')
|
563
|
-
assert_have_selector('select option', :content => 'orange', :value => '2', :selected => 'selected')
|
564
|
-
assert_have_selector('select option', :content => 'purple', :value => '3')
|
565
|
-
end
|
566
|
-
end
|
567
|
-
|
568
|
-
context 'for #submit_tag method' do
|
569
|
-
should "display submit tag in ruby" do
|
570
|
-
actual_html = submit_tag("Update", :class => 'success')
|
571
|
-
assert_has_tag(:input, :type => 'submit', :class => "success", :value => 'Update') { actual_html }
|
572
|
-
end
|
573
|
-
|
574
|
-
should "display submit tag in erb" do
|
575
|
-
visit '/erb/form_tag'
|
576
|
-
assert_have_selector 'form.simple-form input[type=submit]', :count => 1, :value => "Submit"
|
577
|
-
assert_have_selector 'form.advanced-form input[type=submit]', :count => 1, :value => "Login"
|
578
|
-
end
|
579
|
-
|
580
|
-
should "display submit tag in haml" do
|
581
|
-
visit '/haml/form_tag'
|
582
|
-
assert_have_selector 'form.simple-form input[type=submit]', :count => 1, :value => "Submit"
|
583
|
-
assert_have_selector 'form.advanced-form input[type=submit]', :count => 1, :value => "Login"
|
584
|
-
end
|
585
|
-
|
586
|
-
should "display submit tag in slim" do
|
587
|
-
visit '/slim/form_tag'
|
588
|
-
assert_have_selector 'form.simple-form input[type=submit]', :count => 1, :value => "Submit"
|
589
|
-
assert_have_selector 'form.advanced-form input[type=submit]', :count => 1, :value => "Login"
|
590
|
-
end
|
591
|
-
end
|
592
|
-
|
593
|
-
context 'for #button_tag method' do
|
594
|
-
should "display submit tag in ruby" do
|
595
|
-
actual_html = button_tag("Cancel", :class => 'clear')
|
596
|
-
assert_has_tag(:input, :type => 'button', :class => "clear", :value => 'Cancel') { actual_html }
|
597
|
-
end
|
598
|
-
|
599
|
-
should "display submit tag in erb" do
|
600
|
-
visit '/erb/form_tag'
|
601
|
-
assert_have_selector 'form.advanced-form input[type=button]', :count => 1, :value => "Cancel"
|
602
|
-
end
|
603
|
-
|
604
|
-
should "display submit tag in haml" do
|
605
|
-
visit '/haml/form_tag'
|
606
|
-
assert_have_selector 'form.advanced-form input[type=button]', :count => 1, :value => "Cancel"
|
607
|
-
end
|
608
|
-
|
609
|
-
should "display submit tag in slim" do
|
610
|
-
visit '/slim/form_tag'
|
611
|
-
assert_have_selector 'form.advanced-form input[type=button]', :count => 1, :value => "Cancel"
|
612
|
-
end
|
613
|
-
end
|
614
|
-
|
615
|
-
context 'for #image_submit_tag method' do
|
616
|
-
setup do
|
617
|
-
@stamp = stop_time_for_test.to_i
|
618
|
-
end
|
619
|
-
|
620
|
-
should "display image submit tag in ruby with relative path" do
|
621
|
-
actual_html = image_submit_tag('buttons/ok.png', :class => 'success')
|
622
|
-
assert_has_tag(:input, :type => 'image', :class => "success", :src => "/images/buttons/ok.png?#{@stamp}") { actual_html }
|
623
|
-
end
|
624
|
-
|
625
|
-
should "display image submit tag in ruby with absolute path" do
|
626
|
-
actual_html = image_submit_tag('/system/ok.png', :class => 'success')
|
627
|
-
assert_has_tag(:input, :type => 'image', :class => "success", :src => "/system/ok.png?#{@stamp}") { actual_html }
|
628
|
-
end
|
629
|
-
|
630
|
-
should "display image submit tag in erb" do
|
631
|
-
visit '/erb/form_tag'
|
632
|
-
assert_have_selector 'form.advanced-form input[type=image]', :count => 1, :src => "/images/buttons/submit.png?#{@stamp}"
|
633
|
-
end
|
634
|
-
|
635
|
-
should "display image submit tag in haml" do
|
636
|
-
visit '/haml/form_tag'
|
637
|
-
assert_have_selector 'form.advanced-form input[type=image]', :count => 1, :src => "/images/buttons/submit.png?#{@stamp}"
|
638
|
-
end
|
639
|
-
|
640
|
-
should "display image submit tag in slim" do
|
641
|
-
visit '/slim/form_tag'
|
642
|
-
assert_have_selector 'form.advanced-form input[type=image]', :count => 1, :src => "/images/buttons/submit.png?#{@stamp}"
|
643
|
-
end
|
644
|
-
end
|
645
|
-
end
|