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(
%(),