Class: SimpleCov::Result
| Relationships & Source Files | |
| Super Chains via Extension / Inclusion / Inheritance | |
| Class Chain: 
          self,
          Forwardable
         | |
| Inherits: | Object | 
| Defined in: | lib/simplecov/result.rb | 
Overview
A simplecov code coverage result, initialized from the Hash Ruby’s built-in coverage library generates (Coverage.result).
Class Method Summary
- 
    
      .from_hash(hash)  
    
    Loads a #to_hash dump. 
- 
    
      .new(original_result, command_name: nil, created_at: nil)  ⇒ Result 
    
    constructor
    Initialize a new Resultfrom givenCoverage.result(a Hash of filenames each containing an array of coverage data).
Instance Attribute Summary
- 
    
      #command_name  
    
    rw
    The command name that launched this result. 
- 
    
      #command_name=(value)  
    
    rw
    Explicitly set the command name that was used for this coverage result. 
- 
    
      #created_at  
    
    rw
    Defines when this result has been created. 
- 
    
      #created_at=(value)  
    
    rw
    Explicitly set the Time this result has been created. 
- 
    
      #files  
      (also: #source_files)
    
    readonly
    Returns all files that are applicable to this result (sans filters!) as instances of SourceFile.
- 
    
      #original_result  
    
    readonly
    Returns the original Coverage.resultused for this instance ofResult
- 
    
      #source_files  
    
    readonly
    Alias for #files. 
Instance Method Summary
- 
    
      #filenames  
    
    Returns all filenames for source files contained in this result. 
- 
    
      #format!  
    
    Applies the configured SimpleCov.formatteron this result.
- 
    
      #groups  
    
    Returns a Hash of groups for this result. 
- 
    
      #to_hash  
    
    Returns a hash representation of this Resultthat can be used for marshalling it into JSON.
- #coverage private
- 
    
      #filter!  
    
    private
    Applies all configured ::SimpleCovfilters on this result’s source files.
Constructor Details
    .new(original_result, command_name: nil, created_at: nil)  ⇒ Result 
  
Initialize a new Result from given Coverage.result (a Hash of filenames each containing an array of coverage data)
# File 'lib/simplecov/result.rb', line 28
def initialize(original_result, command_name: nil, created_at: nil) result = original_result @original_result = result.freeze @command_name = command_name @created_at = created_at @files = SimpleCov::FileList.new(result.map do |filename, coverage| SimpleCov::SourceFile.new(filename, JSON.parse(JSON.dump(coverage))) if File.file?(filename) end.compact.sort_by(&:filename)) filter! end
Class Method Details
.from_hash(hash)
Loads a #to_hash dump
# File 'lib/simplecov/result.rb', line 76
def self.from_hash(hash) hash.map do |command_name, data| new(data.fetch("coverage"), command_name: command_name, created_at: Time.at(data["timestamp"])) end end
Instance Attribute Details
#command_name (rw)
The command name that launched this result. Delegated to SimpleCov.command_name if not set manually
# File 'lib/simplecov/result.rb', line 61
def command_name @command_name ||= SimpleCov.command_name end
#command_name=(value) (rw)
Explicitly set the command name that was used for this coverage result. Defaults to SimpleCov.command_name
# File 'lib/simplecov/result.rb', line 21
attr_writer :command_name
#created_at (rw)
Defines when this result has been created. Defaults to Time.now
# File 'lib/simplecov/result.rb', line 55
def created_at @created_at ||= Time.now end
#created_at=(value) (rw)
Explicitly set the Time this result has been created
# File 'lib/simplecov/result.rb', line 19
attr_writer :created_at
#files (readonly) Also known as: #source_files
Returns all files that are applicable to this result (sans filters!) as instances of SourceFile. Aliased as :source_files
# File 'lib/simplecov/result.rb', line 16
attr_reader :files
#original_result (readonly)
Returns the original Coverage.result used for this instance of Result
# File 'lib/simplecov/result.rb', line 14
attr_reader :original_result
#source_files (readonly)
Alias for #files.
# File 'lib/simplecov/result.rb', line 17
alias source_files files
Instance Method Details
#coverage (private)
[ GitHub ]# File 'lib/simplecov/result.rb', line 84
def coverage keys = original_result.keys & filenames keys.zip(original_result.values_at(*keys)).to_h end
#filenames
Returns all filenames for source files contained in this result
# File 'lib/simplecov/result.rb', line 40
def filenames files.map(&:filename) end
#filter! (private)
Applies all configured ::SimpleCov filters on this result’s source files
#format!
Applies the configured SimpleCov.formatter on this result
#groups
Returns a Hash of groups for this result. Define groups using SimpleCov.add_group ‘Models’, ‘app/models’
#to_hash
Returns a hash representation of this Result that can be used for marshalling it into JSON
# File 'lib/simplecov/result.rb', line 66
def to_hash { command_name => { "coverage" => coverage, "timestamp" => created_at.to_i } } end