Sha256: 77b151948aa7ac4f06307783eb22cdb97f4d22dd663d1aba1a8ae2537fa90cc1

Contents?: true

Size: 1.93 KB

Versions: 3

Compression:

Stored size: 1.93 KB

Contents

require File.dirname(__FILE__) + '/../../spec_helper'

describe RequestLogAnalyzer::Source::LogParser, :merb do
  
  before(:each) do
    @log_parser = RequestLogAnalyzer::Source::LogParser.new(RequestLogAnalyzer::FileFormat.load(:merb))
  end
  
  it "should have a valid language definitions" do
    @log_parser.file_format.should be_valid
  end
  
  it "should parse a stream and find valid requests" do
    File.open(log_fixture(:merb), 'r') do |io|
      @log_parser.parse_io(io) do |request| 
        request.should be_kind_of(RequestLogAnalyzer::Request)
      end
    end
  end

  it "should find 11 completed requests" do
    @log_parser.should_receive(:handle_request).exactly(11).times
    @log_parser.parse_file(log_fixture(:merb))
  end
  
  it "should parse all details from the first request correctly" do
    request = nil
    @log_parser.parse_file(log_fixture(:merb)) { |found_request| request ||= found_request }
    
    request.should be_completed
    request[:controller].should == 'session'
    request[:action].should == 'destroy'    
    request[:method].should == 'delete'
    request[:params].should be_kind_of(Hash)      
    request[:timestamp].should == 20080829111023 # 'Fri Aug 29 11:10:23 +0200 2008'
    request[:dispatch_time].should == 0.243424
    request[:after_filters_time].should == 6.9e-05
    request[:before_filters_time].should == 0.213213
    request[:action_time].should == 0.241652

  end
  
  it "should parse a prefixed Merb file correctly" do
    request = nil
    @log_parser.parse_file(log_fixture(:merb_prefixed)) { |found_request| request ||= found_request }
    
    request.should be_completed
    request[:timestamp].should == 20090831183525
    request[:controller].should == 'home'
    request[:action].should == 'index'
    request[:dispatch_time].should == 0.012001
    request[:after_filters_time].should == 0.0
    request[:before_filters_time].should == 0.0
    request[:action_time].should == 0.012001
  end
end

Version data entries

3 entries across 3 versions & 2 rubygems

Version Path
wvanbergen-request-log-analyzer-1.2.5 spec/unit/file_format/merb_format_spec.rb
wvanbergen-request-log-analyzer-1.2.6 spec/unit/file_format/merb_format_spec.rb
request-log-analyzer-1.2.6 spec/unit/file_format/merb_format_spec.rb