middleman-core 3.2.0 → 3.2.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (241) hide show
  1. checksums.yaml +4 -4
  2. data/.yardopts +10 -0
  3. data/features/helpers_auto_javascript_include_tag.feature +21 -0
  4. data/features/helpers_auto_stylesheet_link_tag.feature +21 -0
  5. data/features/i18n_builder.feature +23 -13
  6. data/features/i18n_preview.feature +9 -9
  7. data/features/markdown_kramdown.feature +1 -1
  8. data/fixtures/i18n-test-app/source/{layout.erb → layouts/layout.erb} +0 -0
  9. data/fixtures/i18n-test-app/source/{morning.en.html.erb → localizable/morning.en.html.erb} +0 -0
  10. data/fixtures/i18n-test-app/source/{morning.es.html.erb → localizable/morning.es.html.erb} +0 -0
  11. data/fixtures/i18n-test-app/source/{one.en.md → localizable/one.en.md} +0 -0
  12. data/fixtures/i18n-test-app/source/{one.es.md → localizable/one.es.md} +0 -0
  13. data/lib/middleman-core/application.rb +4 -0
  14. data/lib/middleman-core/cli/build.rb +14 -2
  15. data/lib/middleman-core/cli/init.rb +1 -0
  16. data/lib/middleman-core/core_extensions.rb +6 -1
  17. data/lib/middleman-core/core_extensions/file_watcher.rb +1 -0
  18. data/lib/middleman-core/core_extensions/request.rb +2 -4
  19. data/lib/middleman-core/extensions.rb +13 -5
  20. data/lib/middleman-core/meta_pages.rb +25 -11
  21. data/lib/middleman-core/meta_pages/sitemap_resource.rb +2 -2
  22. data/lib/middleman-core/meta_pages/templates/config.html.erb +7 -9
  23. data/lib/middleman-core/meta_pages/templates/index.html.erb +3 -3
  24. data/lib/middleman-core/meta_pages/templates/sitemap.html.erb +6 -6
  25. data/lib/middleman-core/sitemap/extensions/redirects.rb +1 -2
  26. data/lib/middleman-core/sitemap/extensions/request_endpoints.rb +2 -3
  27. data/lib/middleman-core/sitemap/resource.rb +7 -13
  28. data/lib/middleman-core/util.rb +2 -3
  29. data/lib/middleman-core/version.rb +1 -1
  30. data/lib/middleman-more/core_extensions/default_helpers.rb +9 -5
  31. data/lib/middleman-more/core_extensions/i18n.rb +17 -10
  32. data/lib/middleman-more/extensions/{automatic-alt-tags.rb → automatic_alt_tags.rb} +0 -0
  33. data/lib/middleman-more/extensions/gzip.rb +29 -6
  34. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/.document +0 -0
  35. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/.gitignore +0 -0
  36. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/.yardopts +0 -0
  37. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/LICENSE.txt +0 -0
  38. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/README.rdoc +5 -5
  39. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/Rakefile +0 -0
  40. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/bin/padrino +0 -0
  41. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core.rb +4 -10
  42. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/application.rb +39 -35
  43. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/application/flash.rb +7 -7
  44. data/lib/vendored-middleman-deps/padrino-core-0.11.4/lib/padrino-core/application/rendering.rb +317 -0
  45. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/application/rendering/extensions/erubis.rb +15 -6
  46. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/application/rendering/extensions/haml.rb +2 -0
  47. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/application/rendering/extensions/slim.rb +0 -0
  48. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/application/routing.rb +406 -368
  49. data/lib/vendored-middleman-deps/padrino-core-0.11.4/lib/padrino-core/application/showexceptions.rb +21 -0
  50. data/lib/vendored-middleman-deps/padrino-core-0.11.4/lib/padrino-core/caller.rb +53 -0
  51. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/cli/adapter.rb +4 -4
  52. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/cli/base.rb +40 -39
  53. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/cli/console.rb +0 -0
  54. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/cli/rake.rb +2 -2
  55. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/cli/rake_tasks.rb +2 -4
  56. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/command.rb +2 -2
  57. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/images/404.png +0 -0
  58. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/images/500.png +0 -0
  59. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/loader.rb +14 -15
  60. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/cs.yml +0 -1
  61. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/da.yml +0 -1
  62. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/de.yml +0 -1
  63. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/en.yml +0 -1
  64. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/es.yml +1 -2
  65. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/fr.yml +2 -3
  66. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/hu.yml +1 -2
  67. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/it.yml +0 -1
  68. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/ja.yml +1 -2
  69. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/lv.yml +0 -1
  70. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/nl.yml +0 -1
  71. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/no.yml +0 -2
  72. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/pl.yml +0 -1
  73. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/pt_br.yml +0 -1
  74. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/ro.yml +0 -1
  75. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/ru.yml +0 -1
  76. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/sv.yml +0 -1
  77. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/tr.yml +0 -1
  78. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/uk.yml +0 -1
  79. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/zh_cn.yml +0 -1
  80. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/locale/zh_tw.yml +0 -1
  81. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/logger.rb +30 -36
  82. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/module.rb +3 -3
  83. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/mounter.rb +59 -59
  84. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/reloader.rb +23 -23
  85. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/router.rb +10 -13
  86. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/server.rb +17 -19
  87. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/support_lite.rb +0 -0
  88. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/tasks.rb +3 -3
  89. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/lib/padrino-core/version.rb +1 -1
  90. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/padrino-core.gemspec +2 -2
  91. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/app_gem/Gemfile +0 -0
  92. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/app_gem/app/app.rb +0 -0
  93. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/app_gem/app_gem.gemspec +0 -0
  94. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/app_gem/lib/app_gem.rb +0 -0
  95. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/app_gem/lib/app_gem/version.rb +0 -0
  96. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/apps/.components +0 -0
  97. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/apps/.gitignore +0 -0
  98. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/apps/complex.rb +0 -0
  99. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/apps/simple.rb +0 -0
  100. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/dependencies/a.rb +0 -0
  101. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/dependencies/b.rb +0 -0
  102. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/dependencies/c.rb +0 -0
  103. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/dependencies/circular/e.rb +0 -0
  104. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/dependencies/circular/f.rb +0 -0
  105. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/dependencies/circular/g.rb +0 -0
  106. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/fixtures/dependencies/d.rb +0 -0
  107. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/helper.rb +0 -0
  108. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/mini_shoulda.rb +0 -0
  109. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_application.rb +7 -7
  110. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_core.rb +0 -0
  111. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_csrf_protection.rb +0 -0
  112. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_dependencies.rb +0 -0
  113. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_filters.rb +0 -0
  114. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_flash.rb +0 -0
  115. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_locale.rb +0 -0
  116. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_logger.rb +29 -0
  117. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_mounter.rb +0 -0
  118. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_reloader_complex.rb +0 -0
  119. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_reloader_simple.rb +0 -0
  120. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_rendering.rb +15 -2
  121. data/lib/vendored-middleman-deps/padrino-core-0.11.4/test/test_rendering_extensions.rb +14 -0
  122. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_restful_routing.rb +0 -0
  123. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_router.rb +0 -0
  124. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_routing.rb +69 -11
  125. data/lib/vendored-middleman-deps/{padrino-core-0.11.2 → padrino-core-0.11.4}/test/test_support_lite.rb +0 -0
  126. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/.document +0 -0
  127. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/.gitignore +0 -0
  128. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/.yardopts +0 -0
  129. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/LICENSE.txt +0 -0
  130. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/README.rdoc +1 -1
  131. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/Rakefile +0 -0
  132. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers.rb +3 -6
  133. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/asset_tag_helpers.rb +34 -42
  134. data/lib/vendored-middleman-deps/padrino-helpers-0.11.4/lib/padrino-helpers/breadcrumb_helpers.rb +183 -0
  135. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/form_builder/abstract_form_builder.rb +126 -118
  136. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/form_builder/standard_form_builder.rb +6 -9
  137. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/form_helpers.rb +252 -195
  138. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/format_helpers.rb +29 -42
  139. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/cs.yml +14 -14
  140. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/da.yml +1 -1
  141. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/de.yml +1 -1
  142. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/en.yml +16 -16
  143. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/es.yml +16 -16
  144. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/fr.yml +1 -2
  145. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/hu.yml +16 -16
  146. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/it.yml +2 -2
  147. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/ja.yml +16 -16
  148. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/lv.yml +16 -16
  149. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/nl.yml +1 -1
  150. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/no.yml +1 -1
  151. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/pl.yml +7 -7
  152. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/pt_br.yml +16 -16
  153. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/ro.yml +16 -16
  154. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/ru.yml +16 -16
  155. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/sv.yml +16 -16
  156. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/tr.yml +16 -16
  157. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/uk.yml +16 -16
  158. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/zh_cn.yml +16 -16
  159. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/locale/zh_tw.yml +16 -16
  160. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/number_helpers.rb +10 -15
  161. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/output_helpers.rb +50 -58
  162. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/output_helpers/abstract_handler.rb +16 -18
  163. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/output_helpers/erb_handler.rb +11 -12
  164. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/output_helpers/haml_handler.rb +9 -9
  165. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/output_helpers/slim_handler.rb +11 -13
  166. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/render_helpers.rb +5 -6
  167. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/tag_helpers.rb +26 -22
  168. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/lib/padrino-helpers/translation_helpers.rb +4 -6
  169. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/padrino-helpers.gemspec +0 -0
  170. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/app.rb +7 -3
  171. data/lib/vendored-middleman-deps/padrino-helpers-0.11.4/test/fixtures/markup_app/views/button_to.erb +8 -0
  172. data/lib/vendored-middleman-deps/padrino-helpers-0.11.4/test/fixtures/markup_app/views/button_to.haml +5 -0
  173. data/lib/vendored-middleman-deps/padrino-helpers-0.11.4/test/fixtures/markup_app/views/button_to.slim +6 -0
  174. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/capture_concat.erb +0 -0
  175. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/capture_concat.haml +0 -0
  176. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/capture_concat.slim +0 -0
  177. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/content_for.erb +0 -0
  178. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/content_for.haml +0 -0
  179. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/content_for.slim +0 -0
  180. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/content_tag.erb +0 -0
  181. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/content_tag.haml +0 -0
  182. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/content_tag.slim +0 -0
  183. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/current_engine.erb +0 -0
  184. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/current_engine.haml +0 -0
  185. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/current_engine.slim +0 -0
  186. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/fields_for.erb +0 -0
  187. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/fields_for.haml +0 -0
  188. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/fields_for.slim +0 -0
  189. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/form_for.erb +0 -0
  190. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/form_for.haml +0 -0
  191. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/form_for.slim +0 -0
  192. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/form_tag.erb +9 -0
  193. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/form_tag.haml +8 -0
  194. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/form_tag.slim +9 -0
  195. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/link_to.erb +0 -0
  196. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/link_to.haml +0 -0
  197. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/link_to.slim +0 -0
  198. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/mail_to.erb +0 -0
  199. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/mail_to.haml +0 -0
  200. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/mail_to.slim +0 -0
  201. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/meta_tag.erb +0 -0
  202. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/meta_tag.haml +0 -0
  203. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/meta_tag.slim +0 -0
  204. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/partials/_erb.erb +0 -0
  205. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/partials/_haml.haml +0 -0
  206. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/partials/_slim.slim +0 -0
  207. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/simple_partial.erb +0 -0
  208. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/simple_partial.haml +0 -0
  209. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/markup_app/views/simple_partial.slim +0 -0
  210. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/render_app/app.rb +1 -0
  211. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/render_app/views/current_engine.haml +0 -0
  212. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/render_app/views/current_engines/_erb.erb +0 -0
  213. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/render_app/views/current_engines/_haml.haml +0 -0
  214. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/render_app/views/current_engines/_slim.slim +0 -0
  215. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/render_app/views/double_capture_erb.erb +0 -0
  216. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/render_app/views/double_capture_haml.haml +0 -0
  217. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/render_app/views/double_capture_slim.slim +0 -0
  218. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/render_app/views/erb/test.erb +0 -0
  219. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/render_app/views/explicit_engine.haml +0 -0
  220. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/render_app/views/haml/test.haml +0 -0
  221. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/render_app/views/template/_user.haml +0 -0
  222. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/render_app/views/template/haml_template.haml +0 -0
  223. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/fixtures/render_app/views/template/some_template.haml +0 -0
  224. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/helper.rb +0 -0
  225. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/test_asset_tag_helpers.rb +9 -3
  226. data/lib/vendored-middleman-deps/padrino-helpers-0.11.4/test/test_breadcrumb_helpers.rb +134 -0
  227. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/test_form_builder.rb +38 -6
  228. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/test_form_helpers.rb +230 -12
  229. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/test_format_helpers.rb +3 -3
  230. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/test_locale.rb +0 -0
  231. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/test_number_helpers.rb +4 -0
  232. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/test_output_helpers.rb +1 -1
  233. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/test_render_helpers.rb +1 -1
  234. data/lib/vendored-middleman-deps/{padrino-helpers-0.11.2 → padrino-helpers-0.11.4}/test/test_tag_helpers.rb +3 -3
  235. data/middleman-core.gemspec +7 -8
  236. data/spec/spec_helper.rb +1 -1
  237. metadata +220 -215
  238. data/lib/vendored-middleman-deps/padrino-core-0.11.2/lib/padrino-core/application/rendering.rb +0 -320
  239. data/lib/vendored-middleman-deps/padrino-core-0.11.2/lib/padrino-core/application/showexceptions.rb +0 -20
  240. data/lib/vendored-middleman-deps/padrino-core-0.11.2/lib/padrino-core/caller.rb +0 -53
  241. data/lib/vendored-middleman-deps/padrino-helpers-0.11.2/lib/padrino-helpers/breadcrumb_helpers.rb +0 -171
