mirror of
https://gitea.invidious.io/iv-org/shard-spectator.git
synced 2024-08-15 00:53:35 +00:00
Some config cleanup
This commit is contained in:
parent
79499c5d2e
commit
b2bf980685
3 changed files with 32 additions and 35 deletions
|
@ -16,19 +16,16 @@ module Spectator
|
||||||
# Examples won't run, but the output will show that they did.
|
# Examples won't run, but the output will show that they did.
|
||||||
getter? dry_run : Bool
|
getter? dry_run : Bool
|
||||||
|
|
||||||
# Random number generator to use for everything.
|
# Indicates whether examples run in a random order.
|
||||||
getter random : Random
|
|
||||||
|
|
||||||
# Indicates whether tests are run in a random order.
|
|
||||||
getter? randomize : Bool
|
getter? randomize : Bool
|
||||||
|
|
||||||
# Random seed used for number generation.
|
# Seed used for random number generation.
|
||||||
getter! random_seed : UInt64?
|
getter! random_seed : UInt64?
|
||||||
|
|
||||||
# Indicates whether profiling information should be displayed.
|
# Indicates whether timing information should be displayed.
|
||||||
getter? profile : Bool
|
getter? profile : Bool
|
||||||
|
|
||||||
# Filter that determines which examples to run.
|
# Filter determining examples to run.
|
||||||
getter example_filter : ExampleFilter
|
getter example_filter : ExampleFilter
|
||||||
|
|
||||||
# Creates a new configuration.
|
# Creates a new configuration.
|
||||||
|
@ -37,7 +34,6 @@ module Spectator
|
||||||
@fail_fast = builder.fail_fast?
|
@fail_fast = builder.fail_fast?
|
||||||
@fail_blank = builder.fail_blank?
|
@fail_blank = builder.fail_blank?
|
||||||
@dry_run = builder.dry_run?
|
@dry_run = builder.dry_run?
|
||||||
@random = builder.random
|
|
||||||
@randomize = builder.randomize?
|
@randomize = builder.randomize?
|
||||||
@random_seed = builder.seed?
|
@random_seed = builder.seed?
|
||||||
@profile = builder.profile?
|
@profile = builder.profile?
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
require "./composite_example_filter"
|
require "./composite_example_filter"
|
||||||
|
require "./config"
|
||||||
require "./example_filter"
|
require "./example_filter"
|
||||||
require "./null_example_filter"
|
require "./null_example_filter"
|
||||||
|
|
||||||
|
@ -12,14 +13,6 @@ module Spectator
|
||||||
new.build
|
new.build
|
||||||
end
|
end
|
||||||
|
|
||||||
# Random number generator to use.
|
|
||||||
protected getter random = Random::DEFAULT
|
|
||||||
|
|
||||||
def initialize
|
|
||||||
@seed = seed = @random.rand(UInt16).to_u64
|
|
||||||
@random.new_seed(seed)
|
|
||||||
end
|
|
||||||
|
|
||||||
@primary_formatter : Formatting::Formatter?
|
@primary_formatter : Formatting::Formatter?
|
||||||
@additional_formatters = [] of Formatting::Formatter
|
@additional_formatters = [] of Formatting::Formatter
|
||||||
@fail_fast = false
|
@fail_fast = false
|
||||||
|
@ -29,6 +22,11 @@ module Spectator
|
||||||
@profile = false
|
@profile = false
|
||||||
@filters = [] of ExampleFilter
|
@filters = [] of ExampleFilter
|
||||||
|
|
||||||
|
# Creates a configuration.
|
||||||
|
def build : Config
|
||||||
|
Config.new(self)
|
||||||
|
end
|
||||||
|
|
||||||
# Sets the primary formatter to use for reporting test progress and results.
|
# Sets the primary formatter to use for reporting test progress and results.
|
||||||
def formatter=(formatter : Formatting::Formatter)
|
def formatter=(formatter : Formatting::Formatter)
|
||||||
@primary_formatter = formatter
|
@primary_formatter = formatter
|
||||||
|
@ -105,7 +103,6 @@ module Spectator
|
||||||
# Sets the seed for the random number generator.
|
# Sets the seed for the random number generator.
|
||||||
def seed=(seed)
|
def seed=(seed)
|
||||||
@seed = seed
|
@seed = seed
|
||||||
@random = Random.new(seed)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# Randomizes test execution order.
|
# Randomizes test execution order.
|
||||||
|
@ -153,10 +150,5 @@ module Spectator
|
||||||
CompositeExampleFilter.new(@filters)
|
CompositeExampleFilter.new(@filters)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# Creates a configuration.
|
|
||||||
def build : Config
|
|
||||||
Config.new(self)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -30,6 +30,17 @@ module Spectator
|
||||||
@group_stack.push(root_group)
|
@group_stack.push(root_group)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Constructs the test spec.
|
||||||
|
# Returns the spec instance.
|
||||||
|
#
|
||||||
|
# Raises an error if there were not symmetrical calls to `#start_group` and `#end_group`.
|
||||||
|
# This would indicate a logical error somewhere in Spectator or an extension of it.
|
||||||
|
def build : Spec
|
||||||
|
raise "Mismatched start and end groups" unless root?
|
||||||
|
|
||||||
|
Spec.new(root_group, config)
|
||||||
|
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.
|
||||||
# Examples and groups defined after calling this method will be nested under the new group.
|
# Examples and groups defined after calling this method will be nested under the new group.
|
||||||
# The group will be finished and popped off the stack when `#end_example` is called.
|
# The group will be finished and popped off the stack when `#end_example` is called.
|
||||||
|
@ -87,23 +98,21 @@ 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
|
||||||
|
|
||||||
|
# Builds the configuration to use for the spec.
|
||||||
|
# A `ConfigBuilder` is yielded to the block provided to this method.
|
||||||
|
# That builder will be used to create the configuration.
|
||||||
|
def config
|
||||||
|
builder = ConfigBuilder.new
|
||||||
|
yield builder
|
||||||
|
@config = builder.build
|
||||||
|
end
|
||||||
|
|
||||||
# Sets the configuration of the spec.
|
# Sets the configuration of the spec.
|
||||||
# This configuration controls how examples run.
|
# This configuration controls how examples run.
|
||||||
def config=(config)
|
def config=(config)
|
||||||
@config = config
|
@config = config
|
||||||
end
|
end
|
||||||
|
|
||||||
# Constructs the test spec.
|
|
||||||
# Returns the spec instance.
|
|
||||||
#
|
|
||||||
# Raises an error if there were not symmetrical calls to `#start_group` and `#end_group`.
|
|
||||||
# This would indicate a logical error somewhere in Spectator or an extension of it.
|
|
||||||
def build : Spec
|
|
||||||
raise "Mismatched start and end groups" unless root?
|
|
||||||
|
|
||||||
Spec.new(root_group, config)
|
|
||||||
end
|
|
||||||
|
|
||||||
# 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
|
@group_stack.size == 1
|
||||||
|
@ -122,8 +131,8 @@ module Spectator
|
||||||
|
|
||||||
# Retrieves the configuration.
|
# Retrieves the configuration.
|
||||||
# If one wasn't previously set, a default configuration is used.
|
# If one wasn't previously set, a default configuration is used.
|
||||||
private def config
|
private def config : Config
|
||||||
@config || ConfigBuilder.new.build
|
@config || ConfigBuilder.default
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue