Cleanup and document some example classes

This commit is contained in:
Michael Miller 2018-10-10 13:05:17 -06:00
parent 53831ab36a
commit 81dce3df9a
3 changed files with 30 additions and 6 deletions

View file

@ -1,16 +1,38 @@
module Spectator module Spectator
# Base class for all types of examples.
# Concrete types must implement the `#run_inner` and `#description` methods.
abstract class Example abstract class Example
# Indicates whether the example has already been run.
getter? finished = false getter? finished = false
# Group that the example belongs to.
getter group : ExampleGroup getter group : ExampleGroup
abstract def run : Result # Runs the example code.
# A result is returned, which represents the outcome of the test.
# An example can be run only once.
# An exception is raised if an attempt is made to run it more than once.
def run : Result
raise "Attempted to run example more than once (#{self})" if finished?
@finished = true
run_inner
end
# Implementation-specific for running the example code.
private abstract def run_inner : Result
# Message that describes what the example tests.
abstract def description : String abstract def description : String
# Creates the base of the example.
# The group should be the example group the example belongs to.
# The `sample_values` are passed to the example code.
def initialize(@group, sample_values : Internals::SampleValues) def initialize(@group, sample_values : Internals::SampleValues)
end end
private getter locals # String representation of the example.
# This consists of the groups the example is in and the description.
# The string can be given to end-users to identify the example.
def to_s(io) def to_s(io)
@group.to_s(io) @group.to_s(io)
io << ' ' io << ' '

View file

@ -1,9 +1,11 @@
require "./example" require "./example"
module Spectator module Spectator
# Common class for all examples marked as pending.
# This class will not run example code.
abstract class PendingExample < Example abstract class PendingExample < Example
def run # Returns a pending result.
@finished = true private def run_inner : Result
PendingResult.new(self) PendingResult.new(self)
end end
end end

View file

@ -2,7 +2,7 @@ require "./example"
module Spectator module Spectator
abstract class RunnableExample < Example abstract class RunnableExample < Example
def run def run_inner
result = ResultCapture.new result = ResultCapture.new
group.run_before_all_hooks group.run_before_all_hooks
group.run_before_each_hooks group.run_before_each_hooks