@@ -18,6 +18,8 @@
18
18
  = search_field_tag :search
19
19
  = label_tag :color
20
20
  = select_tag :color, :options => ['green', 'orange', 'purple']
21
+ = select_tag :type, :grouped_options => { 'foo' => ['foo', 'bar'], 'bar' => ['foo', 'bar'] }
22
+ = select_tag :character, :grouped_options => [['Friends',['Yoda',['Obiwan',1]]],['Enemies',['Palpatine',['Darth Vader',3]]]]
21
23
  = label_tag :gender
22
24
  = radio_button_tag :gender, :value => 'male'
23
25
  = radio_button_tag :gender, :value => 'female'
@@ -64,7 +66,13 @@
64
66
  = select_tag :fav_color, :options => [ ['green', '1'], ['orange', '2'], ['purple', '3'] ], :selected => '2'
65
67
  %p
66
68
  = check_box_tag :remember_me, :value => "1", :checked => true
69
+ %p
70
+ = range_field_tag('ranger_with_min_max', :min => 1, :max => 50)
71
+ = range_field_tag('ranger_with_range', :range => 1..5)
67
72
  - field_set_tag(:class => 'buttons') do
68
73
  = submit_tag "Login"
69
74
  = button_tag "Cancel"
70
75
  = image_submit_tag "buttons/submit.png"
