Class: Evilution::Config

Inherits:
Object
  • Object
show all
Defined in:
lib/evilution/config.rb

Constant Summary collapse

CONFIG_FILES =
%w[.evilution.yml config/evilution.yml].freeze
DEFAULTS =
{
  timeout: 30,
  format: :text,
  target: nil,
  min_score: 0.0,
  integration: :rspec,
  verbose: false,
  quiet: false,
  jobs: 1,
  fail_fast: nil,
  baseline: true,
  isolation: :auto,
  incremental: false,
  suggest_tests: false,
  progress: true,
  save_session: false,
  line_ranges: {},
  spec_files: [],
  ignore_patterns: [],
  show_disabled: false,
  baseline_session: nil,
  skip_heredoc_literals: false,
  related_specs_heuristic: false,
  preload: nil
}.freeze

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**options) ⇒ Config

Returns a new instance of Config.



41
42
43
44
45
46
# File 'lib/evilution/config.rb', line 41

def initialize(**options)
  file_options = options.delete(:skip_config_file) ? {} : load_config_file
  merged = DEFAULTS.merge(file_options).merge(options)
  assign_attributes(merged)
  freeze
end

Instance Attribute Details

#baselineObject (readonly)

Returns the value of attribute baseline.



34
35
36
# File 'lib/evilution/config.rb', line 34

def baseline
  @baseline
end

#baseline_sessionObject (readonly)

Returns the value of attribute baseline_session.



34
35
36
# File 'lib/evilution/config.rb', line 34

def baseline_session
  @baseline_session
end

#fail_fastObject (readonly)

Returns the value of attribute fail_fast.



34
35
36
# File 'lib/evilution/config.rb', line 34

def fail_fast
  @fail_fast
end

#formatObject (readonly)

Returns the value of attribute format.



34
35
36
# File 'lib/evilution/config.rb', line 34

def format
  @format
end

#hooksObject (readonly)

Returns the value of attribute hooks.



34
35
36
# File 'lib/evilution/config.rb', line 34

def hooks
  @hooks
end

#ignore_patternsObject (readonly)

Returns the value of attribute ignore_patterns.



34
35
36
# File 'lib/evilution/config.rb', line 34

def ignore_patterns
  @ignore_patterns
end

#incrementalObject (readonly)

Returns the value of attribute incremental.



34
35
36
# File 'lib/evilution/config.rb', line 34

def incremental
  @incremental
end

#integrationObject (readonly)

Returns the value of attribute integration.



34
35
36
# File 'lib/evilution/config.rb', line 34

def integration
  @integration
end

#isolationObject (readonly)

Returns the value of attribute isolation.



34
35
36
# File 'lib/evilution/config.rb', line 34

def isolation
  @isolation
end

#jobsObject (readonly)

Returns the value of attribute jobs.



34
35
36
# File 'lib/evilution/config.rb', line 34

def jobs
  @jobs
end

#line_rangesObject (readonly)

Returns the value of attribute line_ranges.



34
35
36
# File 'lib/evilution/config.rb', line 34

def line_ranges
  @line_ranges
end

#min_scoreObject (readonly)

Returns the value of attribute min_score.



34
35
36
# File 'lib/evilution/config.rb', line 34

def min_score
  @min_score
end

#preloadObject (readonly)

Returns the value of attribute preload.



34
35
36
# File 'lib/evilution/config.rb', line 34

def preload
  @preload
end

#progressObject (readonly)

Returns the value of attribute progress.



34
35
36
# File 'lib/evilution/config.rb', line 34

def progress
  @progress
end

#quietObject (readonly)

Returns the value of attribute quiet.



34
35
36
# File 'lib/evilution/config.rb', line 34

def quiet
  @quiet
end

Returns the value of attribute related_specs_heuristic.



34
35
36
# File 'lib/evilution/config.rb', line 34

def related_specs_heuristic
  @related_specs_heuristic
end

#save_sessionObject (readonly)

Returns the value of attribute save_session.



34
35
36
# File 'lib/evilution/config.rb', line 34

def save_session
  @save_session
end

#show_disabledObject (readonly)

Returns the value of attribute show_disabled.



34
35
36
# File 'lib/evilution/config.rb', line 34

def show_disabled
  @show_disabled
end

#skip_heredoc_literalsObject (readonly)

Returns the value of attribute skip_heredoc_literals.



34
35
36
# File 'lib/evilution/config.rb', line 34

def skip_heredoc_literals
  @skip_heredoc_literals
end

#spec_filesObject (readonly)

Returns the value of attribute spec_files.



34
35
36
# File 'lib/evilution/config.rb', line 34

def spec_files
  @spec_files
end

#suggest_testsObject (readonly)

Returns the value of attribute suggest_tests.



34
35
36
# File 'lib/evilution/config.rb', line 34

def suggest_tests
  @suggest_tests
end

#targetObject (readonly)

Returns the value of attribute target.



34
35
36
# File 'lib/evilution/config.rb', line 34

def target
  @target
end

#target_filesObject (readonly)

Returns the value of attribute target_files.



34
35
36
# File 'lib/evilution/config.rb', line 34

def target_files
  @target_files
end

#timeoutObject (readonly)

Returns the value of attribute timeout.



34
35
36
# File 'lib/evilution/config.rb', line 34

def timeout
  @timeout
end

#verboseObject (readonly)

