OptimizedImage-Spezifikationen schlagen mit Ruby 3.0.2 fehl

Ich arbeite an der Unterstützung von Ruby 3 und habe diesen Spec-Fehler erhalten.

Schritte zur Reproduktion

  1. Ruby 3.0.2 ausführen
$ cd discourse
$ bundle exec rspec spec/models/optimized_image_spec.rb:10

Erwartetes Ergebnis

Es sollte erfolgreich abgeschlossen werden wie folgt:

1 example, 0 failures

Tatsächliches Ergebnis

Es tritt immer ein Fehler auf wie folgt.

$ bundle exec rspec spec/models/optimized_image_spec.rb:10
Run options: include {:locations=>{"./spec/models/optimized_image_spec.rb"=>[10]}}

Randomized with seed 44957
F

Failures:

  1) OptimizedImage.crop should produce cropped images (requires ImageMagick 7)
     Failure/Error: expect(cropped_size).to be < 120

       expected: < 120
            got:   9476
     # ./spec/models/optimized_image_spec.rb:27:in `block (3 levels) in <top (required)>'
     # ./spec/rails_helper.rb:279:in `block (2 levels) in <top (required)>'

Finished in 0.22966 seconds (files took 2.89 seconds to load)
1 example, 1 failure

Failed examples:

rspec ./spec/models/optimized_image_spec.rb:10 # OptimizedImage.crop should produce cropped images (requires ImageMagick 7)

Randomized with seed 44957

$

Diagnose-Info

Dieser Fehler hängt mit dieser Zeile zusammen.

Wenn es mit Ruby 2.7.4 ausgeführt wird, funktioniert es, aber mit Ruby 3.0.2 wird „can’t convert ImageOptim::Timer into Float (TypeError)" ausgelöst. Hier sind die minimalen Schritte zur Reproduktion.

$ more foo.rb
gem 'image_optim'
require 'image_optim'

timeout = ImageOptim::Timer.new(15.0)

args = [{"PATH"=>
   "/usr/bin"},
   "date"
]

pid = Process.spawn(*args)
waiter = Process.detach(pid)

waiter.join(timeout)
  • Mit Ruby 3.0.2 wird „can’t convert ImageOptim::Timer into Float (TypeError)" angezeigt.
$ ruby -v
ruby 3.0.2p107 (2021-07-07 revision 0db68f0233) [x86_64-linux]
$ ruby foo.rb
foo.rb:14:in `join': can't convert ImageOptim::Timer into Float (TypeError)
	from foo.rb:14:in `<main>'
Fri Oct  1 12:42:51 PM JST 2021
$
  • Mit Ruby 2.7.4 funktioniert es ohne Ausnahme.
$ ruby -v
ruby 2.7.4p191 (2021-07-07 revision a21a3b7d23) [x86_64-linux]
$ ruby foo.rb
Fri Oct  1 12:44:00 PM JST 2021
$

Sieht aus, als gäbe es eine einfache Lösung … einfach .to_f hinzufügen.

if waiter.join(timeout.to_f)

Kannst du einen PR einreichen?

Danke für den Vorschlag. Gerne. Ich werde einen Pull Request für GitHub - toy/image_optim: Optimize images using multiple utilities · GitHub eröffnen.

Geöffnet Fix: TypeError: can't convert ImageOptim::Timer into Float by yahonda · Pull Request #194 · toy/image_optim · GitHub