76
+
77
+ - form_tag '/dontprotect', :class => 'no-protection', :protect_from_csrf => false do
78
+ = submit_tag "Login"
@@ -18,6 +18,8 @@
18
18
  = search_field_tag :search
19
19
  = label_tag :color
20
20
  = select_tag :color, :options => ['green', 'orange', 'purple']
21
+ = select_tag :type, :grouped_options => { 'foo' => ['foo', 'bar'], 'bar' => ['foo', 'bar'] }
22
+ = select_tag :character, :grouped_options => [['Friends',['Yoda',['Obiwan',1]]],['Enemies',['Palpatine',['Darth Vader',3]]]]
21
23
  = label_tag :gender
22
24
  = radio_button_tag :gender, :value => 'male'
23
25
  = radio_button_tag :gender, :value => 'female'
@@ -64,7 +66,14 @@
64
66
  = select_tag :fav_color, :options => [ ['green', '1'], ['orange', '2'], ['purple', '3'] ], :selected => '2'
65
67
  p
66
68
  = check_box_tag :remember_me, :value => "1", :checked => true
69
+ p
70
+ = range_field_tag('ranger_with_min_max', :min => 1, :max => 50)
71
+ = range_field_tag('ranger_with_range', :range => 1..5)
72
+
67
73
  = field_set_tag(:class => 'buttons') do
68
74
  = submit_tag "Login"
69
75
  = button_tag "Cancel"
70
76
  = image_submit_tag "buttons/submit.png"
77
+
78
+ = form_tag '/dontprotect', :class => 'no-protection', :protect_from_csrf => false do
79
+ = submit_tag "Login"
@@ -16,6 +16,7 @@ class RenderDemo < Padrino::Application
16
16
  configure do
17
17
  set :logging, false
18
18
  set :padrino_logging, false
19
+ set :environment, :test
19
20
  set :erb, :engine_class => Padrino::Erubis::SafeBufferTemplate
20
21
  set :haml, :escape_html => true
21
22
  set :slim, :generator => Temple::Generators::RailsOutputBuffer
@@ -5,7 +5,7 @@ describe "AssetTagHelpers" do
5
5
  include Padrino::Helpers::AssetTagHelpers
6
6
 
7
7
  def app
8
- MarkupDemo.tap { |app| app.set :environment, :test }
8
+ MarkupDemo
9
9
  end
10
10
 
11
11
  def flash
@@ -71,9 +71,9 @@ describe "AssetTagHelpers" do
71
71
  end
72
72
 
73
73
  should "escape the link text" do
74
- actual_link = link_to('/register', :class => 'first', :id => 'binky') { "<>" }
74
+ actual_link = link_to('/register', :class => 'first', :id => 'binky') { "<&>" }
75
75
  assert_has_tag('a#binky.first', :href => '/register') { actual_link }
76
- assert_match "&lt;&gt;", actual_link
76
+ assert_match "&lt;&amp;&gt;", actual_link
77
77
  end
78
78
 
79
79
  should "not escape image_tag" do
@@ -119,6 +119,12 @@ describe "AssetTagHelpers" do
119
119
  assert_match %r{subject\=demo\%20test}, actual_html
120
120
  end
121
121
 
122
+ should "escape & with encoded string and &amp; in HTML" do
123
+ actual_html = mail_to('test@demo.com', "My&Email", :subject => "this&that")
124
+ assert_match 'this%26that', actual_html
125
+ assert_match 'My&amp;Email', actual_html
126
+ end
127
+
122
128
  should "display mail link element in haml" do
123
129
  visit '/haml/mail_to'
124
130
  assert_have_selector 'p.simple a', :href => 'mailto:test@demo.com', :content => 'test@demo.com'
