Shorten names and cleanup

This commit is contained in:
Michael Miller 2021-07-17 10:47:16 -06:00
parent 6c55301d0b
commit c7a90b3e64
No known key found for this signature in database
GPG key ID: FB9F12F7C646A4AD

View file

@ -19,7 +19,7 @@ module Spectator
# The root group should never be removed. # The root group should never be removed.
# The top of the stack (last element) is the current group. # The top of the stack (last element) is the current group.
# New examples should be added to the current group. # New examples should be added to the current group.
@group_stack : Deque(ExampleGroup) @stack : Deque(ExampleGroup)
# Configuration for the spec. # Configuration for the spec.
@config : Config? @config : Config?
@ -27,9 +27,9 @@ module Spectator
# Creates a new spec builder. # Creates a new spec builder.
# A root group is pushed onto the group stack. # A root group is pushed onto the group stack.
def initialize def initialize
root_group = ExampleGroup.new root = ExampleGroup.new
@group_stack = Deque(ExampleGroup).new @stack = Deque(ExampleGroup).new
@group_stack.push(root_group) @stack.push(root)
end end
# Constructs the test spec. # Constructs the test spec.
@ -40,7 +40,7 @@ module Spectator
def build : Spec def build : Spec
raise "Mismatched start and end groups" unless root? raise "Mismatched start and end groups" unless root?
Spec.new(root_group, config) Spec.new(root, config)
end end
# Defines a new example group and pushes it onto the group stack. # Defines a new example group and pushes it onto the group stack.
@ -60,8 +60,8 @@ module Spectator
# It shouldn't be used outside of this class until a matching `#end_group` is called. # It shouldn't be used outside of this class until a matching `#end_group` is called.
def start_group(name, location = nil, metadata = Metadata.new) : ExampleGroup def start_group(name, location = nil, metadata = Metadata.new) : ExampleGroup
Log.trace { "Start group: #{name.inspect} @ #{location}; metadata: #{metadata}" } Log.trace { "Start group: #{name.inspect} @ #{location}; metadata: #{metadata}" }
ExampleGroup.new(name, location, current_group, metadata).tap do |group| ExampleGroup.new(name, location, current, metadata).tap do |group|
@group_stack << group @stack.push(group)
end end
end end
@ -81,8 +81,8 @@ module Spectator
# It shouldn't be used outside of this class until a matching `#end_group` is called. # It shouldn't be used outside of this class until a matching `#end_group` is called.
def start_iterative_group(collection, location = nil, metadata = Metadata.new) : ExampleGroup def start_iterative_group(collection, location = nil, metadata = Metadata.new) : ExampleGroup
Log.trace { "Start iterative group: #{typeof(collection)} @ #{location}; metadata: #{metadata}" } Log.trace { "Start iterative group: #{typeof(collection)} @ #{location}; metadata: #{metadata}" }
IterativeExampleGroup.new(collection, location, current_group, metadata).tap do |group| IterativeExampleGroup.new(collection, location, current, metadata).tap do |group|
@group_stack << group @stack.push(group)
end end
end end
@ -93,10 +93,10 @@ module Spectator
# At this point, it is safe to use the group. # At this point, it is safe to use the group.
# All of its examples and sub-groups have been populated. # All of its examples and sub-groups have been populated.
def end_group : ExampleGroup def end_group : ExampleGroup
Log.trace { "End group: #{current_group}" } Log.trace { "End group: #{current}" }
raise "Can't pop root group" if root? raise "Can't pop root group" if root?
@group_stack.pop @stack.pop
end end
# Defines a new example. # Defines a new example.
@ -120,7 +120,7 @@ module Spectator
# It is expected that the test code runs when the block is called. # It is expected that the test code runs when the block is called.
def add_example(name, location, context_builder, metadata = Metadata.new, &block : Example -> _) def add_example(name, location, context_builder, metadata = Metadata.new, &block : Example -> _)
Log.trace { "Add example: #{name} @ #{location}; metadata: #{metadata}" } Log.trace { "Add example: #{name} @ #{location}; metadata: #{metadata}" }
current_group.create_child do |group| current.create_child do |group|
context = context_builder.call context = context_builder.call
Example.new(context, block, name, location, group, metadata) Example.new(context, block, name, location, group, metadata)
end end
@ -142,7 +142,7 @@ module Spectator
# The newly created example is returned. # The newly created example is returned.
def add_pending_example(name, location, metadata = Metadata.new, reason = nil) : Example def add_pending_example(name, location, metadata = Metadata.new, reason = nil) : Example
Log.trace { "Add pending example: #{name} @ #{location}; metadata: #{metadata}" } Log.trace { "Add pending example: #{name} @ #{location}; metadata: #{metadata}" }
current_group.create_child do |group| current.create_child do |group|
Example.pending(name, location, group, metadata, reason) Example.pending(name, location, group, metadata, reason)
end end
end end
@ -150,67 +150,67 @@ module Spectator
# Attaches a hook to be invoked before any and all examples in the current group. # Attaches a hook to be invoked before any and all examples in the current group.
def before_all(hook) def before_all(hook)
Log.trace { "Add before_all hook #{hook}" } Log.trace { "Add before_all hook #{hook}" }
current_group.add_before_all_hook(hook) current.add_before_all_hook(hook)
end end
# Defines a block of code to execute before any and all examples in the current group. # Defines a block of code to execute before any and all examples in the current group.
def before_all(&block) def before_all(&block)
Log.trace { "Add before_all hook" } Log.trace { "Add before_all hook" }
current_group.before_all(&block) current.before_all(&block)
end end
# Attaches a hook to be invoked before every example in the current group. # Attaches a hook to be invoked before every example in the current group.
# The current example is provided as a block argument. # The current example is provided as a block argument.
def before_each(hook) def before_each(hook)
Log.trace { "Add before_each hook #{hook}" } Log.trace { "Add before_each hook #{hook}" }
current_group.add_before_each_hook(hook) current.add_before_each_hook(hook)
end end
# Defines a block of code to execute before every example in the current group. # Defines a block of code to execute before every example in the current group.
# The current example is provided as a block argument. # The current example is provided as a block argument.
def before_each(&block : Example -> _) def before_each(&block : Example -> _)
Log.trace { "Add before_each hook block" } Log.trace { "Add before_each hook block" }
current_group.before_each(&block) current.before_each(&block)
end end
# Attaches a hook to be invoked after any and all examples in the current group. # Attaches a hook to be invoked after any and all examples in the current group.
def after_all(hook) def after_all(hook)
Log.trace { "Add after_all hook #{hook}" } Log.trace { "Add after_all hook #{hook}" }
current_group.add_after_all_hook(hook) current.add_after_all_hook(hook)
end end
# Defines a block of code to execute after any and all examples in the current group. # Defines a block of code to execute after any and all examples in the current group.
def after_all(&block) def after_all(&block)
Log.trace { "Add after_all hook" } Log.trace { "Add after_all hook" }
current_group.after_all(&block) current.after_all(&block)
end end
# Attaches a hook to be invoked after every example in the current group. # Attaches a hook to be invoked after every example in the current group.
# The current example is provided as a block argument. # The current example is provided as a block argument.
def after_each(hook) def after_each(hook)
Log.trace { "Add after_each hook #{hook}" } Log.trace { "Add after_each hook #{hook}" }
current_group.add_after_each_hook(hook) current.add_after_each_hook(hook)
end end
# Defines a block of code to execute after every example in the current group. # Defines a block of code to execute after every example in the current group.
# The current example is provided as a block argument. # The current example is provided as a block argument.
def after_each(&block : Example -> _) def after_each(&block : Example -> _)
Log.trace { "Add after_each hook" } Log.trace { "Add after_each hook" }
current_group.after_each(&block) current.after_each(&block)
end end
# Attaches a hook to be invoked around every example in the current group. # Attaches a hook to be invoked around every example in the current group.
# The current example in procsy form is provided as a block argument. # The current example in procsy form is provided as a block argument.
def around_each(hook) def around_each(hook)
Log.trace { "Add around_each hook #{hook}" } Log.trace { "Add around_each hook #{hook}" }
current_group.add_around_each_hook(hook) current.add_around_each_hook(hook)
end end
# Defines a block of code to execute around every example in the current group. # Defines a block of code to execute around every example in the current group.
# The current example in procsy form is provided as a block argument. # The current example in procsy form is provided as a block argument.
def around_each(&block : Example -> _) def around_each(&block : Example -> _)
Log.trace { "Add around_each hook" } Log.trace { "Add around_each hook" }
current_group.around_each(&block) current.around_each(&block)
end end
# Builds the configuration to use for the spec. # Builds the configuration to use for the spec.
@ -230,18 +230,18 @@ module Spectator
# Checks if the current group is the root group. # Checks if the current group is the root group.
private def root? private def root?
@group_stack.size == 1 @stack.size == 1
end end
# Retrieves the root group. # Retrieves the root group.
private def root_group private def root
@group_stack.first @stack.first
end end
# Retrieves the current group, which is at the top of the stack. # Retrieves the current group, which is at the top of the stack.
# This is the group that new examples should be added to. # This is the group that new examples should be added to.
private def current_group private def current
@group_stack.last @stack.last
end end
# Retrieves the configuration. # Retrieves the configuration.