Sha256: 97d32772403bcc90f26f246b22dbc4b07971bb46d135e8f9b0f0ea4f794f22a8

Contents?: true

Size: 1.77 KB

Versions: 5

Compression:

Stored size: 1.77 KB

Contents

Most Ruby web API libraries use <tt>Net::HTTP</tt> (because it's ubiquitous),
but I want to use them in my non-blocking EventMachine-based applications, and
I don't want Net::HTTP to block. I therefore wrote this.

Using the magic of Ruby 1.9's Fibers, we monkeypatch <tt>Net::HTTP</tt> to use
the faster, nonblocking <tt>[em-http-request][1]</tt> under the hood. Obviously this
will only work from inside the [EventMachine][2] event loop, and from within a spawned
fiber:

    require 'em-net-http'

    EM.run do
      Fiber.new do
        Net::HTTP.start('encrypted.google.com', :use_ssl=>true) do |http|
          res = http.get('/search?q=james')
          puts res.body
        end
        EM.stop_event_loop
      end.resume
    end
    
The above will run without blocking your carefully-tuned nonblocking webapp.

There are a few tests (taking advantage of the very useful [Mimic][6] gem)
that assert that responses are identical to those created by <tt>Net::HTTP</tt>.
These are by no means exhaustive; if you're using <tt>Net::HTTP</tt> in some other way
and the <tt>em-net-http</tt>'s behaviour is not what you expect, do send me a failing test
case.

Currently tested with Ruby (MRI) 1.9.1 and 1.9.2.

### Caveat

The <tt>Net::HTTP</tt> API is a many-headed hydra -- I haven't patched much of it.
Your mileage may therefore vary. Please feed me patches, pull requests and bug reports!

### Thanks

 * [Luke Redpath][7], for [Mimic][6].
 * [Mathieu Ravaux][8], for adding streaming and buffering support.

[1]: http://github.com/igrigorik/em-http-request
[2]: http://rubyeventmachine.com/
[3]: http://rightaws.rubyforge.org/
[4]: http://github.com/mwunsch/weary
[5]: http://github.com/mwunsch/tumblr
[6]: http://github.com/lukeredpath/mimic
[7]: http://lukeredpath.co.uk/
[8]: http://mathieuravaux.com/

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
em-net-http-0.3.6 README.md
em-net-http-0.3.5 README.md
em-net-http-0.3.2 README.md
em-net-http-0.3.1 README.md
em-net-http-0.3.0 README.md