From 701975f3ee63a8b7ea2356595e07d2fff68cc734 Mon Sep 17 00:00:00 2001 From: Burke Libbey Date: Mon, 19 Jun 2017 15:27:52 -0400 Subject: [PATCH] Add Coverage.enabled? to quickly check if coverage is enabled --- ext/coverage/coverage.c | 15 +++++++++++++++ test/coverage/test_coverage.rb | 10 ++++++++++ 2 files changed, 25 insertions(+) diff --git a/ext/coverage/coverage.c b/ext/coverage/coverage.c index 9a9011a7da..d2077a969e 100644 --- a/ext/coverage/coverage.c +++ b/ext/coverage/coverage.c @@ -75,6 +75,20 @@ rb_coverage_result(VALUE klass) return ncoverages; } +/* + * call-seq: + * Coverage.running? => bool + * + * Returns true if coverage stats are currently being collected (after + * Coverage.start call, but before Coverage.result call) + */ +static VALUE +rb_coverage_running(VALUE klass) +{ + VALUE coverages = rb_get_coverages(); + return RTEST(coverages) ? Qtrue : Qfalse; +} + /* Coverage provides coverage measurement feature for Ruby. * This feature is experimental, so these APIs may be changed in future. * @@ -115,4 +129,5 @@ Init_coverage(void) rb_define_module_function(rb_mCoverage, "start", rb_coverage_start, 0); rb_define_module_function(rb_mCoverage, "result", rb_coverage_result, 0); rb_define_module_function(rb_mCoverage, "peek_result", rb_coverage_peek_result, 0); + rb_define_module_function(rb_mCoverage, "running?", rb_coverage_running, 0); } diff --git a/test/coverage/test_coverage.rb b/test/coverage/test_coverage.rb index b0392135fd..58b942804b 100644 --- a/test/coverage/test_coverage.rb +++ b/test/coverage/test_coverage.rb @@ -23,6 +23,16 @@ def test_result_with_nothing end end + def test_coverage_running? + refute Coverage.running? + Coverage.start + assert Coverage.running? + Coverage.peek_result + assert Coverage.running? + Coverage.result + refute Coverage.running? + end + def test_coverage_snapshot loaded_features = $".dup -- 2.11.0 (Apple Git-81)