whitby3001-paperclip-cloudfiles 2.3.8.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (61) hide show
  1. data/LICENSE +26 -0
  2. data/README.md +225 -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 +376 -0
  12. data/lib/paperclip/attachment.rb +415 -0
  13. data/lib/paperclip/callback_compatability.rb +61 -0
  14. data/lib/paperclip/command_line.rb +80 -0
  15. data/lib/paperclip/geometry.rb +115 -0
  16. data/lib/paperclip/interpolations.rb +114 -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/cloud_files.rb +138 -0
  27. data/lib/paperclip/storage/filesystem.rb +73 -0
  28. data/lib/paperclip/storage/s3.rb +192 -0
  29. data/lib/paperclip/style.rb +93 -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 +818 -0
  37. data/test/command_line_test.rb +133 -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/geometry_test.rb +177 -0
  47. data/test/helper.rb +149 -0
  48. data/test/integration_test.rb +498 -0
  49. data/test/interpolations_test.rb +127 -0
  50. data/test/iostream_test.rb +71 -0
  51. data/test/matchers/have_attached_file_matcher_test.rb +24 -0
  52. data/test/matchers/validate_attachment_content_type_matcher_test.rb +47 -0
  53. data/test/matchers/validate_attachment_presence_matcher_test.rb +26 -0
  54. data/test/matchers/validate_attachment_size_matcher_test.rb +51 -0
  55. data/test/paperclip_test.rb +292 -0
  56. data/test/processor_test.rb +10 -0
  57. data/test/storage_test.rb +605 -0
  58. data/test/style_test.rb +141 -0
  59. data/test/thumbnail_test.rb +227 -0
  60. data/test/upfile_test.rb +36 -0
  61. metadata +242 -0
