From: "mame (Yusuke Endoh) via ruby-core" Date: 2023-09-05T11:28:31+00:00 Subject: [ruby-core:114632] [Ruby master Bug#19857] Eval coverage is reset after each `eval`. Issue #19857 has been updated by mame (Yusuke Endoh). @ioquatix When creating a ticket, could you write up a use case? Even if you believe it is a bug, it is not necessarily so to others. You only showed an example of evaling a method definition many times. As far as that case is concerned, I don't think that it is so important and frequent that we need to care in the coverage library. Please explain how the current behavior is troubling in a real-world example. ---------------------------------------- Bug #19857: Eval coverage is reset after each `eval`. https://bugs.ruby-lang.org/issues/19857#change-104460 * Author: ioquatix (Samuel Williams) * Status: Open * Priority: Normal * Assignee: ioquatix (Samuel Williams) * Backport: 3.0: DONTNEED, 3.1: DONTNEED, 3.2: REQUIRED ---------------------------------------- It seems like `eval` based coverage is reset every time eval is invoked. ```ruby #!/usr/bin/env ruby require 'coverage' def measure(flag) c = Class.new c.class_eval(<<~RUBY, "foo.rb", 1) def foo(flag) if flag puts "foo" else puts "bar" end end RUBY return c.new.foo(flag) end Coverage.start(lines: true, eval: true) # Depending on the order of these two operations, different coverage is calculated, because the evaluation of the code is considered different, even if the content/path is the same. measure(false) measure(true) p Coverage.result ``` Further investigation is required. -- https://bugs.ruby-lang.org/ ______________________________________________ ruby-core mailing list -- ruby-core@ml.ruby-lang.org To unsubscribe send an email to ruby-core-leave@ml.ruby-lang.org ruby-core info -- https://ml.ruby-lang.org/mailman3/postorius/lists/ruby-core.ml.ruby-lang.org/