mirror of
https://gitea.invidious.io/iv-org/shard-spectator.git
synced 2024-08-15 00:53:35 +00:00
Capture source info for hooks
This commit is contained in:
parent
def66acc15
commit
df096d91aa
3 changed files with 50 additions and 24 deletions
|
@ -36,31 +36,27 @@ module Spectator::DSL
|
||||||
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(source = nil, label = "before_all", &block)
|
||||||
# See `Spec::Builder#before_all` for usage details.
|
hook = ExampleGroupHook.new(source: source, label: label, &block)
|
||||||
def before_all(&block)
|
@@builder.before_all(hook)
|
||||||
@@builder.before_all(&block)
|
|
||||||
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
|
||||||
#
|
def before_each(source = nil, label = "before_each", &block : Example -> _)
|
||||||
# See `Spec::Builder#before_each` for usage details.
|
hook = ExampleHook.new(source: source, label: label, &block)
|
||||||
def before_each(&block : Example -> _)
|
@@builder.before_each(hook)
|
||||||
@@builder.before_each(&block)
|
|
||||||
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(source = nil, label = "after_all", &block)
|
||||||
# See `Spec::Builder#after_all` for usage details.
|
hook = ExampleGroupHook.new(source: source, label: label, &block)
|
||||||
def after_all(&block)
|
@@builder.after_all(hook)
|
||||||
@@builder.after_all(&block)
|
|
||||||
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.
|
||||||
#
|
def after_each(source = nil, label = "after_each", &block : Example ->)
|
||||||
# See `Spec::Builder#after_each` for usage details.
|
hook = ExampleHook.new(source: source, label: label, &block)
|
||||||
def after_each(&block : Example ->)
|
@@builder.after_each(hook)
|
||||||
@@builder.after_each(&block)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# Sets the configuration of the spec.
|
# Sets the configuration of the spec.
|
||||||
|
|
|
@ -11,7 +11,9 @@ module Spectator::DSL
|
||||||
{{block.body}}
|
{{block.body}}
|
||||||
end
|
end
|
||||||
|
|
||||||
::Spectator::DSL::Builder.before_all { {{@type.name}}.%hook }
|
::Spectator::DSL::Builder.before_all(
|
||||||
|
::Spectator::Source.new({{block.filename}}, {{block.line_number}})
|
||||||
|
) { {{@type.name}}.%hook }
|
||||||
end
|
end
|
||||||
|
|
||||||
macro before_each(&block)
|
macro before_each(&block)
|
||||||
|
@ -21,9 +23,9 @@ module Spectator::DSL
|
||||||
{{block.body}}
|
{{block.body}}
|
||||||
end
|
end
|
||||||
|
|
||||||
::Spectator::DSL::Builder.before_each do |example|
|
::Spectator::DSL::Builder.before_each(
|
||||||
example.with_context({{@type.name}}) { %hook }
|
::Spectator::Source.new({{block.filename}}, {{block.line_number}})
|
||||||
end
|
) { |example| example.with_context({{@type.name}}) { %hook } }
|
||||||
end
|
end
|
||||||
|
|
||||||
macro after_all(&block)
|
macro after_all(&block)
|
||||||
|
@ -33,7 +35,9 @@ module Spectator::DSL
|
||||||
{{block.body}}
|
{{block.body}}
|
||||||
end
|
end
|
||||||
|
|
||||||
::Spectator::DSL::Builder.after_all { {{@type.name}}.%hook }
|
::Spectator::DSL::Builder.after_all(
|
||||||
|
::Spectator::Source.new({{block.filename}}, {{block.line_number}})
|
||||||
|
) { {{@type.name}}.%hook }
|
||||||
end
|
end
|
||||||
|
|
||||||
macro after_each(&block)
|
macro after_each(&block)
|
||||||
|
@ -43,9 +47,9 @@ module Spectator::DSL
|
||||||
{{block.body}}
|
{{block.body}}
|
||||||
end
|
end
|
||||||
|
|
||||||
::Spectator::DSL::Builder.after_each do |example|
|
::Spectator::DSL::Builder.after_each(
|
||||||
example.with_context({{@type.name}}) { %hook }
|
::Spectator::Source.new({{block.filename}}, {{block.line_number}})
|
||||||
end
|
) { |example| example.with_context({{@type.name}}) { %hook } }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -97,12 +97,25 @@ module Spectator
|
||||||
# The example is added to the current group by `Example` initializer.
|
# The example is added to the current group by `Example` initializer.
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Attaches a hook to be invoked before any and all examples in the current group.
|
||||||
|
def before_all(hook)
|
||||||
|
Log.trace { "Add before_all hook #{hook}" }
|
||||||
|
current_group.add_before_all_hook(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(&block)
|
def before_all(&block)
|
||||||
Log.trace { "Add before_all hook" }
|
Log.trace { "Add before_all hook" }
|
||||||
current_group.before_all(&block)
|
current_group.before_all(&block)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Attaches a hook to be invoked before every example in the current group.
|
||||||
|
# The current example is provided as a block argument.
|
||||||
|
def before_each(hook)
|
||||||
|
Log.trace { "Add before_each hook #{hook}" }
|
||||||
|
current_group.add_before_each_hook(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.
|
||||||
# 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 -> _)
|
||||||
|
@ -110,12 +123,25 @@ module Spectator
|
||||||
current_group.before_each(&block)
|
current_group.before_each(&block)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Attaches a hook to be invoked after any and all examples in the current group.
|
||||||
|
def after_all(hook)
|
||||||
|
Log.trace { "Add after_all hook #{hook}" }
|
||||||
|
current_group.add_after_all_hook(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(&block)
|
def after_all(&block)
|
||||||
Log.trace { "Add after_all hook" }
|
Log.trace { "Add after_all hook" }
|
||||||
current_group.after_all(&block)
|
current_group.after_all(&block)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Attaches a hook to be invoked after every example in the current group.
|
||||||
|
# The current example is provided as a block argument.
|
||||||
|
def after_each(hook)
|
||||||
|
Log.trace { "Add after_each hook #{hook}" }
|
||||||
|
current_group.add_after_each_hook(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.
|
||||||
# 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 -> _)
|
||||||
|
|
Loading…
Reference in a new issue