Class: Rack::Lint

Inherits:
Object
  • Object
show all
Defined in:
lib/rack/lint.rb

Overview

Rack::Lint validates your application and the requests and responses according to the Rack spec.

Defined Under Namespace

Classes: LintError, Wrapper

Constant Summary collapse

REQUEST_PATH_ORIGIN_FORM =
/\A\/[^#]*\z/
REQUEST_PATH_ABSOLUTE_FORM =
/\A#{Utils::URI_PARSER.make_regexp}\z/
REQUEST_PATH_AUTHORITY_FORM =
/\A[^\/:]+:\d+\z/
REQUEST_PATH_ASTERISK_FORM =
'*'

Instance Method Summary collapse

Constructor Details

#initialize(app) ⇒ Lint

Returns a new instance of Lint.



19
20
21
# File 'lib/rack/lint.rb', line 19

def initialize(app)
  @app = app
end

Instance Method Details

#call(env = nil) ⇒ Object

AUTHORS: n.b. The trailing whitespace between paragraphs is important and should not be removed. The whitespace creates paragraphs in the RDoc output.

This specification aims to formalize the Rack protocol. You can (and should) use Rack::Lint to enforce it.

When you develop middleware, be sure to add a Lint before and after to catch all mistakes.

Rack applications

A Rack application is a Ruby object (not a class) that responds to call.



40
41
42
# File 'lib/rack/lint.rb', line 40

def call(env = nil)
  Wrapper.new(@app, env).response
end