ryansch-paperclip 2.3.10

Sign up to get free protection for your applications and to get access to all the features.
Files changed (63) hide show
  1. data/LICENSE +26 -0
  2. data/README.md +239 -0
  3. data/Rakefile +80 -0
  4. data/generators/paperclip/USAGE +5 -0
  5. data/generators/paperclip/paperclip_generator.rb +27 -0
  6. data/generators/paperclip/templates/paperclip_migration.rb.erb +19 -0
  7. data/init.rb +1 -0
  8. data/lib/generators/paperclip/USAGE +8 -0
  9. data/lib/generators/paperclip/paperclip_generator.rb +31 -0
  10. data/lib/generators/paperclip/templates/paperclip_migration.rb.erb +19 -0
  11. data/lib/paperclip.rb +384 -0
  12. data/lib/paperclip/attachment.rb +378 -0
  13. data/lib/paperclip/callback_compatability.rb +61 -0
  14. data/lib/paperclip/command_line.rb +86 -0
  15. data/lib/paperclip/geometry.rb +115 -0
  16. data/lib/paperclip/interpolations.rb +130 -0
  17. data/lib/paperclip/iostream.rb +45 -0
  18. data/lib/paperclip/matchers.rb +33 -0
  19. data/lib/paperclip/matchers/have_attached_file_matcher.rb +57 -0
  20. data/lib/paperclip/matchers/validate_attachment_content_type_matcher.rb +75 -0
  21. data/lib/paperclip/matchers/validate_attachment_presence_matcher.rb +54 -0
  22. data/lib/paperclip/matchers/validate_attachment_size_matcher.rb +95 -0
  23. data/lib/paperclip/processor.rb +58 -0
  24. data/lib/paperclip/railtie.rb +24 -0
  25. data/lib/paperclip/storage.rb +3 -0
  26. data/lib/paperclip/storage/filesystem.rb +74 -0
  27. data/lib/paperclip/storage/fog.rb +98 -0
  28. data/lib/paperclip/storage/s3.rb +192 -0
  29. data/lib/paperclip/style.rb +91 -0
  30. data/lib/paperclip/thumbnail.rb +79 -0
  31. data/lib/paperclip/upfile.rb +55 -0
  32. data/lib/paperclip/version.rb +3 -0
  33. data/lib/tasks/paperclip.rake +72 -0
  34. data/rails/init.rb +2 -0
  35. data/shoulda_macros/paperclip.rb +118 -0
  36. data/test/attachment_test.rb +939 -0
  37. data/test/command_line_test.rb +138 -0
  38. data/test/database.yml +4 -0
  39. data/test/fixtures/12k.png +0 -0
  40. data/test/fixtures/50x50.png +0 -0
  41. data/test/fixtures/5k.png +0 -0
  42. data/test/fixtures/bad.png +1 -0
  43. data/test/fixtures/s3.yml +8 -0
  44. data/test/fixtures/text.txt +0 -0
  45. data/test/fixtures/twopage.pdf +0 -0
  46. data/test/fixtures/uppercase.PNG +0 -0
  47. data/test/fog_test.rb +107 -0
  48. data/test/geometry_test.rb +177 -0
  49. data/test/helper.rb +146 -0
  50. data/test/integration_test.rb +570 -0
  51. data/test/interpolations_test.rb +143 -0
  52. data/test/iostream_test.rb +71 -0
  53. data/test/matchers/have_attached_file_matcher_test.rb +24 -0
  54. data/test/matchers/validate_attachment_content_type_matcher_test.rb +47 -0
  55. data/test/matchers/validate_attachment_presence_matcher_test.rb +26 -0
  56. data/test/matchers/validate_attachment_size_matcher_test.rb +51 -0
  57. data/test/paperclip_test.rb +306 -0
  58. data/test/processor_test.rb +10 -0
  59. data/test/storage_test.rb +416 -0
  60. data/test/style_test.rb +163 -0
  61. data/test/thumbnail_test.rb +227 -0
  62. data/test/upfile_test.rb +36 -0
  63. metadata +233 -0
