Sha256: cc8427bc724e094edb0c2f828a9e45a3106f521dd07f012e1c868766a4f8c976

Contents?: true

Size: 715 Bytes

Versions: 11

Compression:

Stored size: 715 Bytes

Contents

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

$LOAD_PATH << File.expand_path(File.join(File.dirname(__FILE__), "..", "..", "lib"))

require "amq/protocol/client"

FRAME_SIZE = 128 * 1024

puts
puts "-" * 80
puts "Profiling on #{RUBY_DESCRIPTION}"

n = 250_000

# warm up the JIT, etc
puts "Doing a warmup run..."
15_000.times { AMQ::Protocol::Method.encode_body("ab" * 1024, 1, FRAME_SIZE) }

require 'stackprof'

# preallocate
ary = Array.new(n) { "ab" * 1024 }

puts "Doing main run..."
result = StackProf.run(mode: :wall) do
  n.times { |i| AMQ::Protocol::Method.encode_body(ary[i], 1, FRAME_SIZE) }
end

File.open('./profiling/dumps/body_framing_with_2k_payload.dump', "w+") do |f|
  f.write Marshal.dump(result)
end

Version data entries

11 entries across 11 versions & 1 rubygems

Version Path
amq-protocol-2.3.2 profiling/stackprof/body_framing_with_2k_payload.rb
amq-protocol-2.3.1 profiling/stackprof/body_framing_with_2k_payload.rb
amq-protocol-2.3.0 profiling/stackprof/body_framing_with_2k_payload.rb
amq-protocol-2.3.0.rc2 profiling/stackprof/body_framing_with_2k_payload.rb
amq-protocol-2.3.0.rc1 profiling/stackprof/body_framing_with_2k_payload.rb
amq-protocol-2.2.0 profiling/stackprof/body_framing_with_2k_payload.rb
amq-protocol-2.1.0 profiling/stackprof/body_framing_with_2k_payload.rb
amq-protocol-2.0.1 profiling/stackprof/body_framing_with_2k_payload.rb
amq-protocol-2.0.0 profiling/stackprof/body_framing_with_2k_payload.rb
amq-protocol-1.9.2 profiling/stackprof/body_framing_with_2k_payload.rb
amq-protocol-1.9.1 profiling/stackprof/body_framing_with_2k_payload.rb