Sha256: 08ca2e11849f9778023e4b5e288e2634044b773ef3d4cd01404a3cfea2a97a05

Contents?: true

Size: 1.29 KB

Versions: 10

Compression:

Stored size: 1.29 KB

Contents

#!/usr/bin/env ruby
# encoding: UTF-8

require File.expand_path('../test_helper', __FILE__)
require 'fileutils'
require 'tmpdir'
require_relative 'prime'

# --  Tests ----
class PrinterGraphTest < TestCase
  def setup
    # WALL_TIME so we can use sleep in our test and get same measurements on linux and windows
    RubyProf::measure_mode = RubyProf::WALL_TIME
    @result = RubyProf.profile do
      run_primes(1000, 5000)
    end
  end

  def graph_output_nth_column_values(output, n)
    only_root_calls = output.split("\n").select { |line| line =~ /^ +[\d\.]+%/ }
    only_root_calls.collect { |line| line.split(/ +/)[n] }
  end

  def assert_sorted(array)
    array = array.map {|n| n.to_f} # allow for > 10s times to sort right, since lexographically 4.0 > 10.0
    assert_equal(array, array.sort.reverse, "Array #{array.inspect} is not sorted")
  end

  def test_graph_results_sorting
    printer = RubyProf::GraphPrinter.new(@result)

    sort_method_with_column_number = {:total_time => 3, :self_time => 4, :wait_time => 5, :children_time => 6}

    sort_method_with_column_number.each_pair do |sort_method, n|
      printer.print(output = '', :sort_method => sort_method)
      times = graph_output_nth_column_values(output, n)
      assert_sorted times
    end
  end
end

Version data entries

10 entries across 10 versions & 1 rubygems

Version Path
ruby-prof-1.5.0-x64-mingw-ucrt test/printer_graph_test.rb
ruby-prof-1.5.0 test/printer_graph_test.rb
ruby-prof-1.4.5-x64-mingw-ucrt test/printer_graph_test.rb
ruby-prof-1.4.5 test/printer_graph_test.rb
ruby-prof-1.4.4-x64-mingw-ucrt test/printer_graph_test.rb
ruby-prof-1.4.4 test/printer_graph_test.rb
ruby-prof-1.4.3-x64-mingw32 test/printer_graph_test.rb
ruby-prof-1.4.3 test/printer_graph_test.rb
ruby-prof-1.4.2-x64-mingw32 test/printer_graph_test.rb
ruby-prof-1.4.2 test/printer_graph_test.rb