Class: Grntest::BaseResult

Inherits:
Object
  • Object
show all
Defined in:
lib/grntest/base-result.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeBaseResult

Returns a new instance of BaseResult.



20
21
22
23
# File 'lib/grntest/base-result.rb', line 20

def initialize
  @cpu_elapsed_time = 0
  @real_elapsed_time = 0
end

Instance Attribute Details

#cpu_elapsed_timeObject

Returns the value of attribute cpu_elapsed_time.



18
19
20
# File 'lib/grntest/base-result.rb', line 18

def cpu_elapsed_time
  @cpu_elapsed_time
end

#real_elapsed_timeObject

Returns the value of attribute real_elapsed_time.



19
20
21
# File 'lib/grntest/base-result.rb', line 19

def real_elapsed_time
  @real_elapsed_time
end

Instance Method Details

#measureObject



25
26
27
28
29
30
31
32
33
34
35
36
37
38
# File 'lib/grntest/base-result.rb', line 25

def measure
  cpu_start_time = Process.times
  real_start_time = Process.clock_gettime(Process::CLOCK_MONOTONIC)
  yield
ensure
  cpu_finish_time = Process.times
  real_finish_time = Process.clock_gettime(Process::CLOCK_MONOTONIC)
  @cpu_elapsed_time +=
    (cpu_finish_time.utime - cpu_start_time.utime) +
    (cpu_finish_time.stime - cpu_start_time.stime) +
    (cpu_finish_time.cutime - cpu_start_time.cutime) +
    (cpu_finish_time.cstime - cpu_start_time.cstime)
  @real_elapsed_time += real_finish_time - real_start_time
end