Sha256: 3706203983c8ebe5b58322c1bb976561cc4294528a160c57ca7392745de41d09

Contents?: true

Size: 1.1 KB

Versions: 1

Compression:

Stored size: 1.1 KB

Contents

require 'fileutils'

module StackProf
  class Middleware
    def initialize(app, options = {})
      @app = app
      @options = options
      @num_reqs = options[:save_every] || nil
      Middleware.mode = options[:mode] || :cpu
      Middleware.interval = options[:interval] || 1000
      Middleware.enabled = options[:enabled]
      at_exit{ Middleware.save? } if options[:save_at_exit]
    end

    def call(env)
      StackProf.start(mode: Middleware.mode, interval: Middleware.interval) if Middleware.enabled?
      @app.call(env)
    ensure
      if Middleware.enabled?
        StackProf.stop
        if @num_reqs && (@num_reqs-=1) == 0
          @num_reqs = @options[:save_every]
          Middleware.save
        end
      end
    end

    class << self
      attr_accessor :enabled, :mode, :interval
      alias enabled? enabled

      def save
        if results = StackProf.results
          FileUtils.mkdir_p('tmp')
          File.open("tmp/stackprof-#{results[:mode]}-#{Process.pid}-#{Time.now.to_i}.dump", 'wb') do |f|
            f.write Marshal.dump(results)
          end
        end
      end
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
stackprof-0.2.1 lib/stackprof/middleware.rb