Add prepend and append variants of hooks to DSL

This commit is contained in:
Michael Miller 2021-08-08 10:51:39 -06:00
parent 841efc236d
commit 605b82c532
No known key found for this signature in database
GPG key ID: FB9F12F7C646A4AD
3 changed files with 100 additions and 1 deletions

View file

@ -60,42 +60,84 @@ module Spectator::DSL
@@builder.before_suite(hook) @@builder.before_suite(hook)
end end
# Defines a block of code to execute before any and all examples in the test suite.
def prepend_before_suite(location = nil, label = "before_suite", &block)
hook = ExampleGroupHook.new(location: location, label: label, &block)
@@builder.prepend_before_suite(hook)
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(location = nil, label = "before_all", &block) def before_all(location = nil, label = "before_all", &block)
hook = ExampleGroupHook.new(location: location, label: label, &block) hook = ExampleGroupHook.new(location: location, label: label, &block)
@@builder.before_all(hook) @@builder.before_all(hook)
end end
# Defines a block of code to execute before any and all examples in the current group.
def prepend_before_all(location = nil, label = "before_all", &block)
hook = ExampleGroupHook.new(location: location, label: label, &block)
@@builder.prepend_before_all(hook)
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
def before_each(location = nil, label = "before_each", &block : Example -> _) def before_each(location = nil, label = "before_each", &block : Example -> _)
hook = ExampleHook.new(location: location, label: label, &block) hook = ExampleHook.new(location: location, label: label, &block)
@@builder.before_each(hook) @@builder.before_each(hook)
end end
# Defines a block of code to execute before every example in the current group
def prepend_before_each(location = nil, label = "before_each", &block : Example -> _)
hook = ExampleHook.new(location: location, label: label, &block)
@@builder.prepend_before_each(hook)
end
# Defines a block of code to execute after any and all examples in the test suite. # Defines a block of code to execute after any and all examples in the test suite.
def after_suite(location = nil, label = "after_suite", &block) def after_suite(location = nil, label = "after_suite", &block)
hook = ExampleGroupHook.new(location: location, label: label, &block) hook = ExampleGroupHook.new(location: location, label: label, &block)
@@builder.after_suite(hook) @@builder.after_suite(hook)
end end
# Defines a block of code to execute after any and all examples in the test suite.
def append_after_suite(location = nil, label = "after_suite", &block)
hook = ExampleGroupHook.new(location: location, label: label, &block)
@@builder.append_after_suite(hook)
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(location = nil, label = "after_all", &block) def after_all(location = nil, label = "after_all", &block)
hook = ExampleGroupHook.new(location: location, label: label, &block) hook = ExampleGroupHook.new(location: location, label: label, &block)
@@builder.after_all(hook) @@builder.after_all(hook)
end end
# Defines a block of code to execute after any and all examples in the current group.
def append_after_all(location = nil, label = "after_all", &block)
hook = ExampleGroupHook.new(location: location, label: label, &block)
@@builder.append_after_all(hook)
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.
def after_each(location = nil, label = "after_each", &block : Example ->) def after_each(location = nil, label = "after_each", &block : Example ->)
hook = ExampleHook.new(location: location, label: label, &block) hook = ExampleHook.new(location: location, label: label, &block)
@@builder.after_each(hook) @@builder.after_each(hook)
end end
# Defines a block of code to execute after every example in the current group.
def append_after_each(location = nil, label = "after_each", &block : Example ->)
hook = ExampleHook.new(location: location, label: label, &block)
@@builder.append_after_each(hook)
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.
def around_each(location = nil, label = "around_each", &block : Example::Procsy ->) def around_each(location = nil, label = "around_each", &block : Example::Procsy ->)
hook = ExampleProcsyHook.new(location: location, label: label, &block) hook = ExampleProcsyHook.new(location: location, label: label, &block)
@@builder.around_each(hook) @@builder.around_each(hook)
end end
# Defines a block of code to execute around every example in the current group.
def prepend_around_each(location = nil, label = "around_each", &block : Example::Procsy ->)
hook = ExampleProcsyHook.new(location: location, label: label, &block)
@@builder.prepend_around_each(hook)
end
# Sets the configuration of the spec. # Sets the configuration of the spec.
# #
# See `Spec::Builder#config=` for usage details. # See `Spec::Builder#config=` for usage details.

View file

