Class: Minitest::Runnable
- Defined in:
- lib/minitest.rb,
lib/minitest.rb more...
Overview
re-open
Constant Summary collapse
- SIGNALS =
:nodoc:
Signal.list
- @@marshal_dump_warned =
false
Instance Attribute Summary collapse
-
#assertions ⇒ Object
Number of assertions executed in this run.
-
#failures ⇒ Object
An assertion raised during the run, if any.
-
#time ⇒ Object
The time it took to run.
Class Method Summary collapse
-
.inherited(klass) ⇒ Object
:nodoc:.
-
.methods_matching(re) ⇒ Object
Returns all instance methods matching the pattern
re
. -
.on_signal(name, action) ⇒ Object
:nodoc:.
-
.reset ⇒ Object
:nodoc:.
-
.run(reporter, options = {}) ⇒ Object
Responsible for running all runnable methods in a given class, each in its own instance.
-
.run_one_method(klass, method_name, reporter) ⇒ Object
Runs a single method and has the reporter record the result.
-
.runnable_methods ⇒ Object
Each subclass of Runnable is responsible for overriding this method to return all runnable methods.
-
.runnables ⇒ Object
Returns all subclasses of Runnable.
-
.with_info_handler(reporter, &block) ⇒ Object
:nodoc:.
Instance Method Summary collapse
-
#failure ⇒ Object
:nodoc:.
-
#initialize(name) ⇒ Runnable
constructor
:nodoc:.
-
#marshal_dump ⇒ Object
:nodoc:.
-
#marshal_load(ary) ⇒ Object
:nodoc:.
-
#name ⇒ Object
Name of the run.
-
#name=(o) ⇒ Object
Set the name of the run.
-
#passed? ⇒ Boolean
Did this run pass?.
-
#result_code ⇒ Object
Returns a single character string to print based on the result of the run.
-
#run ⇒ Object
Runs a single method.
-
#skipped? ⇒ Boolean
Was this run skipped? See #passed? for more information.
-
#time_it ⇒ Object
:nodoc:.
Constructor Details
permalink #initialize(name) ⇒ Runnable
:nodoc:
431 432 433 434 435 |
# File 'lib/minitest.rb', line 431 def initialize name # :nodoc: self.name = name self.failures = [] self.assertions = 0 end |
Instance Attribute Details
permalink #assertions ⇒ Object
Number of assertions executed in this run.
281 282 283 |
# File 'lib/minitest.rb', line 281 def assertions @assertions end |
Class Method Details
permalink .inherited(klass) ⇒ Object
:nodoc:
1069 1070 1071 1072 |
# File 'lib/minitest.rb', line 1069 def self.inherited klass # :nodoc: self.runnables << klass super end |
permalink .methods_matching(re) ⇒ Object
Returns all instance methods matching the pattern re
.
318 319 320 |
# File 'lib/minitest.rb', line 318 def self.methods_matching re public_instance_methods(true).grep(re).map(&:to_s) end |
permalink .on_signal(name, action) ⇒ Object
:nodoc:
383 384 385 386 387 388 389 390 391 392 393 394 |
# File 'lib/minitest.rb', line 383 def self.on_signal name, action # :nodoc: supported = SIGNALS[name] old_trap = trap name do old_trap.call if old_trap.respond_to? :call action.call end if supported yield ensure trap name, old_trap if supported end |
permalink .reset ⇒ Object
:nodoc:
322 323 324 |
# File 'lib/minitest.rb', line 322 def self.reset # :nodoc: @@runnables = [] end |
permalink .run(reporter, options = {}) ⇒ Object
Responsible for running all runnable methods in a given class, each in its own instance. Each instance is passed to the reporter to record.
333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 |
# File 'lib/minitest.rb', line 333 def self.run reporter, = {} filter = [:filter] || "/./" filter = Regexp.new $1 if filter.is_a?(String) && filter =~ %r%/(.*)/% filtered_methods = self.runnable_methods.find_all { |m| filter === m || filter === "#{self}##{m}" } exclude = [:exclude] exclude = Regexp.new $1 if exclude =~ %r%/(.*)/% filtered_methods.delete_if { |m| exclude === m || exclude === "#{self}##{m}" } return if filtered_methods.empty? with_info_handler reporter do filtered_methods.each do |method_name| run_one_method self, method_name, reporter end end end |
permalink .run_one_method(klass, method_name, reporter) ⇒ Object
Runs a single method and has the reporter record the result. This was considered internal API but is factored out of run so that subclasses can specialize the running of an individual test. See Minitest::ParallelTest::ClassMethods for an example.
363 364 365 366 |
# File 'lib/minitest.rb', line 363 def self.run_one_method klass, method_name, reporter reporter.prerecord klass, method_name reporter.record Minitest.run_one_method(klass, method_name) end |
permalink .runnable_methods ⇒ Object
Each subclass of Runnable is responsible for overriding this method to return all runnable methods. See #methods_matching.
400 401 402 |
# File 'lib/minitest.rb', line 400 def self.runnable_methods raise NotImplementedError, "subclass responsibility" end |
permalink .runnables ⇒ Object
Returns all subclasses of Runnable.
407 408 409 |
# File 'lib/minitest.rb', line 407 def self.runnables @@runnables end |
permalink .with_info_handler(reporter, &block) ⇒ Object
:nodoc:
368 369 370 371 372 373 374 375 376 377 378 379 |
# File 'lib/minitest.rb', line 368 def self.with_info_handler reporter, &block # :nodoc: handler = lambda do unless reporter.passed? then warn "Current results:" warn "" warn reporter.reporters.first warn "" end end on_signal ::Minitest.info_signal, handler, &block end |
Instance Method Details
permalink #failure ⇒ Object
:nodoc:
427 428 429 |
# File 'lib/minitest.rb', line 427 def failure # :nodoc: self.failures.first end |
permalink #marshal_dump ⇒ Object
:nodoc:
413 414 415 416 417 418 419 420 421 |
# File 'lib/minitest.rb', line 413 def marshal_dump # :nodoc: unless @@marshal_dump_warned then warn ["Minitest::Runnable#marshal_dump is deprecated.", "You might be violating internals. From", caller.first].join " " @@marshal_dump_warned = true end [self.name, self.failures, self.assertions, self.time] end |
permalink #marshal_load(ary) ⇒ Object
:nodoc:
423 424 425 |
# File 'lib/minitest.rb', line 423 def marshal_load ary # :nodoc: self.name, self.failures, self.assertions, self.time = ary end |
permalink #name ⇒ Object
Name of the run.
304 305 306 |
# File 'lib/minitest.rb', line 304 def name @NAME end |
permalink #name=(o) ⇒ Object
Set the name of the run.
311 312 313 |
# File 'lib/minitest.rb', line 311 def name= o @NAME = o end |
permalink #passed? ⇒ Boolean
Did this run pass?
Note: skipped runs are not considered passing, but they don’t cause the process to exit non-zero.
450 451 452 |
# File 'lib/minitest.rb', line 450 def passed? raise NotImplementedError, "subclass responsibility" end |
permalink #result_code ⇒ Object
Returns a single character string to print based on the result of the run. One of "."
, "F"
, "E"
or "S"
.
459 460 461 |
# File 'lib/minitest.rb', line 459 def result_code raise NotImplementedError, "subclass responsibility" end |
permalink #run ⇒ Object
Runs a single method. Needs to return self.
440 441 442 |
# File 'lib/minitest.rb', line 440 def run raise NotImplementedError, "subclass responsibility" end |
permalink #skipped? ⇒ Boolean
Was this run skipped? See #passed? for more information.
466 467 468 |
# File 'lib/minitest.rb', line 466 def skipped? raise NotImplementedError, "subclass responsibility" end |
permalink #time_it ⇒ Object
:nodoc:
293 294 295 296 297 298 299 |
# File 'lib/minitest.rb', line 293 def time_it # :nodoc: t0 = Minitest.clock_time yield ensure self.time = Minitest.clock_time - t0 end |