Change ExampleNode to SpecNode

This commit is contained in:
Michael Miller 2021-01-09 10:39:04 -07:00
parent 0ee708281f
commit 7d0ba752e9
No known key found for this signature in database
GPG key ID: FB9F12F7C646A4AD
4 changed files with 21 additions and 18 deletions

View file

@ -1,14 +1,14 @@
require "./example_context_delegate" require "./example_context_delegate"
require "./example_group" require "./example_group"
require "./example_node"
require "./harness" require "./harness"
require "./pending_result" require "./pending_result"
require "./result" require "./result"
require "./source" require "./source"
require "./spec_node"
module Spectator module Spectator
# Standard example that runs a test case. # Standard example that runs a test case.
class Example < ExampleNode class Example < SpecNode
# Currently running example. # Currently running example.
class_getter! current : Example class_getter! current : Example

View file

@ -1,12 +1,12 @@
require "./events" require "./events"
require "./example_node" require "./spec_node"
module Spectator module Spectator
# Collection of examples and sub-groups. # Collection of examples and sub-groups.
class ExampleGroup < ExampleNode class ExampleGroup < SpecNode
include Enumerable(ExampleNode) include Enumerable(SpecNode)
include Events include Events
include Iterable(ExampleNode) include Iterable(SpecNode)
group_event before_all do |hooks| group_event before_all do |hooks|
Log.trace { "Processing before_all hooks" } Log.trace { "Processing before_all hooks" }
@ -48,11 +48,11 @@ module Spectator
end end
end end
@nodes = [] of ExampleNode @nodes = [] of SpecNode
# Removes the specified *node* from the group. # Removes the specified *node* from the group.
# The node will be unassigned from this group. # The node will be unassigned from this group.
def delete(node : ExampleNode) def delete(node : SpecNode)
# Only remove from the group if it is associated with this group. # Only remove from the group if it is associated with this group.
return unless node.group == self return unless node.group == self
@ -79,7 +79,7 @@ module Spectator
# Assigns the node to this group. # Assigns the node to this group.
# If the node already belongs to a group, # If the node already belongs to a group,
# it will be removed from the previous group before adding it to this group. # it will be removed from the previous group before adding it to this group.
def <<(node : ExampleNode) def <<(node : SpecNode)
# Remove from existing group if the node is part of one. # Remove from existing group if the node is part of one.
if (previous = node.group?) if (previous = node.group?)
previous.delete(node) previous.delete(node)

View file

@ -1,6 +1,6 @@
require "./example" require "./example"
require "./example_group" require "./example_group"
require "./example_node" require "./spec_node"
module Spectator module Spectator
# Iterates through all examples in a group and its nested groups. # Iterates through all examples in a group and its nested groups.
@ -9,12 +9,12 @@ module Spectator
# Stack that contains the iterators for each group. # Stack that contains the iterators for each group.
# A stack is used to track where in the tree this iterator is. # A stack is used to track where in the tree this iterator is.
@stack : Array(Iterator(ExampleNode)) @stack : Array(Iterator(SpecNode))
# Creates a new iterator. # Creates a new iterator.
# The *group* is the example group to iterate through. # The *group* is the example group to iterate through.
def initialize(@group : ExampleGroup) def initialize(@group : ExampleGroup)
iter = @group.each.as(Iterator(ExampleNode)) iter = @group.each.as(Iterator(SpecNode))
@stack = [iter] @stack = [iter]
end end
@ -39,7 +39,7 @@ module Spectator
# Restart the iterator at the beginning. # Restart the iterator at the beginning.
def rewind def rewind
# Same code as `#initialize`, but return self. # Same code as `#initialize`, but return self.
iter = @group.each.as(Iterator(ExampleNode)) iter = @group.each.as(Iterator(SpecNode))
@stack = [iter] @stack = [iter]
self self
end end

View file

@ -1,12 +1,15 @@
require "./label"
require "./source" require "./source"
module Spectator module Spectator
# A single example or collection (group) of examples in an example tree. # A single item in a test spec.
abstract class ExampleNode # This is commonly an `Example` or `ExampleGroup`,
# but can be anything that should be iterated over when running the spec.
abstract class SpecNode
# Location of the node in source code. # Location of the node in source code.
getter! source : Source getter! source : Source
# User-provided name or description of the test. # User-provided name or description of the node.
# This does not include the group name or descriptions. # This does not include the group name or descriptions.
# Use `#to_s` to get the full name. # Use `#to_s` to get the full name.
# #
@ -16,7 +19,7 @@ module Spectator
# of the first matcher that runs in the test case. # of the first matcher that runs in the test case.
# #
# If this value is a `Symbol`, the user specified a type for the name. # If this value is a `Symbol`, the user specified a type for the name.
getter! name : String | Symbol getter! name : Label
# Updates the name of the node. # Updates the name of the node.
protected def name=(@name : String) protected def name=(@name : String)
@ -35,7 +38,7 @@ module Spectator
# It can be a `Symbol` to describe a type. # It can be a `Symbol` to describe a type.
# The *source* tracks where the node exists in source code. # The *source* tracks where the node exists in source code.
# The node will be assigned to *group* if it is provided. # The node will be assigned to *group* if it is provided.
def initialize(@name : String | Symbol? = nil, @source : Source? = nil, group : ExampleGroup? = nil) def initialize(@name : Label = nil, @source : Source? = nil, group : ExampleGroup? = nil)
# Ensure group is linked. # Ensure group is linked.
group << self if group group << self if group
end end