Returns the value of attribute verbose.



34
35
36
# File 'lib/evilution/config.rb', line 34

def verbose
  @verbose
end

Class Method Details

.default_templateObject

Generates a default config file template.



120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
# File 'lib/evilution/config.rb', line 120

def self.default_template
  <<~YAML
    # Evilution configuration
    # See: https://github.com/marinazzio/evilution

    # Per-mutation timeout in seconds (default: 30)
    # timeout: 30

    # Output format: text or json (default: text)
    # format: text

    # Minimum mutation score to pass (0.0 to 1.0, default: 0.0)
    # min_score: 0.0

    # Test integration: rspec, minitest (default: rspec)
    # integration: rspec

    # Number of parallel workers (default: 1)
    # jobs: 1

    # Stop after N surviving mutants (default: disabled)
    # fail_fast: 1

    # Generate concrete test code in suggestions, matching integration (default: false)
    # suggest_tests: false

    # Skip all string literal mutations inside heredocs (default: false).
    # Useful for Rails apps where heredoc content (SQL, templates, fixtures)
    # rarely has meaningful test coverage and produces noisy survivors.
    # skip_heredoc_literals: true

    # Opt into the RelatedSpecHeuristic, which appends request/integration/
    # feature/system specs for mutations that touch `.includes(...)` calls
    # (default: false). Off by default because the fan-out can be heavy and
    # push runs over the per-mutation timeout. Enable if you need coverage
    # of N+1 regressions that only surface in higher-level specs.
    # related_specs_heuristic: true

    # Preload file required in the parent process before forking workers.
    # For Rails projects, spec/rails_helper.rb or test/test_helper.rb is
    # auto-detected when isolation resolves to :fork. Set to false to disable.
    # preload: spec/rails_helper.rb # or test/test_helper.rb

    # Hooks: Ruby files returning a Proc, keyed by lifecycle event
    # hooks:
    #   worker_process_start: config/evilution_hooks/worker_start.rb
    #   mutation_insert_pre: config/evilution_hooks/mutation_pre.rb

    # AST patterns to skip during mutation generation (default: [])
    # See docs/ast_pattern_syntax.md for pattern syntax
    # ignore_patterns:
    #   - "call{name=info, receiver=call{name=logger}}"
    #   - "call{name=debug|warn}"
  YAML
end

.file_optionsObject



104
105
106
107
108
109
110
111
112
113
114
115
116
117
# File 'lib/evilution/config.rb', line 104

def self.file_options
  CONFIG_FILES.each do |path|
    next unless File.exist?(path)

    data = YAML.safe_load_file(path, symbolize_names: true)
    return data.is_a?(Hash) ? data : {}
  rescue Psych::SyntaxError, Psych::DisallowedClass => e
    raise Evilution::ConfigError.new("failed to parse config file #{path}: #{e.message}", file: path)
  rescue SystemCallError => e
    raise Evilution::ConfigError.new("cannot read config file #{path}: #{e.message}", file: path)
  end

  {}
end

Instance Method Details

#baseline?Boolean

Returns:

  • (Boolean)


72
73
74
# File 'lib/evilution/config.rb', line 72

def baseline?
  baseline
end

#fail_fast?Boolean

Returns:

  • (Boolean)


68
69
70
# File 'lib/evilution/config.rb', line 68

def fail_fast?
  !fail_fast.nil?
end

#html?Boolean

Returns:

  • (Boolean)


56
57
58
# File 'lib/evilution/config.rb', line 56

def html?
  format == :html
end

#incremental?Boolean

Returns:

  • (Boolean)


76
77
78
# File 'lib/evilution/config.rb', line 76

def incremental?
  incremental
end

#json?Boolean

Returns:

  • (Boolean)


48
49
50
# File 'lib/evilution/config.rb', line 48

def json?
  format == :json
end

#line_ranges?Boolean

Returns:

  • (Boolean)


60
61
62
# File 'lib/evilution/config.rb', line 60

def line_ranges?
  !line_ranges.empty?
end

#progress?Boolean

Returns:

  • (Boolean)


84
85
86
# File 'lib/evilution/config.rb', line 84

def progress?
  progress
end

Returns:

  • (Boolean)


100
101
102
# File 'lib/evilution/config.rb', line 100

def related_specs_heuristic?
  related_specs_heuristic
end

#save_session?Boolean

Returns:

  • (Boolean)


88
89
90
# File 'lib/evilution/config.rb', line 88

def save_session?
  save_session
end

#show_disabled?Boolean

Returns:

  • (Boolean)


92
93
94
# File 'lib/evilution/config.rb', line 92

def show_disabled?
  show_disabled
end

#skip_heredoc_literals?Boolean

Returns:

  • (Boolean)


96
97
98
# File 'lib/evilution/config.rb', line 96

def skip_heredoc_literals?
  skip_heredoc_literals
end

#suggest_tests?Boolean

Returns:

  • (Boolean)


80
81
82
# File 'lib/evilution/config.rb', line 80

def suggest_tests?
  suggest_tests
end

#target?Boolean

Returns:

  • (Boolean)


64
65
66
# File 'lib/evilution/config.rb', line 64

def target?
  !target.nil?
end

#text?Boolean

Returns:

  • (Boolean)


52
53
54
# File 'lib/evilution/config.rb', line 52

def text?
  format == :text
end