Some parts of the Ruby test suite won't work correctly under ASAN. In particular, assert_no_memory_leak will need different parameters for ASAN (or be skipped, in the same way as for MJIT/RJIT).
I propose that we add a module RubyVM::ASAN (which will be unconditionally defined), and RubyVM::ASAN.enabled? (which will return true if Ruby was compiled with ASAN, or false otherwise).
This means we can check if ASAN is enabled by running defined?(RubyVM::ASAN) && RubyVM::ASAN.enabled?, in the same way that the mjit/rjit check is performed.
So I was going to implement RubyVM::ASAN.enabled? by using conditional compilation to just return Qtrue or Qfalse.
Maybe RbConfig might be a better place for it? I think I’d have to write some autoconf macros/test program to emit an AC_SUBST about whether asan is enabled. But that should be just as robust. WDYT?
You just need the API for the Ruby test suite, right? Then, it would be enough to implement it in ext/-test-/. Introducing a method under RubyVM means making it available to Ruby users. Is that necessary?
Note, I don't think that it is a good idea to change the test behavior only when ASAN is enabled. I understand #20273 since callcc is very special, though.
Then, it would be enough to implement it in ext/-test-/.
This is a much better idea - I'll do this.
Note, I don't think that it is a good idea to change the test behavior only when ASAN is enabled
I definitely agree with this in general. The only place I've found so far where I actually want to change test behaviour on ASAN is assert_no_memory_leak which I think is also a bit special (it just hardcodes some guess numbers about how much memory the subprocess "should" use. I'm very carefully evaluating all the other failures the test suite throws up and fixing them :) (I think I have found two actual real bugs already with it!)
ASAN greatly increases the memory footprint of Ruby, so these static
thresholds are not appropriate. There's no real need to run these tests
under ASAN.