Sha256: 5156c15c16a90a14f06fac4f30623db6dd9348a9030dfdf4eb4f6727383787f2
Contents?: true
Size: 1.31 KB
Versions: 1
Compression:
Stored size: 1.31 KB
Contents
# frozen_string_literal: true require 'rast/rules/rule_processor' # Validates rules class RuleValidator def validate(scenario: [], fixture: {}) rule_result = RuleProcessor.new.evaluate( scenario: scenario, fixture: fixture ) spec = fixture[:spec] rule = spec.rule single_result = rule.size == 1 if single_result next_result = rule_result.first outcome = rule.outcomes.first binary_outcome(outcome: outcome, spec: spec, expected: next_result) else validate_multi(scenario: scenario, spec: spec, rule_result: rule_result) end end private def validate_multi(scenario: [], spec: nil, rule_result: []) matched_outputs = [] match_count = 0 rule_result.map { |result| result.to_s == 'true' }.each_with_index do |result, i| next unless result match_count += 1 matched_outputs << spec.rule.outcomes[i] end Rast.assert("#{spec.description} #{scenario} must fall into a unique rule outcome/clause, matched: #{matched_outputs}") do match_count == 1 || match_count == 0 && !spec.default_outcome.nil? end matched_outputs.first || spec.default_outcome end # def binary_outcome(outcome: '', spec: nil, expected: false) if expected == 'true' outcome else spec.pair[outcome] end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
rast-0.18.0 | lib/rast/rules/rule_validator.rb |