@@ -0,0 +1,134 @@
1
+ require File.expand_path(File.dirname(__FILE__) + '/helper')
2
+
3
+ describe "BreadcrumbHelpers" do
4
+ include Padrino::Helpers::Breadcrumbs
5
+
6
+ def breadcrumb
7
+ @breadcrumb ||= Padrino::Helpers::Breadcrumb.new
8
+ end
9
+
10
+ before(:each) { breadcrumb.reset! }
11
+
12
+ context "for Breadcrumbs#breadcrumbs method" do
13
+ should "support breadcrumbs which is Padrino::Helpers::Breadcrumbs instance." do
14
+ breadcrumb.add "foo", "/foo", "foo link"
15
+ assert_has_tag(:a, :content => "Foo link", :href => "/foo") { breadcrumbs(breadcrumb) }
16
+ end
17
+
18
+ should "support bootstrap" do
19
+ breadcrumb.add "foo", "/foo", "foo link"
20
+ assert_has_tag(:span, :content => "/", :class => "divider") { breadcrumbs(breadcrumb, true) }
21
+ end
22
+
23
+ should "support active" do
24
+ breadcrumb.add "foo", "/foo", "foo link"
25
+ assert_has_tag(:li, :class => "custom-active") { breadcrumbs(breadcrumb, nil, "custom-active") }
26
+ end
27
+
28
+ should "support options" do
29
+ assert_has_tag(:ul, :class => "breadcrumbs-class breadcrumb", :id => "breadcrumbs-id") do
30
+ breadcrumbs(breadcrumb, nil, nil, :id => "breadcrumbs-id", :class => "breadcrumbs-class")
31
+ end
32
+ end
33
+ end
34
+
35
+ context "for #add method" do
36
+ should "support name of string and symbol type" do
37
+ breadcrumb.add "foo", "/foo", "Foo Link"
38
+ breadcrumb.add :bar, "/bar", "Bar Link"
39
+
40
+ actual_html = breadcrumbs(breadcrumb)
41
+ assert_has_tag(:a, :content => "Foo link", :href => "/foo") { actual_html }
42
+ assert_has_tag(:a, :content => "Bar link", :href => "/bar") { actual_html }
43
+ end
44
+
45
+ should "support url" do
46
+ breadcrumb.add :foo, "/foo", "Foo Link"
47
+ assert_has_tag(:a, :href => "/foo") { breadcrumbs(breadcrumb) }
48
+ end
49
+
50
+ should "support caption" do
51
+ breadcrumb.add :foo, "/foo", "Foo Link"
52
+ assert_has_tag(:a, :content => "Foo link") { breadcrumbs(breadcrumb) }
53
+ end
54
+
55
+ should "support options" do
56
+ breadcrumb.add :foo, "/foo", "Foo Link", :id => "foo-id", :class => "foo-class"
57
+ breadcrumb.add :bar, "/bar", "Bar Link", :id => "bar-id", :class => "bar-class"
58
+
59
+ actual_html = breadcrumbs(breadcrumb)
60
+ assert_has_tag(:li, :class => "foo-class", :id => "foo-id") { actual_html }
61
+ assert_has_tag(:li, :class => "bar-class active", :id => "bar-id") { actual_html }
62
+ end
63
+ end
64
+
65
+ context "for #del method" do
66
+ should "support name of string type" do
67
+ breadcrumb.add "foo", "/foo", "Foo Link"
68
+ breadcrumb.add :bar, "/bar", "Bar Link"
69
+
70
+ breadcrumb.del "foo"
71
+ breadcrumb.del "bar"
72
+
73
+ actual_html = breadcrumbs(breadcrumb)
74
+ assert_has_no_tag(:a, :content => "Foo link", :href => "/foo") { actual_html }
75
+ assert_has_no_tag(:a, :content => "Bar link", :href => "/bar") { actual_html }
76
+ end
77
+
78
+ should "support name of symbol type" do
79
+ breadcrumb.add "foo", "/foo", "Foo Link"
80
+ breadcrumb.add :bar, "/bar", "Bar Link"
81
+
82
+ breadcrumb.del :foo
83
+ breadcrumb.del :bar
84
+
85
+ actual_html = breadcrumbs(breadcrumb)
86
+ assert_has_no_tag(:a, :content => "Foo link", :href => "/foo") { actual_html }
87
+ assert_has_no_tag(:a, :content => "Bar link", :href => "/bar") { actual_html }
88
+ end
89
+ end
90
+
91
+ context "for #set_home method" do
92
+ should "modified home item elements." do
93
+ breadcrumb.set_home("/custom", "Custom Home Page")
94
+ assert_has_tag(:a, :content => "Custom home page", :href => "/custom") { breadcrumbs(breadcrumb) }
95
+ end
96
+
97
+ should "support options" do
98
+ breadcrumb.set_home("/custom", "Custom Home Page", :id => "home-id")
99
+
100
+ actual_html = breadcrumbs(breadcrumb)
101
+ assert_has_tag(:li, :id => "home-id") { actual_html }
102
+ assert_has_tag(:a, :content => "Custom home page", :href => "/custom") { actual_html }
103
+ end
104
+ end
105
+
106
+ context "for #reset method" do
107
+ should "be #items which contains only home item." do
108
+ breadcrumb.set_home("/custom", "Custom Home Page")
109
+ breadcrumb.add "foo", "/foo", "Foo Link"
110
+ breadcrumb.add :bar, "/bar", "Bar Link"
111
+
112
+ breadcrumb.reset
113
+
114
+ actual_html = breadcrumbs(breadcrumb)
115
+ assert_has_tag(:a, :content => "Custom home page", :href => "/custom") { actual_html }
116
+ assert_has_no_tag(:a, :content => "Foo link", :href => "/foo") { actual_html }
117
+ assert_has_no_tag(:a, :content => "Bar link", :href => "/bar") { actual_html }
118
+ end
119
+ end
120
+
121
+ context "for #reset! method" do
122
+ should "be #items which contains only default home item." do
123
+ breadcrumb.add "foo", "/foo", "foo link"
124
+ breadcrumb.add :bar, "/bar", "Bar Link"
125
+
126
+ breadcrumb.reset!
127
+
128
+ actual_html = breadcrumbs(breadcrumb)
129
+ assert_has_tag(:a, :content => "Home Page", :href => "/") { actual_html }
130
+ assert_has_no_tag(:a, :content => "Foo link", :href => "/foo") { actual_html }
131
+ assert_has_no_tag(:a, :content => "Bar link", :href => "/bar") { actual_html }
132
+ end
133
+ end
134
+ end
@@ -4,6 +4,10 @@ require File.expand_path(File.dirname(__FILE__) + '/fixtures/markup_app/app')
4
4
  describe "FormBuilder" do
5
5
  include Padrino::Helpers::FormHelpers
6
6
 
7
+ def app
8
+ MarkupDemo
9
+ end
10
+
7
11
  # Dummy form builder for testing
8
12
  module Padrino::Helpers::FormBuilder
9
13
  class FakeFormBuilder < AbstractFormBuilder
@@ -11,10 +15,6 @@ describe "FormBuilder" do
11
15
  end
12
16
  end
13
17
 
14
- def app
15
- MarkupDemo.tap { |app| app.set :environment, :test }
16
- end
17
-
18
18
  def setup
19
19
  role_types = [mock_model('Role', :name => "Admin", :id => 1),
20
20
  mock_model('Role', :name => 'Moderate', :id => 2), mock_model('Role', :name => 'Limited', :id => 3)]
