mirror of
https://gitea.invidious.io/iv-org/shard-spectator.git
synced 2024-08-15 00:53:35 +00:00
Split double macro into def_double and new_double
This commit is contained in:
parent
f1daecd25f
commit
5a4e95e8a2
1 changed files with 29 additions and 20 deletions
|
@ -8,13 +8,25 @@ module Spectator::DSL
|
||||||
# and double type name relative to its context.
|
# and double type name relative to its context.
|
||||||
DOUBLES = [] of {Symbol, Symbol, Symbol}
|
DOUBLES = [] of {Symbol, Symbol, Symbol}
|
||||||
|
|
||||||
macro double(name, **value_methods, &block)
|
private macro def_double(name, **value_methods, &block)
|
||||||
{% name_symbol = name.id.symbolize
|
{% # Construct a unique type name for the double by using the number of defined doubles.
|
||||||
context_type_name = @type.name(generic_args: false).symbolize %}
|
index = ::Spectator::DSL::Mocks::DOUBLES.size
|
||||||
|
double_type_name = "Double#{index}".id.symbolize
|
||||||
|
|
||||||
{% if @def %}
|
# Store information about how the double is defined and its context.
|
||||||
{% # Find tuples with the same name.
|
# This is important for constructing an instance of the double later.
|
||||||
found_tuples = ::Spectator::DSL::Mocks::DOUBLES.select { |tuple| tuple[0] == name_symbol }
|
::Spectator::DSL::Mocks::DOUBLES << {name.id.symbolize, @type.name(generic_args: false).symbolize, double_type_name} %}
|
||||||
|
|
||||||
|
{% begin %}
|
||||||
|
::Spectator::Double.define({{double_type_name}}, {{name}}, {{**value_methods}}){% if block %} do
|
||||||
|
{{block.body}}
|
||||||
|
end{% end %}
|
||||||
|
{% end %}
|
||||||
|
end
|
||||||
|
|
||||||
|
private macro new_double(name)
|
||||||
|
{% # Find tuples with the same name.
|
||||||
|
found_tuples = ::Spectator::DSL::Mocks::DOUBLES.select { |tuple| tuple[0] == name.id.symbolize }
|
||||||
|
|
||||||
# Split the current context's type namespace into parts.
|
# Split the current context's type namespace into parts.
|
||||||
type_parts = @type.name(generic_args: false).split("::")
|
type_parts = @type.name(generic_args: false).split("::")
|
||||||
|
@ -42,21 +54,18 @@ module Spectator::DSL
|
||||||
# Store the type name used to define the underlying double.
|
# Store the type name used to define the underlying double.
|
||||||
double_type_name = found_tuple[2].id %}
|
double_type_name = found_tuple[2].id %}
|
||||||
|
|
||||||
{{double_type_name}}.new
|
{{double_type_name}}.new
|
||||||
|
end
|
||||||
|
|
||||||
|
macro double(name, **value_methods, &block)
|
||||||
|
{% if @def %}
|
||||||
|
new_double({{name}}){% if block %} do
|
||||||
|
{{block.body}}
|
||||||
|
end{% end %}
|
||||||
{% else %}
|
{% else %}
|
||||||
{% # Construct a unique type name for the double by using the number of defined doubles.
|
def_double({{name}}, {{**value_methods}}){% if block %} do
|
||||||
index = ::Spectator::DSL::Mocks::DOUBLES.size
|
{{block.body}}
|
||||||
double_type_name = "Double#{index}".id.symbolize
|
end{% end %}
|
||||||
|
|
||||||
# Store information about how the double is defined and its context.
|
|
||||||
# This is important for constructing an instance of the double later.
|
|
||||||
::Spectator::DSL::Mocks::DOUBLES << {name_symbol, context_type_name, double_type_name} %}
|
|
||||||
|
|
||||||
{% begin %}
|
|
||||||
::Spectator::Double.define({{double_type_name}}, {{name}}, {{value_methods.double_splat}}){% if block %} do
|
|
||||||
{{block.body}}
|
|
||||||
end{% end %}
|
|
||||||
{% end %}
|
|
||||||
{% end %}
|
{% end %}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue