summaryrefslogtreecommitdiffhomepage
path: root/test/profile.rb
blob: 91b0507f0f2cac1fc5a3e49c0f30f663221521e6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
#!/usr/bin/env ruby -s

# Usage:
# > ruby test/profile.rb
# > pprof.rb --gif /tmp/axlsx > /tmp/axlsx.gif
# > open /tmp/axlsx_noautowidth.gif

$:.unshift "#{File.dirname(__FILE__)}/../lib"
require 'axlsx'
require 'ruby-prof'
row = []
# Taking worst case scenario of all string data
input = (32..126).to_a.pack('U*').chars.to_a
20.times { row << input.shuffle.join}

profile = RubyProf.profile do
  p = Axlsx::Package.new
  p.workbook.add_worksheet do |sheet|
    30.times do
      sheet << row
    end
  end
end
printer = RubyProf::CallTreePrinter.new(profile)
printer.print(File.new('axlsx.qcachegrind', 'w'))