@@ -0,0 +1,133 @@
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 "take a command and parameters and produce a shell command for bash" do
10
+ cmd = Paperclip::CommandLine.new("convert", "a.jpg b.png", :swallow_stderr => false)
11
+ assert_equal "convert a.jpg b.png", cmd.command
12
+ end
13
+
14
+ should "be able to set a path and produce commands with that path" do
15
+ Paperclip::CommandLine.path = "/opt/bin"
16
+ cmd = Paperclip::CommandLine.new("convert", "a.jpg b.png", :swallow_stderr => false)
17
+ assert_equal "/opt/bin/convert a.jpg b.png", cmd.command
18
+ end
19
+
20
+ should "be able to interpolate quoted variables into the parameters" do
21
+ cmd = Paperclip::CommandLine.new("convert",
22
+ ":one :{two}",
23
+ :one => "a.jpg",
24
+ :two => "b.png",
25
+ :swallow_stderr => false)
26
+ assert_equal "convert 'a.jpg' 'b.png'", cmd.command
27
+ end
28
+
29
+ should "quote command line options differently if we're on windows" do
30
+ File.stubs(:exist?).with("/dev/null").returns(false)
31
+ cmd = Paperclip::CommandLine.new("convert",
32
+ ":one :{two}",
33
+ :one => "a.jpg",
34
+ :two => "b.png",
35
+ :swallow_stderr => false)
36
+ assert_equal 'convert "a.jpg" "b.png"', cmd.command
37
+ end
38
+
39
+ should "be able to quote and interpolate dangerous variables" do
40
+ cmd = Paperclip::CommandLine.new("convert",
41
+ ":one :two",
42
+ :one => "`rm -rf`.jpg",
43
+ :two => "ha'ha.png",
44
+ :swallow_stderr => false)
45
+ assert_equal "convert '`rm -rf`.jpg' 'ha'\\''ha.png'", cmd.command
46
+ end
47
+
48
+ should "be able to quote and interpolate dangerous variables even on windows" do
49
+ File.stubs(:exist?).with("/dev/null").returns(false)
50
+ cmd = Paperclip::CommandLine.new("convert",
51
+ ":one :two",
52
+ :one => "`rm -rf`.jpg",
53
+ :two => "ha'ha.png",
54
+ :swallow_stderr => false)
55
+ assert_equal %{convert "`rm -rf`.jpg" "ha'ha.png"}, cmd.command
56
+ end
57
+
58
+ should "add redirection to get rid of stderr in bash" do
59
+ File.stubs(:exist?).with("/dev/null").returns(true)
60
+ cmd = Paperclip::CommandLine.new("convert",
61
+ "a.jpg b.png",
62
+ :swallow_stderr => true)
63
+
64
+ assert_equal "convert a.jpg b.png 2>/dev/null", cmd.command
65
+ end
66
+
67
+ should "add redirection to get rid of stderr in cmd.exe" do
68
+ File.stubs(:exist?).with("/dev/null").returns(false)
69
+ cmd = Paperclip::CommandLine.new("convert",
70
+ "a.jpg b.png",
71
+ :swallow_stderr => true)
72
+
73
+ assert_equal "convert a.jpg b.png 2>NUL", cmd.command
74
+ end
75
+
76
+ should "raise if trying to interpolate :swallow_stderr or :expected_outcodes" do
77
+ cmd = Paperclip::CommandLine.new("convert",
78
+ ":swallow_stderr :expected_outcodes",
79
+ :swallow_stderr => false,
80
+ :expected_outcodes => [0, 1])
81
+ assert_raise(Paperclip::PaperclipCommandLineError) do
82
+ cmd.command
83
+ end
84
+ end
85
+
86
+ should "run the #command it's given and return the output" do
87
+ cmd = Paperclip::CommandLine.new("convert", "a.jpg b.png", :swallow_stderr => false)
88
+ cmd.class.stubs(:"`").with("convert a.jpg b.png").returns(:correct_value)
89
+ with_exitstatus_returning(0) do
90
+ assert_equal :correct_value, cmd.run
91
+ end
92
+ end
93
+
94
+ should "raise a PaperclipCommandLineError if the result code isn't expected" do
95
+ cmd = Paperclip::CommandLine.new("convert", "a.jpg b.png", :swallow_stderr => false)
96
+ cmd.class.stubs(:"`").with("convert a.jpg b.png").returns(:correct_value)
97
+ with_exitstatus_returning(1) do
98
+ assert_raises(Paperclip::PaperclipCommandLineError) do
99
+ cmd.run
100
+ end
101
+ end
102
+ end
103
+
104
+ should "not raise a PaperclipCommandLineError if the result code is expected" do
105
+ cmd = Paperclip::CommandLine.new("convert",
106
+ "a.jpg b.png",
107
+ :expected_outcodes => [0, 1],
108
+ :swallow_stderr => false)
109
+ cmd.class.stubs(:"`").with("convert a.jpg b.png").returns(:correct_value)
110
+ with_exitstatus_returning(1) do
111
+ assert_nothing_raised do
112
+ cmd.run
113
+ end
114
+ end
115
+ end
116
+
117
+ should "log the command" do
118
+ cmd = Paperclip::CommandLine.new("convert", "a.jpg b.png", :swallow_stderr => false)
119
+ cmd.class.stubs(:'`')
120
+ Paperclip.expects(:log).with("convert a.jpg b.png")
121
+ cmd.run
122
+ end
123
+
124
+ should "detect that the system is unix or windows based on presence of /dev/null" do
125
+ File.stubs(:exist?).returns(true)
126
+ assert Paperclip::CommandLine.unix?
127
+ end
128
+
129
+ should "detect that the system is not unix or windows based on absence of /dev/null" do
130
+ File.stubs(:exist?).returns(false)
131
+ assert ! Paperclip::CommandLine.unix?
132
+ end
133
+ 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
@@ -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
data/test/helper.rb ADDED
@@ -0,0 +1,149 @@
1
+ $:.reject! { |e| e.include? 'TextMate' }
2
+
3
+ require 'rubygems'
4
+ require 'tempfile'
5
+ require 'cloudfiles'
6
+ require 'test/unit'
7
+
8
+ require 'shoulda'
9
+ require 'mocha'
10
+
11
+ require 'active_record'
12
+ require 'active_record/version'
13
+ require 'active_support'
14
+
15
+ puts "Testing against version #{ActiveRecord::VERSION::STRING}"
16
+
17
+ `ruby -e 'exit 0'` # Prime $? with a value.
18
+
19
+ begin
20
+ require 'ruby-debug'
21
+ rescue LoadError => e
22
+ puts "debugger disabled"
23
+ end
24
+
25
+ ROOT = File.join(File.dirname(__FILE__), '..')
26
+
27
+ def silence_warnings
28
+ old_verbose, $VERBOSE = $VERBOSE, nil
29
+ yield
30
+ ensure
31
+ $VERBOSE = old_verbose
32
+ end
33
+
34
+ class Test::Unit::TestCase
35
+ def setup
36
+ silence_warnings do
37
+ Object.const_set(:Rails, stub('Rails', :root => ROOT, :env => 'test'))
38
+ end
39
+ end
40
+ end
41
+
42
+ $LOAD_PATH << File.join(ROOT, 'lib')
43
+ $LOAD_PATH << File.join(ROOT, 'lib', 'paperclip')
44
+
45
+ require File.join(ROOT, 'lib', 'paperclip.rb')
46
+
47
+ require './shoulda_macros/paperclip'
48
+
49
+ FIXTURES_DIR = File.join(File.dirname(__FILE__), "fixtures")
50
+ config = YAML::load(IO.read(File.dirname(__FILE__) + '/database.yml'))
51
+ ActiveRecord::Base.logger = ActiveSupport::BufferedLogger.new(File.dirname(__FILE__) + "/debug.log")
52
+ ActiveRecord::Base.establish_connection(config['test'])
53
+
54
+ def reset_class class_name
55
+ ActiveRecord::Base.send(:include, Paperclip::Glue)
56
+ Object.send(:remove_const, class_name) rescue nil
57
+ klass = Object.const_set(class_name, Class.new(ActiveRecord::Base))
58
+ klass.class_eval{ include Paperclip::Glue }
59
+ klass
60
+ end
61
+
62
+ def reset_table table_name, &block
63
+ block ||= lambda { |table| true }
64
+ ActiveRecord::Base.connection.create_table :dummies, {:force => true}, &block
65
+ end
66
+
67
+ def modify_table table_name, &block
68
+ ActiveRecord::Base.connection.change_table :dummies, &block
69
+ end
70
+
71
+ def rebuild_model options = {}
72
+ ActiveRecord::Base.connection.create_table :dummies, :force => true do |table|
73
+ table.column :other, :string
74
+ table.column :avatar_file_name, :string
75
+ table.column :avatar_content_type, :string
76
+ table.column :avatar_file_size, :integer
77
+ table.column :avatar_updated_at, :datetime
78
+ table.column :avatar_fingerprint, :string
79
+ end
80
+ rebuild_class options
81
+ end
82
+
83
+ def rebuild_class options = {}
84
+ ActiveRecord::Base.send(:include, Paperclip::Glue)
85
+ Object.send(:remove_const, "Dummy") rescue nil
86
+ Object.const_set("Dummy", Class.new(ActiveRecord::Base))
87
+ Dummy.class_eval do
88
+ include Paperclip::Glue
89
+ has_attached_file :avatar, options
90
+ end
91
+ end
92
+
93
+ class FakeModel
94
+ attr_accessor :avatar_file_name,
95
+ :avatar_file_size,
96
+ :avatar_last_updated,
97
+ :avatar_content_type,
98
+ :avatar_fingerprint,
99
+ :id
100
+
101
+ def errors
102
+ @errors ||= []
103
+ end
104
+
105
+ def run_paperclip_callbacks name, *args
106
+ end
107
+
108
+ end
109
+
110
+ def attachment options
111
+ Paperclip::Attachment.new(:avatar, FakeModel.new, options)
112
+ end
113
+
114
+ def silence_warnings
115
+ old_verbose, $VERBOSE = $VERBOSE, nil
116
+ yield
117
+ ensure
118
+ $VERBOSE = old_verbose
119
+ end
120
+
121
+ def should_accept_dummy_class
122
+ should "accept the class" do
123
+ assert_accepts @matcher, @dummy_class
124
+ end
125
+
126
+ should "accept an instance of that class" do
127
+ assert_accepts @matcher, @dummy_class.new
128
+ end
129
+ end
130
+
131
+ def should_reject_dummy_class
132
+ should "reject the class" do
133
+ assert_rejects @matcher, @dummy_class
134
+ end
135
+
136
+ should "reject an instance of that class" do
137
+ assert_rejects @matcher, @dummy_class.new
138
+ end
139
+ end
140
+
141
+ def with_exitstatus_returning(code)
142
+ saved_exitstatus = $?.nil? ? 0 : $?.exitstatus
143
+ begin
144
+ `ruby -e 'exit #{code.to_i}'`
145
+ yield
146
+ ensure
147
+ `ruby -e 'exit #{saved_exitstatus.to_i}'`
148
+ end
149
+ end