public
Description: Adds a helper method to your controller and integration tests that automatically opens the response body in the default browser.
Homepage: http://adeptware.com
Clone URL: git://github.com/adeptware/lindo.git
Click here to lend your support to: lindo and make a donation at www.pledgie.com !
lindo / README
100644 82 lines (55 sloc) 2.201 kb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
= lindo
 
Enables rendering of the body of an HTTP response from inside controller and
integration tests. This makes it easy to diagnose problems when building
assert_select statements or just sanity check the output of the test.
 
== Installation
  
Install the gem directly:
 
  sudo gem install adeptware-lindo --source=http://gems.github.com
 
Or install the gem in your Rails project:
 
  script/plugin install git://github.com/adeptware/lindo.git
 
Then require lindo in your test_helper.rb or spec_helper.rb file:
 
  require 'lindo'
 
You may also have to extend the Lindo module from your test or spec
helper if you use sessions in your integration tests:
 
  session.extend Lindo
 
== Usage
 
Insert the vr method in your functional test immediately after an HTTP
request has been sent:
 
  def test_new
    post :new
    vr
    assert_select "div[id=header]"
  end
 
vr attempts to open the response body in the default web browser. If you want
to open the raw HTML in the default text editor instead, simply pass the :html
symbol to the method:
 
  def test_new
    post :new
    vr(:html)
    ...
  end
 
By default, vr looks for an instance variable named @response and calls the #body
method on it. If your page body is stored in a different variable, such as when
testing a mailer, you can pass the raw HTML directly to vr and it will do the
right thing:
 
  def test_mailer
    mail = Mailer.create_notification
    vr(mail.body)
    ...
  end
 
Note that to use the default web view, your Rails application must be running
locally on port 3000. This will ensure that the page renders correctly with the
appropriate images and stylesheets. The server doesn't need to be running if
you use the HTML-only view.
 
== Compatibility
 
lindo requires OS X. Support for Windows is planned.
 
test/spec and test/unit work fine with lindo. RSpec, however, tests views
independently of controllers, so lindo won't work with it.
 
== Running Unit Tests
 
Use the rake command to run the unit tests for the plugin. The tests require
that the Mocha gem be installed locally:
 
  sudo gem install mocha
 
== Resources
 
Repository: http://github.com/adeptware/lindo/
Blog: http://adeptware.com/blog
Author: Adeptware, Inc.