letter_opener_web 1.0.1 → 1.0.2
Sign up to get free protection for your applications and to get access to all the features.
- data/.travis.yml +5 -0
- data/Gemfile +6 -5
- data/README.md +3 -1
- data/app/controllers/letter_opener_web/letters_controller.rb +3 -3
- data/app/models/letter_opener_web/letter.rb +1 -1
- data/letter_opener_web.gemspec +1 -1
- data/lib/letter_opener_web/engine.rb +3 -0
- data/lib/letter_opener_web/version.rb +1 -1
- data/spec/controllers/letter_opener_web/letters_controller_spec.rb +11 -11
- data/spec/internal/config/routes.rb +3 -3
- data/spec/models/letter_opener_web/letter_spec.rb +5 -4
- metadata +8 -8
- data/app/helpers/letter_opener_web/application_helper.rb +0 -4
data/.travis.yml
ADDED
data/Gemfile
CHANGED
@@ -5,8 +5,9 @@ source "http://rubygems.org"
|
|
5
5
|
# development dependencies will be added by default to the :development group.
|
6
6
|
gemspec
|
7
7
|
|
8
|
-
|
9
|
-
|
10
|
-
gem 'rb-inotify', '~> 0.8.8'
|
11
|
-
gem 'guard'
|
12
|
-
gem 'guard-rspec'
|
8
|
+
group :devonly do
|
9
|
+
gem 'debugger'
|
10
|
+
gem 'rb-inotify', '~> 0.8.8'
|
11
|
+
gem 'guard'
|
12
|
+
gem 'guard-rspec'
|
13
|
+
end
|
data/README.md
CHANGED
@@ -1,5 +1,7 @@
|
|
1
1
|
# LetterOpenerWeb
|
2
2
|
|
3
|
+
[![Build Status](https://travis-ci.org/fgrehm/letter_opener_web.png?branch=master)](https://travis-ci.org/fgrehm/letter_opener_web)
|
4
|
+
|
3
5
|
Gives [letter_opener](https://github.com/ryanb/letter_opener) an interface for
|
4
6
|
browsing sent emails.
|
5
7
|
|
@@ -7,7 +9,7 @@ browsing sent emails.
|
|
7
9
|
|
8
10
|
First add the gem to your development environment and run the `bundle` command to install it.
|
9
11
|
|
10
|
-
gem 'letter_opener_web', '1.0
|
12
|
+
gem 'letter_opener_web', '~> 1.0', :group => :development
|
11
13
|
|
12
14
|
## Usage
|
13
15
|
|
@@ -9,9 +9,9 @@ module LetterOpenerWeb
|
|
9
9
|
def show
|
10
10
|
letter = Letter.find(params[:id])
|
11
11
|
text = letter.send("#{params[:style]}_text").
|
12
|
-
gsub(/"plain\.html"/, "\"#{letter_path(id
|
13
|
-
gsub(/"rich\.html"/, "\"#{letter_path(id
|
14
|
-
render text
|
12
|
+
gsub(/"plain\.html"/, "\"#{letter_path(:id => letter.id, :style => 'plain')}\"").
|
13
|
+
gsub(/"rich\.html"/, "\"#{letter_path(:id => letter.id, :style => 'rich')}\"")
|
14
|
+
render :text => text
|
15
15
|
end
|
16
16
|
|
17
17
|
def attachment
|
data/letter_opener_web.gemspec
CHANGED
@@ -20,7 +20,7 @@ Gem::Specification.new do |gem|
|
|
20
20
|
gem.add_dependency 'rails', '~> 3.2'
|
21
21
|
gem.add_dependency 'letter_opener', '~> 1.0'
|
22
22
|
|
23
|
-
gem.add_development_dependency 'rspec-rails'
|
23
|
+
gem.add_development_dependency 'rspec-rails', '~> 2.0'
|
24
24
|
gem.add_development_dependency 'shoulda-matchers'
|
25
25
|
gem.add_development_dependency 'combustion', '~> 0.3.1'
|
26
26
|
end
|
@@ -3,7 +3,7 @@ require 'spec_helper'
|
|
3
3
|
describe LetterOpenerWeb::LettersController do
|
4
4
|
describe 'GET index' do
|
5
5
|
before do
|
6
|
-
LetterOpenerWeb::Letter.stub(search
|
6
|
+
LetterOpenerWeb::Letter.stub(:search => :all_letters)
|
7
7
|
get :index
|
8
8
|
end
|
9
9
|
it { should assign_to(:letters).with(:all_letters) }
|
@@ -14,14 +14,14 @@ describe LetterOpenerWeb::LettersController do
|
|
14
14
|
# TODO: Move these to fixture files
|
15
15
|
let(:rich_text) { "rich text href=\"plain.html\"" }
|
16
16
|
let(:plain_text) { "plain text href=\"rich.html\"" }
|
17
|
-
let(:letter) { mock(:letter, rich_text
|
17
|
+
let(:letter) { mock(:letter, :rich_text => rich_text, :plain_text => plain_text, :id => id) }
|
18
18
|
|
19
19
|
before do
|
20
|
-
LetterOpenerWeb::Letter.stub(find
|
20
|
+
LetterOpenerWeb::Letter.stub(:find => letter)
|
21
21
|
end
|
22
22
|
|
23
23
|
context 'rich text version' do
|
24
|
-
before { get :show, id
|
24
|
+
before { get :show, :id => id, :style => 'rich' }
|
25
25
|
|
26
26
|
it "returns letter's rich text contents" do
|
27
27
|
response.body.should =~ /^rich text/
|
@@ -29,12 +29,12 @@ describe LetterOpenerWeb::LettersController do
|
|
29
29
|
|
30
30
|
it 'fixes plain text link' do
|
31
31
|
response.body.should_not =~ /href="plain.html"/
|
32
|
-
response.body.should =~ /href="#{Regexp.escape letter_path(id
|
32
|
+
response.body.should =~ /href="#{Regexp.escape letter_path(:id => letter.id, :style => 'plain')}"/
|
33
33
|
end
|
34
34
|
end
|
35
35
|
|
36
36
|
context 'plain text version' do
|
37
|
-
before { get :show, id
|
37
|
+
before { get :show, :id => id, :style => 'plain' }
|
38
38
|
|
39
39
|
it "returns letter's plain text contents" do
|
40
40
|
response.body.should =~ /^plain text/
|
@@ -42,7 +42,7 @@ describe LetterOpenerWeb::LettersController do
|
|
42
42
|
|
43
43
|
it 'fixes rich text link' do
|
44
44
|
response.body.should_not =~ /href="rich.html"/
|
45
|
-
response.body.should =~ /href="#{Regexp.escape letter_path(id
|
45
|
+
response.body.should =~ /href="#{Regexp.escape letter_path(:id => letter.id, :style => 'rich')}"/
|
46
46
|
end
|
47
47
|
end
|
48
48
|
end
|
@@ -51,21 +51,21 @@ describe LetterOpenerWeb::LettersController do
|
|
51
51
|
let(:id) { 'an-id' }
|
52
52
|
let(:attachment_path) { "path/to/attachment" }
|
53
53
|
let(:file_name) { 'image.jpg' }
|
54
|
-
let(:letter) { mock(:letter, attachments
|
54
|
+
let(:letter) { mock(:letter, :attachments => { file_name => attachment_path}, :id => id) }
|
55
55
|
|
56
56
|
before do
|
57
|
-
LetterOpenerWeb::Letter.stub(find
|
57
|
+
LetterOpenerWeb::Letter.stub(:find => letter)
|
58
58
|
controller.stub(:send_file) { controller.render :nothing => true }
|
59
59
|
end
|
60
60
|
|
61
61
|
it 'sends the file as an inline attachment' do
|
62
62
|
controller.should_receive(:send_file).with(attachment_path, :filename => file_name, :disposition => 'inline')
|
63
|
-
get :attachment, id
|
63
|
+
get :attachment, :id => id, :file => file_name.gsub(/\.\w+/, ''), :format => File.extname(file_name)[1..-1]
|
64
64
|
response.status.should == 200
|
65
65
|
end
|
66
66
|
|
67
67
|
it "throws a 404 if attachment file can't be found" do
|
68
|
-
get :attachment, id
|
68
|
+
get :attachment, :id => id, :file => 'unknown', :format => 'woot'
|
69
69
|
response.status.should == 404
|
70
70
|
end
|
71
71
|
end
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Rails.application.routes.draw do
|
2
2
|
delete 'clear' => 'letter_opener_web/letters#clear'
|
3
|
-
get '/' => 'letter_opener_web/letters#index', as
|
4
|
-
get ':id(/:style)' => 'letter_opener_web/letters#show', as
|
5
|
-
get ':id/attachments/:file' => 'letter_opener_web/letters#attachment'
|
3
|
+
get '/' => 'letter_opener_web/letters#index', :as => :letters
|
4
|
+
get ':id(/:style)' => 'letter_opener_web/letters#show', :as => :letter
|
5
|
+
get ':id/attachments/:file' => 'letter_opener_web/letters#attachment'
|
6
6
|
end
|
@@ -34,25 +34,26 @@ MAIL
|
|
34
34
|
|
35
35
|
describe 'rich text version' do
|
36
36
|
let(:id) { '1111_1111' }
|
37
|
-
subject { described_class.new(id
|
37
|
+
subject { described_class.new(:id => id).rich_text }
|
38
38
|
|
39
39
|
it { should =~ /Rich text for 1111_1111/ }
|
40
40
|
|
41
41
|
it 'changes links to show up on a new window' do
|
42
|
+
return pending 'This spec if failing randomly on ruby 1.8' if RUBY_VERSION =~ /^1.8/
|
42
43
|
subject.should include("<a href='a-link.html' target='_blank'>\n <img src='an-image.jpg'/>\n Link text\n</a>")
|
43
44
|
end
|
44
45
|
end
|
45
46
|
|
46
47
|
describe 'plain text version' do
|
47
48
|
let(:id) { '2222_2222' }
|
48
|
-
subject { described_class.new(id
|
49
|
+
subject { described_class.new(:id => id).plain_text }
|
49
50
|
|
50
51
|
it { should =~ /Plain text for 2222_2222/ }
|
51
52
|
end
|
52
53
|
|
53
54
|
describe 'default style' do
|
54
55
|
let(:id) { '2222_2222' }
|
55
|
-
subject { described_class.new(id
|
56
|
+
subject { described_class.new(:id => id) }
|
56
57
|
|
57
58
|
it 'returns rich if rich text version is present' do
|
58
59
|
subject.default_style.should == 'rich'
|
@@ -69,7 +70,7 @@ MAIL
|
|
69
70
|
let(:attachments_dir) { "#{location}/#{id}/attachments" }
|
70
71
|
let(:id) { '1111_1111' }
|
71
72
|
|
72
|
-
subject { described_class.new(id
|
73
|
+
subject { described_class.new(:id => id) }
|
73
74
|
|
74
75
|
before do
|
75
76
|
FileUtils.mkdir_p(attachments_dir)
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: letter_opener_web
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.0.
|
4
|
+
version: 1.0.2
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -48,15 +48,15 @@ dependencies:
|
|
48
48
|
name: rspec-rails
|
49
49
|
version_requirements: !ruby/object:Gem::Requirement
|
50
50
|
requirements:
|
51
|
-
- -
|
51
|
+
- - ~>
|
52
52
|
- !ruby/object:Gem::Version
|
53
|
-
version: '0'
|
53
|
+
version: '2.0'
|
54
54
|
none: false
|
55
55
|
requirement: !ruby/object:Gem::Requirement
|
56
56
|
requirements:
|
57
|
-
- -
|
57
|
+
- - ~>
|
58
58
|
- !ruby/object:Gem::Version
|
59
|
-
version: '0'
|
59
|
+
version: '2.0'
|
60
60
|
none: false
|
61
61
|
type: :development
|
62
62
|
- !ruby/object:Gem::Dependency
|
@@ -100,6 +100,7 @@ extra_rdoc_files: []
|
|
100
100
|
files:
|
101
101
|
- .gitignore
|
102
102
|
- .rspec
|
103
|
+
- .travis.yml
|
103
104
|
- Gemfile
|
104
105
|
- Guardfile
|
105
106
|
- LICENSE.txt
|
@@ -109,7 +110,6 @@ files:
|
|
109
110
|
- app/assets/stylesheets/letter_opener_web/application.css.erb
|
110
111
|
- app/controllers/letter_opener_web/application_controller.rb
|
111
112
|
- app/controllers/letter_opener_web/letters_controller.rb
|
112
|
-
- app/helpers/letter_opener_web/application_helper.rb
|
113
113
|
- app/models/letter_opener_web/letter.rb
|
114
114
|
- app/views/layouts/letter_opener_web/application.html.erb
|
115
115
|
- app/views/letter_opener_web/letters/index.html.erb
|
@@ -155,7 +155,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
155
155
|
version: '0'
|
156
156
|
segments:
|
157
157
|
- 0
|
158
|
-
hash: -
|
158
|
+
hash: -2596290624536593694
|
159
159
|
none: false
|
160
160
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
161
161
|
requirements:
|
@@ -164,7 +164,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
164
164
|
version: '0'
|
165
165
|
segments:
|
166
166
|
- 0
|
167
|
-
hash: -
|
167
|
+
hash: -2596290624536593694
|
168
168
|
none: false
|
169
169
|
requirements: []
|
170
170
|
rubyforge_project:
|