diff --git a/lib/carrierwave/downloader/remote_file.rb b/lib/carrierwave/downloader/remote_file.rb index 8b8d6bfe1..851b31dfd 100644 --- a/lib/carrierwave/downloader/remote_file.rb +++ b/lib/carrierwave/downloader/remote_file.rb @@ -33,9 +33,9 @@ def headers def original_filename filename = filename_from_header || filename_from_uri - mime_type = Marcel::TYPES[content_type] - unless File.extname(filename).present? || mime_type.blank? - extension = mime_type[0].first + extensions = Marcel::Magic.new(content_type).extensions + unless File.extname(filename).present? || extensions.blank? + extension = extensions.first filename = "#{filename}.#{extension}" end filename diff --git a/spec/processing/rmagick_spec.rb b/spec/processing/rmagick_spec.rb index 415805af1..c3fb97788 100644 --- a/spec/processing/rmagick_spec.rb +++ b/spec/processing/rmagick_spec.rb @@ -255,7 +255,7 @@ def foo=(value); raise; end instance.manipulate! :read => { :foo => "1" } - end.to raise_error NoMethodError, /private method `foo=' called/ + end.to raise_error NoMethodError, /private method .foo=. called/ end end