diff --git a/actionview/lib/action_view/helpers/tags/select.rb b/actionview/lib/action_view/helpers/tags/select.rb index 33c9b77d8d..dec19bcfd2 100644 --- a/actionview/lib/action_view/helpers/tags/select.rb +++ b/actionview/lib/action_view/helpers/tags/select.rb @@ -15,7 +15,7 @@ module ActionView def render option_tags_options = { - selected: @options.fetch(:selected) { value.to_s }, + selected: @options.fetch(:selected) { value.nil? ? "" : value }, disabled: @options[:disabled] } diff --git a/actionview/test/template/form_options_helper_test.rb b/actionview/test/template/form_options_helper_test.rb index a27f039994..952f05b7ec 100644 --- a/actionview/test/template/form_options_helper_test.rb +++ b/actionview/test/template/form_options_helper_test.rb @@ -851,6 +851,15 @@ class FormOptionsHelperTest < ActionView::TestCase ) end + def test_select_with_array + @continent = Continent.new + @continent.countries = ["Africa", "Europe"] + assert_dom_equal( + %(), + select("continent", "countries", %W(Africa Europe America), { multiple: true }) + ) + end + def test_required_select assert_dom_equal( %(),