@@ -49,8 +49,7 @@ describe "FormBuilder" do
49
49
  end
50
50
 
51
51
  should "display form specifying default builder setting" do
52
- self.expects(:settings).returns(stub(:default_builder => 'FakeFormBuilder')).once
53
- actual_html = ""
52
+ self.expects(:settings).returns(stub(:default_builder => 'FakeFormBuilder', :protect_from_csrf => false)).at_least_once
54
53
  actual_html = form_for(@user, '/register', :id => 'register', :"accept-charset" => "UTF-8", :method => 'post') { |f| f.foo_field }
55
54
  assert_has_tag('form', :"accept-charset" => "UTF-8", :action => '/register', :method => 'post') { actual_html }
56
55
  assert_has_tag('span', :content => "bar") { actual_html }
@@ -61,6 +60,16 @@ describe "FormBuilder" do
61
60
  assert_has_tag('form', :"accept-charset" => "UTF-8", :action => '/update', :method => 'post', "data-remote" => 'true') { actual_html }
62
61
  end
63
62
 
63
+ should "display correct form html with namespace option" do
64
+ actual_html = form_for(@user, '/update', :namespace => 'foo') do |f|
65
+ f.text_field(:first_name) << f.fields_for(:role_types) { |role| role.text_field(:name) }
66
+ end
67
+
68
+ assert_has_no_tag(:form, :namespace => 'foo') { actual_html }
69
+ assert_has_tag(:input, :type => 'text', :name => 'user[first_name]', :id => 'foo_user_first_name') { actual_html }
70
+ assert_has_tag(:input, :type => 'text', :name => 'user[role_types_attributes][0][name]', :id => 'foo_user_role_types_attributes_0_name') { actual_html }
71
+ end
72
+
64
73
  should "display correct form html with remote option and method put" do
65
74
  actual_html = form_for(@user, '/update', :"accept-charset" => "UTF-8", :remote => true, :method => 'put') { "Demo" }
66
75
  assert_has_tag('form', :"accept-charset" => "UTF-8", :method => 'post', "data-remote" => 'true') { actual_html }
@@ -655,6 +664,17 @@ describe "FormBuilder" do
655
664
  assert_have_selector '#demo input.user-photo', :type => 'file', :name => 'markup_user[photo]', :id => 'markup_user_photo'
656
665
  assert_have_selector '#demo2 input.upload', :type => 'file', :name => 'markup_user[photo]', :id => 'markup_user_photo'
657
666
  end
667
+
668
+ should "display correct form html with multipart, even if no 'multipart' option is specified" do
669
+ actual_html = form_for(@user, '/register', :"accept-charset" => "UTF-8") { |f| f.file_field :photo }
670
+ assert_has_tag('form', :"accept-charset" => "UTF-8", :action => '/register', :enctype => "multipart/form-data") { actual_html }
671
+ end
672
+
673
+ should "display correct form html without multipart, if 'multipart' option is specified 'false'" do
674
+ actual_html = form_for(@user, '/register', :"accept-charset" => "UTF-8", :multipart => false) { |f| f.file_field :photo }
675
+ assert_has_no_tag('form', :"accept-charset" => "UTF-8", :action => '/register', :enctype => "multipart/form-data") { actual_html }
676
+ end
677
+
658
678
  end
659
679
 
660
680
  context 'for #select method' do
@@ -742,6 +762,18 @@ describe "FormBuilder" do
742
762
  assert_has_tag('input[type=submit]', :value => "Submit") { actual_html }
743
763
  end
744
764
 
765
+
766
+ should "display correct submit button html with no caption" do
767
+ actual_html = standard_builder.submit(:class => 'btn')
768
+ assert_has_tag('input.btn[type=submit]', :value => "Submit") { actual_html }
769
+ end
770
+
771
+ should "display correct submit button html with nil caption" do
772
+ actual_html = standard_builder.submit(nil, :class => 'btn')
773
+ assert_has_tag('input.btn[type=submit]') { actual_html }
774
+ assert actual_html !~ %r{ value \* = }x
775
+ end
776
+
745
777
  should "display correct submit button html" do
746
778
  actual_html = standard_builder.submit("Commit", :class => 'large')
747
779
  assert_has_tag('input.large[type=submit]', :value => "Commit") { actual_html }
@@ -5,7 +5,11 @@ describe "FormHelpers" do
5
5
  include Padrino::Helpers::FormHelpers
6
6
 
7
7
  def app
8
- MarkupDemo.tap { |app| app.set :environment, :test }
8
+ MarkupDemo
9
+ end
10
+
11
+ class UnprotectedApp
12
+ def protect_from_csrf; false; end
9
13
  end
10
14
 
11
15
  context 'for #form_tag method' do
@@ -54,25 +58,67 @@ describe "FormHelpers" do
54
58
  assert_has_tag(:form, :enctype => "multipart/form-data") { actual_html }
55
59
  end
56
60
 
61
+ should "have an authenticity_token for method :post, :put or :delete" do
62
+ %w(post put delete).each do |method|
63
+ actual_html = form_tag('/modify', :method => method) { "Demo" }
64
+ assert_has_tag(:input, :name => 'authenticity_token') { actual_html }
65
+ end
66
+ end
67
+
68
+ should "not have an authenticity_token if method: :get" do
69
+ actual_html = form_tag('/get', :method => :get) { "Demo" }
70
+ assert_has_no_tag(:input, :name => 'authenticity_token') { actual_html }
71
+ end
72
+
73
+ should "have an authenticity_token by default" do
74
+ actual_html = form_tag('/superadmindelete') { "Demo" }
75
+ assert_has_tag(:input, :name => 'authenticity_token') { actual_html }
76
+ end
77
+
78
+ should "create csrf meta tags with token and param - #csrf_meta_tags" do
79
+ actual_html = csrf_meta_tags
80
+ assert_has_tag(:meta, :name => 'csrf-param') { actual_html }
81
+ assert_has_tag(:meta, :name => 'csrf-token') { actual_html }
82
+ end
83
+
84
+ should "have an authenticity_token by default" do
85
+ actual_html = form_tag('/superadmindelete') { "Demo" }
86
+ assert_has_tag(:input, :name => 'authenticity_token') { actual_html }
87
+ end
88
+
89
+ should "not have an authenticity_token if passing protect_from_csrf: false" do
90
+ actual_html = form_tag('/superadmindelete', :protect_from_csrf => false) { "Demo" }
91
+ assert_has_no_tag(:input, :name => 'authenticity_token') { actual_html }
92
+ end
93
+
94
+ should "not have an authenticity_token if protect_from_csrf is false on app settings" do
95
+ self.expects(:settings).returns(UnprotectedApp.new)
96
+ actual_html = form_tag('/superadmindelete') { "Demo" }
97
+ assert_has_no_tag(:input, :name => 'authenticity_token') { actual_html }
98
+ end
99
+
57
100
  should "display correct forms in erb" do