@@ -0,0 +1,138 @@
1
+ require './test/helper'
2
+
3
+ class CommandLineTest < Test::Unit::TestCase
4
+ def setup
5
+ Paperclip::CommandLine.path = nil
6
+ File.stubs(:exist?).with("/dev/null").returns(true)
7
+ end
8
+
9
+ should "allow colons in parameters" do
10
+ cmd = Paperclip::CommandLine.new("convert", "'a.jpg' -resize 175x220> -size 175x220 xc:black +swap -gravity center -composite 'b.jpg'", :swallow_stderr => false)
11
+ assert_equal "convert 'a.jpg' -resize 175x220> -size 175x220 xc:black +swap -gravity center -composite 'b.jpg'", cmd.command
12
+ end
13
+
14
+ should "take a command and parameters and produce a shell command for bash" do
15
+ cmd = Paperclip::CommandLine.new("convert", "a.jpg b.png", :swallow_stderr => false)
16
+ assert_equal "convert a.jpg b.png", cmd.command
17
+ end
18
+
19
+ should "be able to set a path and produce commands with that path" do
20
+ Paperclip::CommandLine.path = "/opt/bin"
21
+ cmd = Paperclip::CommandLine.new("convert", "a.jpg b.png", :swallow_stderr => false)
22
+ assert_equal "/opt/bin/convert a.jpg b.png", cmd.command
23
+ end
24
+
25
+ should "be able to interpolate quoted variables into the parameters" do
26
+ cmd = Paperclip::CommandLine.new("convert",
27
+ ":one :{two}",
28
+ :one => "a.jpg",
29
+ :two => "b.png",
30
+ :swallow_stderr => false)
31
+ assert_equal "convert 'a.jpg' 'b.png'", cmd.command
32
+ end
33
+
34
+ should "quote command line options differently if we're on windows" do
35
+ File.stubs(:exist?).with("/dev/null").returns(false)
36
+ cmd = Paperclip::CommandLine.new("convert",
37
+ ":one :{two}",
38
+ :one => "a.jpg",
39
+ :two => "b.png",
40
+ :swallow_stderr => false)
41
+ assert_equal 'convert "a.jpg" "b.png"', cmd.command
42
+ end
43
+
44
+ should "be able to quote and interpolate dangerous variables" do
45
+ cmd = Paperclip::CommandLine.new("convert",
46
+ ":one :two",
47
+ :one => "`rm -rf`.jpg",
48
+ :two => "ha'ha.png",
49
+ :swallow_stderr => false)
50
+ assert_equal "convert '`rm -rf`.jpg' 'ha'\\''ha.png'", cmd.command
51
+ end
52
+
53
+ should "be able to quote and interpolate dangerous variables even on windows" do
54
+ File.stubs(:exist?).with("/dev/null").returns(false)
55
+ cmd = Paperclip::CommandLine.new("convert",
56
+ ":one :two",
57
+ :one => "`rm -rf`.jpg",
58
+ :two => "ha'ha.png",
59
+ :swallow_stderr => false)
60
+ assert_equal %{convert "`rm -rf`.jpg" "ha'ha.png"}, cmd.command
61
+ end
62
+
63
+ should "add redirection to get rid of stderr in bash" do
64
+ File.stubs(:exist?).with("/dev/null").returns(true)
65
+ cmd = Paperclip::CommandLine.new("convert",
66
+ "a.jpg b.png",
67
+ :swallow_stderr => true)
68
+
69
+ assert_equal "convert a.jpg b.png 2>/dev/null", cmd.command
70
+ end
71
+
72
+ should "add redirection to get rid of stderr in cmd.exe" do
73
+ File.stubs(:exist?).with("/dev/null").returns(false)
74
+ cmd = Paperclip::CommandLine.new("convert",
75
+ "a.jpg b.png",
76
+ :swallow_stderr => true)
77
+
78
+ assert_equal "convert a.jpg b.png 2>NUL", cmd.command
79
+ end
80
+
81
+ should "raise if trying to interpolate :swallow_stderr or :expected_outcodes" do
82
+ cmd = Paperclip::CommandLine.new("convert",
83
+ ":swallow_stderr :expected_outcodes",
84
+ :swallow_stderr => false,
85
+ :expected_outcodes => [0, 1])
86
+ assert_raise(Paperclip::PaperclipCommandLineError) do
87
+ cmd.command
88
+ end
89
+ end
90
+
91
+ should "run the #command it's given and return the output" do
92
+ cmd = Paperclip::CommandLine.new("convert", "a.jpg b.png", :swallow_stderr => false)
93
+ cmd.class.stubs(:"`").with("convert a.jpg b.png").returns(:correct_value)
94
+ with_exitstatus_returning(0) do
95
+ assert_equal :correct_value, cmd.run
96
+ end
97
+ end
98
+
99
+ should "raise a PaperclipCommandLineError if the result code isn't expected" do
100
+ cmd = Paperclip::CommandLine.new("convert", "a.jpg b.png", :swallow_stderr => false)
101
+ cmd.class.stubs(:"`").with("convert a.jpg b.png").returns(:correct_value)
102
+ with_exitstatus_returning(1) do
103
+ assert_raises(Paperclip::PaperclipCommandLineError) do
104
+ cmd.run
105
+ end
106
+ end
107
+ end
108
+
109
+ should "not raise a PaperclipCommandLineError if the result code is expected" do
110
+ cmd = Paperclip::CommandLine.new("convert",
111
+ "a.jpg b.png",
112
+ :expected_outcodes => [0, 1],
113
+ :swallow_stderr => false)
114
+ cmd.class.stubs(:"`").with("convert a.jpg b.png").returns(:correct_value)
115
+ with_exitstatus_returning(1) do
116
+ assert_nothing_raised do
117
+ cmd.run
118
+ end
119
+ end
120
+ end
121
+
122
+ should "log the command" do
123
+ cmd = Paperclip::CommandLine.new("convert", "a.jpg b.png", :swallow_stderr => false)
124
+ cmd.class.stubs(:'`')
125
+ Paperclip.expects(:log).with("convert a.jpg b.png")
126
+ cmd.run
127
+ end
128
+
129
+ should "detect that the system is unix or windows based on presence of /dev/null" do
130
+ File.stubs(:exist?).returns(true)
131
+ assert Paperclip::CommandLine.unix?
132
+ end
133
+
134
+ should "detect that the system is not unix or windows based on absence of /dev/null" do
135
+ File.stubs(:exist?).returns(false)
136
+ assert ! Paperclip::CommandLine.unix?
137
+ end
138
+ end
data/test/database.yml ADDED
@@ -0,0 +1,4 @@
1
+ test:
2
+ adapter: sqlite3
3
+ database: ":memory:"
4
+
Binary file
Binary file
Binary file
@@ -0,0 +1 @@
1
+ This is not an image.
@@ -0,0 +1,8 @@
1
+ development:
2
+ key: 54321
3
+ production:
4
+ key: 12345
5
+ test:
6
+ bucket: <%= ENV['S3_BUCKET'] %>
7
+ access_key_id: <%= ENV['S3_KEY'] %>
8
+ secret_access_key: <%= ENV['S3_SECRET'] %>
File without changes
Binary file
Binary file
data/test/fog_test.rb ADDED
@@ -0,0 +1,107 @@
1
+ require './test/helper'
2
+ require 'fog'
3
+
4
+ Fog.mock!
5
+
6
+ class FogTest < Test::Unit::TestCase
7
+ context "" do
8
+
9
+ setup do
10
+ @fog_directory = 'papercliptests'
11
+
12
+ @credentials = {
13
+ :provider => 'AWS',
14
+ :aws_access_key_id => 'ID',
15
+ :aws_secret_access_key => 'SECRET'
16
+ }
17
+
18
+ @connection = Fog::Storage.new(@credentials)
19
+
20
+ rebuild_model(
21
+ :fog_directory => @fog_directory,
22
+ :fog_credentials => @credentials,
23
+ :fog_host => nil,
24
+ :fog_public => true,
25
+ :path => ":attachment/:basename.:extension",
26
+ :storage => :fog
27
+ )
28
+ end
29
+
30
+ should "be extended by the Fog module" do
31
+ assert Dummy.new.avatar.is_a?(Paperclip::Storage::Fog)
32
+ end
33
+
34
+ context "when assigned" do
35
+ setup do
36
+ @file = File.new(File.join(File.dirname(__FILE__), 'fixtures', '5k.png'), 'rb')
37
+ @dummy = Dummy.new
38
+ @dummy.avatar = @file
39
+ end
40
+
41
+ teardown do
42
+ @file.close
43
+ directory = @connection.directories.new(:key => @fog_directory)
44
+ directory.files.each {|file| file.destroy}
45
+ directory.destroy
46
+ end
47
+
48
+ context "without a bucket" do
49
+ should "succeed" do
50
+ assert @dummy.save
51
+ end
52
+ end
53
+
54
+ context "with a bucket" do
55
+ setup do
56
+ @connection.directories.create(:key => @fog_directory)
57
+ end
58
+
59
+ should "succeed" do
60
+ assert @dummy.save
61
+ end
62
+ end
63
+
64
+ context "without a fog_host" do
65
+ setup do
66
+ rebuild_model(
67
+ :fog_directory => @fog_directory,
68
+ :fog_credentials => @credentials,
69
+ :fog_host => nil,
70
+ :fog_public => true,
71
+ :path => ":attachment/:basename.:extension",
72
+ :storage => :fog
73
+ )
74
+ @dummy = Dummy.new
75
+ @dummy.avatar = StringIO.new('.')
76
+ @dummy.save
77
+ end
78
+
79
+ should "provide a public url" do
80
+ assert !@dummy.avatar.url.nil?
81
+ end
82
+ end
83
+
84
+ context "with a fog_host" do
85
+ setup do
86
+ rebuild_model(
87
+ :fog_directory => @fog_directory,
88
+ :fog_credentials => @credentials,
89
+ :fog_host => 'http://example.com',
90
+ :fog_public => true,
91
+ :path => ":attachment/:basename.:extension",
92
+ :storage => :fog
93
+ )
94
+ @dummy = Dummy.new
95
+ @dummy.avatar = StringIO.new('.')
96
+ @dummy.save
97
+ end
98
+
99
+ should "provide a public url" do
100
+ assert @dummy.avatar.url =~ /^http:\/\/example\.com\/avatars\/stringio\.txt\?\d*$/
101
+ end
102
+ end
103
+
104
+ end
105
+
106
+ end
107
+ end
@@ -0,0 +1,177 @@
1
+ require './test/helper'
2
+
3
+ class GeometryTest < Test::Unit::TestCase
4
+ context "Paperclip::Geometry" do
5
+ should "correctly report its given dimensions" do
6
+ assert @geo = Paperclip::Geometry.new(1024, 768)
7
+ assert_equal 1024, @geo.width
8
+ assert_equal 768, @geo.height
9
+ end
10
+
11
+ should "set height to 0 if height dimension is missing" do
12
+ assert @geo = Paperclip::Geometry.new(1024)
13
+ assert_equal 1024, @geo.width
14
+ assert_equal 0, @geo.height
15
+ end
16
+
17
+ should "set width to 0 if width dimension is missing" do
18
+ assert @geo = Paperclip::Geometry.new(nil, 768)
19
+ assert_equal 0, @geo.width
20
+ assert_equal 768, @geo.height
21
+ end
22
+
23
+ should "be generated from a WxH-formatted string" do
24
+ assert @geo = Paperclip::Geometry.parse("800x600")
25
+ assert_equal 800, @geo.width
26
+ assert_equal 600, @geo.height
27
+ end
28
+
29
+ should "be generated from a xH-formatted string" do
30
+ assert @geo = Paperclip::Geometry.parse("x600")
31
+ assert_equal 0, @geo.width
32
+ assert_equal 600, @geo.height
33
+ end
34
+
35
+ should "be generated from a Wx-formatted string" do
36
+ assert @geo = Paperclip::Geometry.parse("800x")
37
+ assert_equal 800, @geo.width
38
+ assert_equal 0, @geo.height
39
+ end
40
+
41
+ should "be generated from a W-formatted string" do
42
+ assert @geo = Paperclip::Geometry.parse("800")
43
+ assert_equal 800, @geo.width
44
+ assert_equal 0, @geo.height
45
+ end
46
+
47
+ should "ensure the modifier is nil if not present" do
48
+ assert @geo = Paperclip::Geometry.parse("123x456")
49
+ assert_nil @geo.modifier
50
+ end
51
+
52
+ should "treat x and X the same in geometries" do
53
+ @lower = Paperclip::Geometry.parse("123x456")
54
+ @upper = Paperclip::Geometry.parse("123X456")
55
+ assert_equal 123, @lower.width
56
+ assert_equal 123, @upper.width
57
+ assert_equal 456, @lower.height
58
+ assert_equal 456, @upper.height
59
+ end
60
+
61
+ ['>', '<', '#', '@', '%', '^', '!', nil].each do |mod|
62
+ should "ensure the modifier #{mod.inspect} is preserved" do
63
+ assert @geo = Paperclip::Geometry.parse("123x456#{mod}")
64
+ assert_equal mod, @geo.modifier
65
+ assert_equal "123x456#{mod}", @geo.to_s
66
+ end
67
+ end
68
+
69
+ ['>', '<', '#', '@', '%', '^', '!', nil].each do |mod|
70
+ should "ensure the modifier #{mod.inspect} is preserved with no height" do
71
+ assert @geo = Paperclip::Geometry.parse("123x#{mod}")
72
+ assert_equal mod, @geo.modifier
73
+ assert_equal "123#{mod}", @geo.to_s
74
+ end
75
+ end
76
+
77
+ should "make sure the modifier gets passed during transformation_to" do
78
+ assert @src = Paperclip::Geometry.parse("123x456")
79
+ assert @dst = Paperclip::Geometry.parse("123x456>")
80
+ assert_equal ["123x456>", nil], @src.transformation_to(@dst)
81
+ end
82
+
83
+ should "generate correct ImageMagick formatting string for W-formatted string" do
84
+ assert @geo = Paperclip::Geometry.parse("800")
85
+ assert_equal "800", @geo.to_s
86
+ end
87
+
88
+ should "generate correct ImageMagick formatting string for Wx-formatted string" do
89
+ assert @geo = Paperclip::Geometry.parse("800x")
90
+ assert_equal "800", @geo.to_s
91
+ end
92
+
93
+ should "generate correct ImageMagick formatting string for xH-formatted string" do
94
+ assert @geo = Paperclip::Geometry.parse("x600")
95
+ assert_equal "x600", @geo.to_s
96
+ end
97
+
98
+ should "generate correct ImageMagick formatting string for WxH-formatted string" do
99
+ assert @geo = Paperclip::Geometry.parse("800x600")
100
+ assert_equal "800x600", @geo.to_s
101
+ end
102
+
103
+ should "be generated from a file" do
104
+ file = File.join(File.dirname(__FILE__), "fixtures", "5k.png")
105
+ file = File.new(file, 'rb')
106
+ assert_nothing_raised{ @geo = Paperclip::Geometry.from_file(file) }
107
+ assert @geo.height > 0
108
+ assert @geo.width > 0
109
+ end
110
+
111
+ should "be generated from a file path" do
112
+ file = File.join(File.dirname(__FILE__), "fixtures", "5k.png")
113
+ assert_nothing_raised{ @geo = Paperclip::Geometry.from_file(file) }
114
+ assert @geo.height > 0
115
+ assert @geo.width > 0
116
+ end
117
+
118
+ should "not generate from a bad file" do
119
+ file = "/home/This File Does Not Exist.omg"
120
+ assert_raise(Paperclip::NotIdentifiedByImageMagickError){ @geo = Paperclip::Geometry.from_file(file) }
121
+ end
122
+
123
+ [['vertical', 900, 1440, true, false, false, 1440, 900, 0.625],
124
+ ['horizontal', 1024, 768, false, true, false, 1024, 768, 1.3333],
125
+ ['square', 100, 100, false, false, true, 100, 100, 1]].each do |args|
126
+ context "performing calculations on a #{args[0]} viewport" do
127
+ setup do
128
+ @geo = Paperclip::Geometry.new(args[1], args[2])
129
+ end
130
+
131
+ should "#{args[3] ? "" : "not"} be vertical" do
132
+ assert_equal args[3], @geo.vertical?
133
+ end
134
+
135
+ should "#{args[4] ? "" : "not"} be horizontal" do
136
+ assert_equal args[4], @geo.horizontal?
137
+ end
138
+
139
+ should "#{args[5] ? "" : "not"} be square" do
140
+ assert_equal args[5], @geo.square?
141
+ end
142
+
143
+ should "report that #{args[6]} is the larger dimension" do
144
+ assert_equal args[6], @geo.larger
145
+ end
146
+
147
+ should "report that #{args[7]} is the smaller dimension" do
148
+ assert_equal args[7], @geo.smaller
149
+ end
150
+
151
+ should "have an aspect ratio of #{args[8]}" do
152
+ assert_in_delta args[8], @geo.aspect, 0.0001
153
+ end
154
+ end
155
+ end
156
+
157
+ [[ [1000, 100], [64, 64], "x64", "64x64+288+0" ],
158
+ [ [100, 1000], [50, 950], "x950", "50x950+22+0" ],
159
+ [ [100, 1000], [50, 25], "50x", "50x25+0+237" ]]. each do |args|
160
+ context "of #{args[0].inspect} and given a Geometry #{args[1].inspect} and sent transform_to" do
161
+ setup do
162
+ @geo = Paperclip::Geometry.new(*args[0])
163
+ @dst = Paperclip::Geometry.new(*args[1])
164
+ @scale, @crop = @geo.transformation_to @dst, true
165
+ end
166
+
167
+ should "be able to return the correct scaling transformation geometry #{args[2]}" do
168
+ assert_equal args[2], @scale
169
+ end
170
+
171
+ should "be able to return the correct crop transformation geometry #{args[3]}" do
172
+ assert_equal args[3], @crop
173
+ end
174
+ end
175
+ end
176
+ end
177
+ end