@ -104,31 +104,67 @@ module Spectator::DSL
# This means that values defined by `let` and `subject` are not available. # This means that values defined by `let` and `subject` are not available.
define_example_group_hook :before_suite define_example_group_hook :before_suite
# Defines a block of code that will be invoked once before any examples in the suite.
# The block will not run in the context of the current running example.
# This means that values defined by `let` and `subject` are not available.
# The hook is added before all others others of the same type in this context.
define_example_group_hook :prepend_before_suite
# Defines a block of code that will be invoked once after all examples in the suite. # Defines a block of code that will be invoked once after all examples in the suite.
# The block will not run in the context of the current running example. # The block will not run in the context of the current running example.
# This means that values defined by `let` and `subject` are not available. # This means that values defined by `let` and `subject` are not available.
define_example_group_hook :after_suite define_example_group_hook :after_suite
# Defines a block of code that will be invoked once after all examples in the suite.
# The block will not run in the context of the current running example.
# This means that values defined by `let` and `subject` are not available.
# The hook is added after all others others of the same type in this context.
define_example_group_hook :append_after_suite
# Defines a block of code that will be invoked once before any examples in the group. # Defines a block of code that will be invoked once before any examples in the group.
# The block will not run in the context of the current running example. # The block will not run in the context of the current running example.
# This means that values defined by `let` and `subject` are not available. # This means that values defined by `let` and `subject` are not available.
define_example_group_hook :before_all define_example_group_hook :before_all
# Defines a block of code that will be invoked once before any examples in the group.
# The block will not run in the context of the current running example.
# This means that values defined by `let` and `subject` are not available.
# The hook is added before all others others of the same type in this context.
define_example_group_hook :prepend_before_all
# Defines a block of code that will be invoked once after all examples in the group. # Defines a block of code that will be invoked once after all examples in the group.
# The block will not run in the context of the current running example. # The block will not run in the context of the current running example.
# This means that values defined by `let` and `subject` are not available. # This means that values defined by `let` and `subject` are not available.
define_example_group_hook :after_all define_example_group_hook :after_all
# Defines a block of code that will be invoked once after all examples in the group.
# The block will not run in the context of the current running example.
# This means that values defined by `let` and `subject` are not available.
# The hook is added after all others others of the same type in this context.
define_example_group_hook :append_after_all
# Defines a block of code that will be invoked before every example in the group. # Defines a block of code that will be invoked before every example in the group.
# The block will be run in the context of the current running example. # The block will be run in the context of the current running example.
# This means that values defined by `let` and `subject` are available. # This means that values defined by `let` and `subject` are available.
define_example_hook :before_each define_example_hook :before_each
# Defines a block of code that will be invoked before every example in the group.
# The block will be run in the context of the current running example.
# This means that values defined by `let` and `subject` are available.
# The hook is added before all others others of the same type in this context.
define_example_hook :prepend_before_each
# Defines a block of code that will be invoked after every example in the group. # Defines a block of code that will be invoked after every example in the group.
# The block will be run in the context of the current running example. # The block will be run in the context of the current running example.
# This means that values defined by `let` and `subject` are available. # This means that values defined by `let` and `subject` are available.
define_example_hook :after_each define_example_hook :after_each
# Defines a block of code that will be invoked after every example in the group.
# The block will be run in the context of the current running example.
# This means that values defined by `let` and `subject` are available.
# The hook is added after all others others of the same type in this context.
define_example_hook :append_after_each
# Defines a block of code that will be invoked around every example in the group. # Defines a block of code that will be invoked around every example in the group.
# The block will be run in the context of the current running example. # The block will be run in the context of the current running example.
# This means that values defined by `let` and `subject` are available. # This means that values defined by `let` and `subject` are available.
@ -138,5 +174,16 @@ module Spectator::DSL
# The `Example::Procsy#run` method should be called to ensure the example runs. # The `Example::Procsy#run` method should be called to ensure the example runs.
# More code can run afterwards (in the block). # More code can run afterwards (in the block).
define_example_hook :around_each define_example_hook :around_each
# Defines a block of code that will be invoked around every example in the group.
# The block will be run in the context of the current running example.
# This means that values defined by `let` and `subject` are available.
# The hook is added before all others others of the same type in this context.
#
# The block will execute before the example.
# An `Example::Procsy` is passed to the block.
# The `Example::Procsy#run` method should be called to ensure the example runs.
# More code can run afterwards (in the block).
define_example_hook :prepend_around_each
end end
end end

View file

@ -18,7 +18,17 @@ module Spectator
class SpecBuilder class SpecBuilder
Log = ::Spectator::Log.for(self) Log = ::Spectator::Log.for(self)
delegate before_all, after_all, before_each, after_each, around_each, to: current delegate before_all,
prepend_before_all,
after_all,
append_after_all,
before_each,
prepend_before_each,
after_each,
append_after_each,
around_each,
prepend_around_each,
to: current
# Stack tracking the current group. # Stack tracking the current group.
# The bottom of the stack (first element) is the root group. # The bottom of the stack (first element) is the root group.