58
101
  visit '/erb/form_tag'
59
102
  assert_have_selector 'form.simple-form', :action => '/simple'
60
103
  assert_have_selector 'form.advanced-form', :action => '/advanced', :id => 'advanced', :method => 'get'
61
- assert_have_selector :input, :name => 'authenticity_token'
104
+ assert_have_selector 'form.simple-form input', :name => 'authenticity_token'
105
+ assert_have_no_selector 'form.no-protection input', :name => 'authenticity_token'
62
106
  end
63
107
 
64
108
  should "display correct forms in haml" do
65
109
  visit '/haml/form_tag'
66
110
  assert_have_selector 'form.simple-form', :action => '/simple'
67
111
  assert_have_selector 'form.advanced-form', :action => '/advanced', :id => 'advanced', :method => 'get'
68
- assert_have_selector :input, :name => 'authenticity_token'
112
+ assert_have_selector 'form.simple-form input', :name => 'authenticity_token'
113
+ assert_have_no_selector 'form.no-protection input', :name => 'authenticity_token'
69
114
  end
70
115
 
71
116
  should "display correct forms in slim" do
72
117
  visit '/slim/form_tag'
73
118
  assert_have_selector 'form.simple-form', :action => '/simple'
74
119
  assert_have_selector 'form.advanced-form', :action => '/advanced', :id => 'advanced', :method => 'get'
75
- assert_have_selector :input, :name => 'authenticity_token'
120
+ assert_have_selector 'form.simple-form input', :name => 'authenticity_token'
121
+ assert_have_no_selector 'form.no-protection input', :name => 'authenticity_token'
76
122
  end
77
123
  end
78
124
 
@@ -127,7 +173,7 @@ describe "FormHelpers" do
127
173
  assert_have_selector 'form.advanced-form .field-errors p', :content => "There were problems with the following fields:"
128
174
  assert_have_selector 'form.advanced-form .field-errors ul'
129
175
  assert_have_selector 'form.advanced-form .field-errors ul li', :count => 4
130
- assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Email must be a email"
176
+ assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Email must be an email"
131
177
  assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Fake must be valid"
132
178
  assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Second must be present"
133
179
  assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Third must be a number"
@@ -141,7 +187,7 @@ describe "FormHelpers" do
141
187
  assert_have_selector 'form.advanced-form .field-errors p', :content => "There were problems with the following fields:"
142
188
  assert_have_selector 'form.advanced-form .field-errors ul'
143
189
  assert_have_selector 'form.advanced-form .field-errors ul li', :count => 4
144
- assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Email must be a email"
190
+ assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Email must be an email"
145
191
  assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Fake must be valid"
146
192
  assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Second must be present"
147
193
  assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Third must be a number"
@@ -155,7 +201,7 @@ describe "FormHelpers" do
155
201
  assert_have_selector 'form.advanced-form .field-errors p', :content => "There were problems with the following fields:"
156
202
  assert_have_selector 'form.advanced-form .field-errors ul'
157
203
  assert_have_selector 'form.advanced-form .field-errors ul li', :count => 4
158
- assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Email must be a email"
204
+ assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Email must be an email"
159
205
  assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Fake must be valid"
160
206
  assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Second must be present"
161
207
  assert_have_selector 'form.advanced-form .field-errors ul li', :content => "Third must be a number"
@@ -611,7 +657,7 @@ describe "FormHelpers" do
611
657
  assert_has_tag('select option:first-child', :value => "", :content => "") { actual_html }
612
658
  end
613
659
 
614
- should "return a select tag with grouped options for an nested array" do
660
+ should "display select tag with grouped options for a nested array" do
615
661
  opts = [
616
662
  ["Friends",["Yoda",["Obiwan",2]]],
617
663
  ["Enemies", ["Palpatine",['Darth Vader',3]]]
@@ -626,7 +672,33 @@ describe "FormHelpers" do
626
672
  assert_has_tag(:option, :value => "3", :content => "Darth Vader") { actual_html }
627
673
  end
628
674
 
629
- should "return a select tag with grouped options for a hash" do
675
+ should "display select tag with grouped options for a nested array and accept disabled groups" do
676
+ opts = [
677
+ ["Friends",["Yoda",["Obiwan",2]]],
678
+ ["Enemies", ["Palpatine",['Darth Vader',3]], true]
679
+ ]
680
+ actual_html = select_tag( 'name', :grouped_options => opts )
681
+ assert_has_tag(:select, :name => "name") { actual_html }
682
+ assert_has_tag(:option, :disabled => 'disabled', :count => 0) { actual_html }
683
+ assert_has_tag(:optgroup, :disabled => 'disabled', :count => 1) { actual_html }
684
+ assert_has_tag(:optgroup, :label => "Enemies", :disabled => 'disabled') { actual_html }
685
+ end
686
+
687
+ should "display select tag with grouped options for a nested array and accept disabled groups and/or with disabled options" do
688
+ opts = [
689
+ ["Friends",["Yoda",["Obiwan",2, true]]],
690
+ ["Enemies", [["Palpatine", "Palpatine", true],['Darth Vader',3]], true]
691
+ ]
692
+ actual_html = select_tag( 'name', :grouped_options => opts )
693
+ assert_has_tag(:select, :name => "name") { actual_html }
694
+ assert_has_tag(:option, :disabled => 'disabled', :count => 2) { actual_html }
695
+ assert_has_tag(:optgroup, :disabled => 'disabled', :count => 1) { actual_html }
696
+ assert_has_tag(:option, :content => "Obiwan", :disabled => 'disabled') { actual_html }
697
+ assert_has_tag(:optgroup, :label => "Enemies", :disabled => 'disabled') { actual_html }
698
+ assert_has_tag(:option, :value => "Palpatine", :content => "Palpatine", :disabled => 'disabled') { actual_html }
699
+ end
700
+
701
+ should "display select tag with grouped options for a hash" do
630
702
  opts = {
631
703
  "Friends" => ["Yoda",["Obiwan",2]],
632
704
  "Enemies" => ["Palpatine",['Darth Vader',3]]
@@ -641,6 +713,33 @@ describe "FormHelpers" do
641
713
  assert_has_tag(:option, :value => "3", :content => "Darth Vader") { actual_html }
642
714
  end
643
715
 
716
+ should "display select tag with grouped options for a hash and accept disabled groups" do
717
+ opts = {
718
+ "Friends" => ["Yoda",["Obiwan",2]],
719
+ "Enemies" => ["Palpatine",['Darth Vader',3], {:disabled => true}]
720
+ }
721
+ actual_html = select_tag( 'name', :grouped_options => opts )
722
+ assert_has_tag(:select, :name => "name") { actual_html }
723
+ assert_has_tag(:option, :disabled => 'disabled', :count => 0) { actual_html }
724
+ assert_has_tag(:optgroup, :disabled => 'disabled', :count => 1) { actual_html }
725
+ assert_has_tag(:optgroup, :label => "Enemies", :disabled => 'disabled') { actual_html }
726
+ end
727
+
728
+ should "display select tag with grouped options for a hash and accept disabled groups and/or with disabled options" do
729
+ opts = {
730
+ "Friends" => ["Yoda",["Obiwan",2,true]],
731
+ "Enemies" => [["Palpatine","Palpatine",true],["Darth Vader",3], {:disabled => true}]
732
+ }
733
+ actual_html = select_tag( 'name', :grouped_options => opts )
734
+ assert_has_tag(:select, :name => "name") { actual_html }
735
+ assert_has_tag(:option, :disabled => 'disabled', :count => 2) { actual_html }
736
+ assert_has_tag(:optgroup, :disabled => 'disabled', :count => 1) { actual_html }
737
+ assert_has_tag(:option, :content => "Obiwan", :disabled => 'disabled') { actual_html }
738
+ assert_has_tag(:optgroup, :label => "Enemies", :disabled => 'disabled') { actual_html }
739
+ assert_has_tag(:option, :value => "Palpatine", :content => "Palpatine", :disabled => 'disabled') { actual_html }
740
+ end
741
+
742
+
644
743
  should "display select tag in ruby with multiple attribute" do
645
744
  actual_html = select_tag(:favorite_color, :multiple => true, :options => ['only', 'option'])
646
745
  assert_has_tag(:select, :multiple => 'multiple', :name => 'favorite_color[]') { actual_html }
@@ -656,6 +755,16 @@ describe "FormHelpers" do
656
755
  assert_has_tag('select option', :content => 'Black', :value => 'black1') { actual_html }
657
756
  end
658
757
 
758
+ should "display options with values and accept disabled options" do
759
+ options = [['Green', 'green1', true], ['Blue', 'blue1'], ['Black', "black1"]]
760
+ actual_html = select_tag(:favorite_color, :options => options)
761
+ assert_has_tag(:select, :name => 'favorite_color') { actual_html }
762
+ assert_has_tag('select option', :disabled => 'disabled', :count => 1) { actual_html }
763
+ assert_has_tag('select option', :content => 'Green', :value => 'green1', :disabled => 'disabled') { actual_html }
764
+ assert_has_tag('select option', :content => 'Blue', :value => 'blue1') { actual_html }
765
+ assert_has_tag('select option', :content => 'Black', :value => 'black1') { actual_html }
766
+ end
767
+
659
768
  should "display option with values and multiple selected" do
660
769
  options = [['Green', 'green1'], ['Blue', 'blue1'], ['Black', "black1"]]
661
770
  actual_html = select_tag(:favorite_color, :options => options, :selected => ['green1', 'Black'])
@@ -680,10 +789,20 @@ describe "FormHelpers" do
680
789
  assert_have_selector('select option', :content => 'green', :value => 'green')
681
790
  assert_have_selector('select option', :content => 'orange', :value => 'orange')
682
791
  assert_have_selector('select option', :content => 'purple', :value => 'purple')
683
- assert_have_selector 'form.advanced-form select', :name => 'fav_color'
792
+ assert_have_selector('form.advanced-form select', :name => 'fav_color')
684
793
  assert_have_selector('select option', :content => 'green', :value => '1')
685
794
  assert_have_selector('select option', :content => 'orange', :value => '2', :selected => 'selected')
686
795
  assert_have_selector('select option', :content => 'purple', :value => '3')
796
+ assert_have_selector('select optgroup', :label => 'foo')
797
+ assert_have_selector('select optgroup', :label => 'bar')
798
+ assert_have_selector('select optgroup option', :content => 'foo', :value => 'foo')
799
+ assert_have_selector('select optgroup option', :content => 'bar', :value => 'bar')
800
+ assert_have_selector('select optgroup', :label => 'Friends')
801
+ assert_have_selector('select optgroup', :label => 'Enemies')
802
+ assert_have_selector('select optgroup option', :content => 'Yoda', :value => 'Yoda')
803
+ assert_have_selector('select optgroup option', :content => 'Obiwan', :value => '1')
804
+ assert_have_selector('select optgroup option', :content => 'Palpatine', :value => 'Palpatine')
805
+ assert_have_selector('select optgroup option', :content => 'Darth Vader', :value => '3')
687
806
  end
688
807
 
689
808
  should "display select tag in haml" do
@@ -692,10 +811,20 @@ describe "FormHelpers" do
692
811
  assert_have_selector('select option', :content => 'green', :value => 'green')
693
812
  assert_have_selector('select option', :content => 'orange', :value => 'orange')
694
813
  assert_have_selector('select option', :content => 'purple', :value => 'purple')
695
- assert_have_selector 'form.advanced-form select', :name => 'fav_color'
814
+ assert_have_selector('form.advanced-form select', :name => 'fav_color')
696
815
  assert_have_selector('select option', :content => 'green', :value => '1')
697
816
  assert_have_selector('select option', :content => 'orange', :value => '2', :selected => 'selected')
698
817
  assert_have_selector('select option', :content => 'purple', :value => '3')
818
+ assert_have_selector('select optgroup', :label => 'foo')
819
+ assert_have_selector('select optgroup', :label => 'bar')
820
+ assert_have_selector('select optgroup option', :content => 'foo', :value => 'foo')
821
+ assert_have_selector('select optgroup option', :content => 'bar', :value => 'bar')
822
+ assert_have_selector('select optgroup', :label => 'Friends')
823
+ assert_have_selector('select optgroup', :label => 'Enemies')
824
+ assert_have_selector('select optgroup option', :content => 'Yoda', :value => 'Yoda')
825
+ assert_have_selector('select optgroup option', :content => 'Obiwan', :value => '1')
826
+ assert_have_selector('select optgroup option', :content => 'Palpatine', :value => 'Palpatine')
827
+ assert_have_selector('select optgroup option', :content => 'Darth Vader', :value => '3')
699
828
  end
700
829
 
701
830
  should "display select tag in slim" do
@@ -704,10 +833,20 @@ describe "FormHelpers" do
704
833
  assert_have_selector('select option', :content => 'green', :value => 'green')
705
834
  assert_have_selector('select option', :content => 'orange', :value => 'orange')
706
835
  assert_have_selector('select option', :content => 'purple', :value => 'purple')
707
- assert_have_selector 'form.advanced-form select', :name => 'fav_color'
836
+ assert_have_selector('form.advanced-form select', :name => 'fav_color')
708
837
  assert_have_selector('select option', :content => 'green', :value => '1')
709
838
  assert_have_selector('select option', :content => 'orange', :value => '2', :selected => 'selected')
710
839
  assert_have_selector('select option', :content => 'purple', :value => '3')
840
+ assert_have_selector('select optgroup', :label => 'foo')
841
+ assert_have_selector('select optgroup', :label => 'bar')
842
+ assert_have_selector('select optgroup option', :content => 'foo', :value => 'foo')
843
+ assert_have_selector('select optgroup option', :content => 'bar', :value => 'bar')
844
+ assert_have_selector('select optgroup', :label => 'Friends')
845
+ assert_have_selector('select optgroup', :label => 'Enemies')
846
+ assert_have_selector('select optgroup option', :content => 'Yoda', :value => 'Yoda')
847
+ assert_have_selector('select optgroup option', :content => 'Obiwan', :value => '1')
848
+ assert_have_selector('select optgroup option', :content => 'Palpatine', :value => 'Palpatine')
849
+ assert_have_selector('select optgroup option', :content => 'Darth Vader', :value => '3')
711
850
  end
712
851
  end
713
852
 
@@ -734,6 +873,26 @@ describe "FormHelpers" do
734
873
  assert_have_selector 'form.simple-form input[type=submit]', :count => 1, :value => "Submit"
735
874
  assert_have_selector 'form.advanced-form input[type=submit]', :count => 1, :value => "Login"
736
875
  end
876
+
877
+ context 'for omitted args' do
878
+ should "display submit tag with default caption" do
879
+ actual_html = submit_tag()
880
+ assert_has_tag(:input, :type => 'submit', :value => 'Submit') { actual_html }
881
+ end
882
+ end
883
+
884
+ context 'for omitted caption arg' do
885
+ should "display submit tag with default caption" do
886
+ actual_html = submit_tag(:class => 'success')
887
+ assert_has_tag(:input, :type => 'submit', :class => 'success', :value => 'Submit') { actual_html }
888
+ end
889
+
890
+ should "display submit tag without caption value when nil" do
891
+ actual_html = submit_tag(nil, :class => 'success')
892
+ assert_has_tag(:input, :type => 'submit', :class => 'success') { actual_html }
893
+ assert_has_no_tag(:input, :type => 'submit', :class => 'success', :value => 'Submit') { actual_html }
894
+ end
895
+ end
737
896
  end
738
897
 
739
898
  context 'for #button_tag method' do
@@ -808,5 +967,64 @@ describe "FormHelpers" do
808
967
  end
809
968
  assert_has_tag('form button', :type => 'submit', :content => "My button's content", :title => "My button") { actual_html }
810
969
  end
970
+
971
+ should "pass options on submit button when submit_options are given" do
972
+ actual_html = button_to("Fancy button", '/users/1', :submit_options => { :class => :fancy })
973
+ assert_has_tag('form input', :type => 'submit', :value => 'Fancy button', :class => 'fancy') { actual_html }
974
+ end
975
+
976
+ should 'display correct button_to in erb' do
977
+ visit '/erb/button_to'
978
+ assert_have_selector('form', :action => '/foo')
979
+ assert_have_selector('form label', :for => 'username', :content => 'Username: ')
980
+ assert_have_selector('form', :action => '/bar')
981
+ assert_have_selector('#test-point ~ form > input[type=submit]', :value => 'Bar button')
982
+ end
983
+
984
+ should 'display correct button_to in haml' do
985
+ visit '/haml/button_to'
986
+ assert_have_selector('form', :action => '/foo')
987
+ assert_have_selector('form label', :for => 'username', :content => 'Username: ')
988
+ assert_have_selector('form', :action => '/bar')
989
+ assert_have_selector('#test-point ~ form > input[type=submit]', :value => 'Bar button')
990
+ end
991
+
992
+ should 'display correct button_to in slim' do
993
+ visit '/slim/button_to'
994
+ assert_have_selector('form', :action => '/foo')
995
+ assert_have_selector('form label', :for => 'username', :content => 'Username: ')
996
+ assert_have_selector('form', :action => '/bar')
997
+ assert_have_selector('#test-point ~ form > input[type=submit]', :value => 'Bar button')
998
+ end
999
+ end
1000
+
1001
+ context 'for #range_field_tag' do
1002
+ should "create an input tag with min and max options" do
1003
+ actual_html = range_field_tag('ranger', :min => 20, :max => 50)
1004
+ assert_has_tag('input', :type => 'range', :name => 'ranger', :min => '20', :max => '50') { actual_html }
1005
+ end
1006
+
1007
+ should "create an input tag with range" do
1008
+ actual_html = range_field_tag('ranger', :range => 1..20)
1009
+ assert_has_tag('input', :min => '1', :max => '20') { actual_html }
1010
+ end
1011
+
1012
+ should "display correct range_field_tag in erb" do
1013
+ visit '/erb/form_tag'
1014
+ assert_have_selector 'input', :type => 'range', :name => 'ranger_with_min_max', :min => '1', :max => '50', :count => 1
1015
+ assert_have_selector 'input', :type => 'range', :name => 'ranger_with_range', :min => '1', :max => '5', :count => 1
1016
+ end
1017
+
1018
+ should "display correct range_field_tag in haml" do
1019
+ visit '/haml/form_tag'
1020
+ assert_have_selector 'input', :type => 'range', :name => 'ranger_with_min_max', :min => '1', :max => '50', :count => 1
1021
+ assert_have_selector 'input', :type => 'range', :name => 'ranger_with_range', :min => '1', :max => '5', :count => 1
1022
+ end
1023
+
1024
+ should "display correct range_field_tag in slim" do
1025
+ visit '/slim/form_tag'
1026
+ assert_have_selector 'input', :type => 'range', :name => 'ranger_with_min_max', :min => '1', :max => '50', :count => 1
1027
+ assert_have_selector 'input', :type => 'range', :name => 'ranger_with_range', :min => '1', :max => '5', :count => 1
1028
+ end
811
1029
  end
812
1030
  end