card 1.19.3 → 1.19.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (190) hide show
  1. checksums.yaml +4 -4
  2. data/.yardopts +1 -0
  3. data/VERSION +1 -1
  4. data/card.gemspec +1 -3
  5. data/db/migrate_core_cards/20160914132636_fix_mod_files.rb +25 -0
  6. data/lib/card.rb +0 -2
  7. data/lib/card/content/diff.rb +3 -4
  8. data/lib/card/format/error.rb +1 -1
  9. data/mod/admin/set/self/admin.rb +2 -2
  10. data/mod/admin/set/self/trash.rb +9 -3
  11. data/mod/basic_types/set/type/html.rb +1 -1
  12. data/mod/bootstrap/set/all/bootstrap/layout.rb +58 -0
  13. data/mod/bootstrap/spec/set/all/bootstrap/layout_spec.rb +32 -0
  14. data/mod/carrierwave/lib/carrier_wave/cardmount.rb +0 -2
  15. data/mod/carrierwave/set/abstract/attachment/upload_cache.rb +2 -1
  16. data/mod/core/set/all/stages.rb +6 -4
  17. data/mod/history/lib/card/act.rb +8 -7
  18. data/mod/history/set/all/history.rb +10 -8
  19. data/mod/machines/set/abstract/script.rb +1 -1
  20. data/mod/machines/set/type/css.rb +1 -1
  21. data/mod/pointer/set/abstract/01_pointer.rb +1 -1
  22. data/mod/standard/file/credit_image/image-icon.png +0 -0
  23. data/mod/standard/file/credit_image/image-large.png +0 -0
  24. data/mod/standard/file/credit_image/image-medium.png +0 -0
  25. data/mod/standard/file/credit_image/image-small.png +0 -0
  26. data/mod/standard/file/favicon/image-icon.png +0 -0
  27. data/mod/standard/file/favicon/image-large.png +0 -0
  28. data/mod/standard/file/favicon/image-medium.png +0 -0
  29. data/mod/standard/file/favicon/image-small.png +0 -0
  30. data/mod/standard/file/logo/image-icon.png +0 -0
  31. data/mod/standard/file/logo/image-large.png +0 -0
  32. data/mod/standard/file/logo/image-medium.png +0 -0
  33. data/mod/standard/file/logo/image-small.png +0 -0
  34. data/mod/standard/set/self/recent.rb +2 -2
  35. data/spec/lib/card/diff_spec.rb +9 -9
  36. metadata +19 -156
  37. data/vendor/carrierwave/.gitignore +0 -19
  38. data/vendor/carrierwave/.rubocop.yml +0 -262
  39. data/vendor/carrierwave/.travis.yml +0 -58
  40. data/vendor/carrierwave/CHANGELOG.md +0 -81
  41. data/vendor/carrierwave/CONTRIBUTING.md +0 -37
  42. data/vendor/carrierwave/Gemfile +0 -5
  43. data/vendor/carrierwave/README.md +0 -995
  44. data/vendor/carrierwave/Rakefile +0 -26
  45. data/vendor/carrierwave/carrierwave.gemspec +0 -45
  46. data/vendor/carrierwave/cucumber.yml +0 -2
  47. data/vendor/carrierwave/features/caching.feature +0 -28
  48. data/vendor/carrierwave/features/download.feature +0 -20
  49. data/vendor/carrierwave/features/file_storage.feature +0 -37
  50. data/vendor/carrierwave/features/file_storage_overridden_filename.feature +0 -38
  51. data/vendor/carrierwave/features/file_storage_overridden_store_dir.feature +0 -38
  52. data/vendor/carrierwave/features/file_storage_reversing_processor.feature +0 -43
  53. data/vendor/carrierwave/features/fixtures/bork.txt +0 -1
  54. data/vendor/carrierwave/features/fixtures/monkey.txt +0 -1
  55. data/vendor/carrierwave/features/fixtures/upcased_bork.txt +0 -1
  56. data/vendor/carrierwave/features/mount_activerecord.feature +0 -46
  57. data/vendor/carrierwave/features/step_definitions/activerecord_steps.rb +0 -20
  58. data/vendor/carrierwave/features/step_definitions/caching_steps.rb +0 -12
  59. data/vendor/carrierwave/features/step_definitions/datamapper_steps.rb +0 -27
  60. data/vendor/carrierwave/features/step_definitions/download_steps.rb +0 -8
  61. data/vendor/carrierwave/features/step_definitions/file_steps.rb +0 -51
  62. data/vendor/carrierwave/features/step_definitions/general_steps.rb +0 -102
  63. data/vendor/carrierwave/features/step_definitions/mount_steps.rb +0 -17
  64. data/vendor/carrierwave/features/step_definitions/store_steps.rb +0 -16
  65. data/vendor/carrierwave/features/support/activerecord.rb +0 -18
  66. data/vendor/carrierwave/features/support/env.rb +0 -19
  67. data/vendor/carrierwave/features/versions_basics.feature +0 -50
  68. data/vendor/carrierwave/features/versions_caching_from_versions.feature +0 -32
  69. data/vendor/carrierwave/features/versions_nested_versions.feature +0 -70
  70. data/vendor/carrierwave/features/versions_overridden_filename.feature +0 -51
  71. data/vendor/carrierwave/features/versions_overriden_store_dir.feature +0 -41
  72. data/vendor/carrierwave/gemfiles/rails-4-0-stable.gemfile +0 -5
  73. data/vendor/carrierwave/gemfiles/rails-4-1-stable.gemfile +0 -5
  74. data/vendor/carrierwave/gemfiles/rails-4-2-stable.gemfile +0 -5
  75. data/vendor/carrierwave/gemfiles/rails-master.gemfile +0 -11
  76. data/vendor/carrierwave/lib/carrierwave.rb +0 -93
  77. data/vendor/carrierwave/lib/carrierwave/compatibility/paperclip.rb +0 -103
  78. data/vendor/carrierwave/lib/carrierwave/error.rb +0 -8
  79. data/vendor/carrierwave/lib/carrierwave/locale/cs.yml +0 -14
  80. data/vendor/carrierwave/lib/carrierwave/locale/de.yml +0 -14
  81. data/vendor/carrierwave/lib/carrierwave/locale/el.yml +0 -14
  82. data/vendor/carrierwave/lib/carrierwave/locale/en.yml +0 -14
  83. data/vendor/carrierwave/lib/carrierwave/locale/es.yml +0 -14
  84. data/vendor/carrierwave/lib/carrierwave/locale/fr-CA.yml +0 -14
  85. data/vendor/carrierwave/lib/carrierwave/locale/fr.yml +0 -14
  86. data/vendor/carrierwave/lib/carrierwave/locale/id.yml +0 -14
  87. data/vendor/carrierwave/lib/carrierwave/locale/ja.yml +0 -14
  88. data/vendor/carrierwave/lib/carrierwave/locale/nb.yml +0 -14
  89. data/vendor/carrierwave/lib/carrierwave/locale/nl.yml +0 -14
  90. data/vendor/carrierwave/lib/carrierwave/locale/pl.yml +0 -14
  91. data/vendor/carrierwave/lib/carrierwave/locale/pt-BR.yml +0 -14
  92. data/vendor/carrierwave/lib/carrierwave/locale/pt-PT.yml +0 -14
  93. data/vendor/carrierwave/lib/carrierwave/locale/ru.yml +0 -14
  94. data/vendor/carrierwave/lib/carrierwave/locale/sk.yml +0 -14
  95. data/vendor/carrierwave/lib/carrierwave/locale/tr.yml +0 -14
  96. data/vendor/carrierwave/lib/carrierwave/locale/zh-CN.yml +0 -14
  97. data/vendor/carrierwave/lib/carrierwave/locale/zh-TW.yml +0 -14
  98. data/vendor/carrierwave/lib/carrierwave/mount.rb +0 -444
  99. data/vendor/carrierwave/lib/carrierwave/mounter.rb +0 -163
  100. data/vendor/carrierwave/lib/carrierwave/orm/activerecord.rb +0 -103
  101. data/vendor/carrierwave/lib/carrierwave/processing.rb +0 -2
  102. data/vendor/carrierwave/lib/carrierwave/processing/mini_magick.rb +0 -328
  103. data/vendor/carrierwave/lib/carrierwave/processing/rmagick.rb +0 -379
  104. data/vendor/carrierwave/lib/carrierwave/sanitized_file.rb +0 -348
  105. data/vendor/carrierwave/lib/carrierwave/storage.rb +0 -2
  106. data/vendor/carrierwave/lib/carrierwave/storage/abstract.rb +0 -43
  107. data/vendor/carrierwave/lib/carrierwave/storage/file.rb +0 -118
  108. data/vendor/carrierwave/lib/carrierwave/storage/fog.rb +0 -462
  109. data/vendor/carrierwave/lib/carrierwave/test/matchers.rb +0 -394
  110. data/vendor/carrierwave/lib/carrierwave/uploader.rb +0 -67
  111. data/vendor/carrierwave/lib/carrierwave/uploader/cache.rb +0 -207
  112. data/vendor/carrierwave/lib/carrierwave/uploader/callbacks.rb +0 -33
  113. data/vendor/carrierwave/lib/carrierwave/uploader/configuration.rb +0 -203
  114. data/vendor/carrierwave/lib/carrierwave/uploader/content_type_blacklist.rb +0 -48
  115. data/vendor/carrierwave/lib/carrierwave/uploader/content_type_whitelist.rb +0 -48
  116. data/vendor/carrierwave/lib/carrierwave/uploader/default_url.rb +0 -17
  117. data/vendor/carrierwave/lib/carrierwave/uploader/download.rb +0 -92
  118. data/vendor/carrierwave/lib/carrierwave/uploader/extension_blacklist.rb +0 -51
  119. data/vendor/carrierwave/lib/carrierwave/uploader/extension_whitelist.rb +0 -51
  120. data/vendor/carrierwave/lib/carrierwave/uploader/file_size.rb +0 -41
  121. data/vendor/carrierwave/lib/carrierwave/uploader/magic_mime_blacklist.rb +0 -94
  122. data/vendor/carrierwave/lib/carrierwave/uploader/magic_mime_whitelist.rb +0 -94
  123. data/vendor/carrierwave/lib/carrierwave/uploader/mountable.rb +0 -38
  124. data/vendor/carrierwave/lib/carrierwave/uploader/processing.rb +0 -88
  125. data/vendor/carrierwave/lib/carrierwave/uploader/proxy.rb +0 -86
  126. data/vendor/carrierwave/lib/carrierwave/uploader/remove.rb +0 -21
  127. data/vendor/carrierwave/lib/carrierwave/uploader/serialization.rb +0 -28
  128. data/vendor/carrierwave/lib/carrierwave/uploader/store.rb +0 -93
  129. data/vendor/carrierwave/lib/carrierwave/uploader/url.rb +0 -41
  130. data/vendor/carrierwave/lib/carrierwave/uploader/versions.rb +0 -295
  131. data/vendor/carrierwave/lib/carrierwave/utilities.rb +0 -6
  132. data/vendor/carrierwave/lib/carrierwave/utilities/uri.rb +0 -21
  133. data/vendor/carrierwave/lib/carrierwave/validations/active_model.rb +0 -78
  134. data/vendor/carrierwave/lib/carrierwave/version.rb +0 -3
  135. data/vendor/carrierwave/lib/generators/templates/uploader.rb +0 -49
  136. data/vendor/carrierwave/lib/generators/uploader_generator.rb +0 -7
  137. data/vendor/carrierwave/script/console +0 -10
  138. data/vendor/carrierwave/script/destroy +0 -14
  139. data/vendor/carrierwave/script/generate +0 -14
  140. data/vendor/carrierwave/spec/compatibility/paperclip_spec.rb +0 -138
  141. data/vendor/carrierwave/spec/fixtures/Uppercase.jpg +0 -1
  142. data/vendor/carrierwave/spec/fixtures/bork.ttxt +0 -1
  143. data/vendor/carrierwave/spec/fixtures/bork.txt +0 -1
  144. data/vendor/carrierwave/spec/fixtures/bork.txtt +0 -1
  145. data/vendor/carrierwave/spec/fixtures/case.JPG +0 -1
  146. data/vendor/carrierwave/spec/fixtures/landscape.jpg +0 -0
  147. data/vendor/carrierwave/spec/fixtures/multi_page.pdf +0 -0
  148. data/vendor/carrierwave/spec/fixtures/new.jpeg +0 -1
  149. data/vendor/carrierwave/spec/fixtures/new.txt +0 -1
  150. data/vendor/carrierwave/spec/fixtures/old.jpeg +0 -1
  151. data/vendor/carrierwave/spec/fixtures/old.txt +0 -1
  152. data/vendor/carrierwave/spec/fixtures/portrait.jpg +0 -0
  153. data/vendor/carrierwave/spec/fixtures/ruby.gif +0 -0
  154. data/vendor/carrierwave/spec/fixtures/sponsored.doc +0 -1
  155. data/vendor/carrierwave/spec/fixtures/test+.jpg +0 -1
  156. data/vendor/carrierwave/spec/fixtures/test.jpeg +0 -1
  157. data/vendor/carrierwave/spec/fixtures/test.jpg +0 -1
  158. data/vendor/carrierwave/spec/generators/uploader_generator_spec.rb +0 -19
  159. data/vendor/carrierwave/spec/mount_multiple_spec.rb +0 -913
  160. data/vendor/carrierwave/spec/mount_single_spec.rb +0 -793
  161. data/vendor/carrierwave/spec/orm/activerecord_spec.rb +0 -1556
  162. data/vendor/carrierwave/spec/processing/mini_magick_spec.rb +0 -210
  163. data/vendor/carrierwave/spec/processing/rmagick_spec.rb +0 -250
  164. data/vendor/carrierwave/spec/sanitized_file_spec.rb +0 -805
  165. data/vendor/carrierwave/spec/spec_helper.rb +0 -105
  166. data/vendor/carrierwave/spec/storage/file_spec.rb +0 -82
  167. data/vendor/carrierwave/spec/storage/fog_credentials.rb +0 -46
  168. data/vendor/carrierwave/spec/storage/fog_helper.rb +0 -428
  169. data/vendor/carrierwave/spec/storage/fog_spec.rb +0 -48
  170. data/vendor/carrierwave/spec/support/activerecord.rb +0 -31
  171. data/vendor/carrierwave/spec/support/file_utils_helper.rb +0 -15
  172. data/vendor/carrierwave/spec/uploader/cache_spec.rb +0 -324
  173. data/vendor/carrierwave/spec/uploader/callback_spec.rb +0 -30
  174. data/vendor/carrierwave/spec/uploader/configuration_spec.rb +0 -133
  175. data/vendor/carrierwave/spec/uploader/content_type_blacklist_spec.rb +0 -61
  176. data/vendor/carrierwave/spec/uploader/content_type_whitelist_spec.rb +0 -63
  177. data/vendor/carrierwave/spec/uploader/default_url_spec.rb +0 -77
  178. data/vendor/carrierwave/spec/uploader/download_spec.rb +0 -204
  179. data/vendor/carrierwave/spec/uploader/extension_blacklist_spec.rb +0 -112
  180. data/vendor/carrierwave/spec/uploader/extension_whitelist_spec.rb +0 -102
  181. data/vendor/carrierwave/spec/uploader/file_size_spec.rb +0 -52
  182. data/vendor/carrierwave/spec/uploader/mountable_spec.rb +0 -26
  183. data/vendor/carrierwave/spec/uploader/overrides_spec.rb +0 -71
  184. data/vendor/carrierwave/spec/uploader/paths_spec.rb +0 -18
  185. data/vendor/carrierwave/spec/uploader/processing_spec.rb +0 -159
  186. data/vendor/carrierwave/spec/uploader/proxy_spec.rb +0 -79
  187. data/vendor/carrierwave/spec/uploader/remove_spec.rb +0 -71
  188. data/vendor/carrierwave/spec/uploader/store_spec.rb +0 -400
  189. data/vendor/carrierwave/spec/uploader/url_spec.rb +0 -273
  190. data/vendor/carrierwave/spec/uploader/versions_spec.rb +0 -633
@@ -1,48 +0,0 @@
1
- require 'spec_helper'
2
- require 'fog'
3
- require 'carrierwave/storage/fog'
4
-
5
- unless ENV['REMOTE'] == 'true'
6
- Fog.mock!
7
- end
8
-
9
- require_relative './fog_credentials' # after Fog.mock!
10
- require_relative './fog_helper'
11
-
12
- FOG_CREDENTIALS.each do |credential|
13
- fog_tests(credential)
14
- end
15
-
16
- describe CarrierWave::Storage::Fog::File do
17
- subject(:file) { CarrierWave::Storage::Fog::File.new(nil, nil, nil) }
18
-
19
- describe "#filename" do
20
- subject(:filename) { file.filename }
21
-
22
- before { allow(file).to receive(:url).and_return(url) }
23
-
24
- context "with normal url" do
25
- let(:url) { 'http://example.com/path/to/foo.txt' }
26
-
27
- it "extracts filename from url" do
28
- is_expected.to eq('foo.txt')
29
- end
30
- end
31
-
32
- context "when url contains '/' in query string" do
33
- let(:url){ 'http://example.com/path/to/foo.txt?bar=baz/fubar' }
34
-
35
- it "extracts correct part" do
36
- is_expected.to eq('foo.txt')
37
- end
38
- end
39
-
40
- context "when url contains multi-byte characters" do
41
- let(:url) { 'http://example.com/path/to/%E6%97%A5%E6%9C%AC%E8%AA%9E.txt' }
42
-
43
- it "decodes multi-byte characters" do
44
- is_expected.to eq('日本語.txt')
45
- end
46
- end
47
- end
48
- end
@@ -1,31 +0,0 @@
1
- if RUBY_ENGINE == 'jruby'
2
- require 'activerecord-jdbcpostgresql-adapter'
3
- else
4
- require 'pg'
5
- end
6
- require 'active_record'
7
- require 'carrierwave/orm/activerecord'
8
- Bundler.require
9
-
10
- # Change this if PG is unavailable
11
- dbconfig = {
12
- :adapter => 'postgresql',
13
- :database => 'carrierwave_test',
14
- :encoding => 'utf8',
15
- :username => 'postgres'
16
- }
17
-
18
- database = dbconfig.delete(:database)
19
-
20
- ActiveRecord::Base.establish_connection(dbconfig.merge(database: "template1"))
21
- begin
22
- ActiveRecord::Base.connection.create_database database
23
- rescue ActiveRecord::StatementInvalid => e # database already exists
24
- end
25
- ActiveRecord::Base.establish_connection(dbconfig.merge(:database => database))
26
-
27
- ActiveRecord::Migration.verbose = false
28
-
29
- if ActiveRecord::VERSION::STRING >= '4.2'
30
- ActiveRecord::Base.raise_in_transactional_callbacks = true
31
- end
@@ -1,15 +0,0 @@
1
- module FileUtilsHelper
2
- # NOTE: Make FileUtils.mkdir_p to raise `Errno::EMLINK` only once
3
- def fake_failed_mkdir_p
4
- original_mkdir_p = FileUtils.method(:mkdir_p)
5
- mkdir_p_called = false
6
- allow(FileUtils).to receive(:mkdir_p) do |args|
7
- if mkdir_p_called
8
- original_mkdir_p.call(*args)
9
- else
10
- mkdir_p_called = true
11
- raise Errno::EMLINK
12
- end
13
- end
14
- end
15
- end
@@ -1,324 +0,0 @@
1
- require 'spec_helper'
2
-
3
- describe CarrierWave::Uploader do
4
- let(:uploader_class) { Class.new(CarrierWave::Uploader::Base) }
5
- let(:uploader) { uploader_class.new }
6
- let(:test_file_name) { "test.jpg"}
7
- let(:test_file_path) { file_path(test_file_name) }
8
- let(:test_file) { File.open(test_file_path) }
9
- let(:permission) { 0777 }
10
- let(:cache_id) { '1369894322-345-1234-2255' }
11
-
12
- before { FileUtils.rm_rf(public_path) }
13
-
14
- after { FileUtils.rm_rf(public_path) }
15
-
16
- describe '#cache_dir' do
17
- it "defaults to the config option" do
18
- expect(uploader.cache_dir).to eq('uploads/tmp')
19
- end
20
- end
21
-
22
- describe '#sanitized_file' do
23
- before { uploader.store! CarrierWave::SanitizedFile.new(test_file) }
24
-
25
- it "returns a sanitized file" do
26
- expect(uploader.sanitized_file).to be_an_instance_of(CarrierWave::SanitizedFile)
27
- end
28
-
29
- it "only read the file once" do
30
- expect(uploader.file).to receive(:read).once.and_return('this is stuff')
31
-
32
- uploader.sanitized_file
33
- end
34
- end
35
-
36
- context "permissions" do
37
- it "sets permissions if options are given" do
38
- uploader_class.permissions = permission
39
- uploader.cache!(test_file)
40
-
41
- expect(uploader).to have_permissions(permission)
42
- end
43
-
44
- it "sets directory permissions if options are given" do
45
- uploader_class.directory_permissions = permission
46
- uploader.cache!(test_file)
47
-
48
- expect(uploader).to have_directory_permissions(permission)
49
- end
50
-
51
- describe "with ensuring multipart form deactivated" do
52
- before do
53
- CarrierWave.configure { |config| config.ensure_multipart_form = false }
54
- end
55
-
56
- it "doesn't raise an error when trying to cache a string" do
57
- expect(running {
58
- uploader.cache!(file_path(test_file_name))
59
- }).not_to raise_error
60
- end
61
-
62
- it "doesn't raise an error when trying to cache a pathname and " do
63
- expect(running {
64
- uploader.cache!(Pathname.new(file_path(test_file_name)))
65
- }).not_to raise_error
66
- end
67
- end
68
- end
69
-
70
- describe '#cache!' do
71
- before { allow(CarrierWave).to receive(:generate_cache_id).and_return(cache_id) }
72
-
73
- context "when ensure_multipart_form is true" do
74
- before { CarrierWave.configure { |config| config.ensure_multipart_form = true } }
75
-
76
- it "raises an error when trying to cache a string" do
77
- expect(running { uploader.cache!(test_file_path) }).to raise_error(CarrierWave::FormNotMultipart)
78
- end
79
-
80
- it "raises an error when trying to cache a pathname" do
81
- expect { uploader.cache!(Pathname.new(test_file)) }.to raise_error(CarrierWave::FormNotMultipart)
82
- end
83
- end
84
-
85
- context "when a file is cached" do
86
- before { uploader.cache!(test_file) }
87
-
88
- it "caches the file" do
89
- expect(uploader.file).to be_an_instance_of(CarrierWave::SanitizedFile)
90
- end
91
-
92
- it { expect(uploader).to be_cached }
93
-
94
- it "stores the cache name" do
95
- expect(uploader.cache_name).to eq("#{cache_id}/#{test_file_name}")
96
- end
97
-
98
- it "sets the filename to the file's sanitized filename" do
99
- expect(uploader.filename).to eq(test_file_name)
100
- end
101
-
102
- it "moves it to the tmp dir" do
103
- expect(uploader.file.path).to eq(public_path("uploads/tmp/#{cache_id}/#{test_file_name}"))
104
- end
105
-
106
- it { expect(uploader.file.exists?).to be_truthy }
107
-
108
- it "sets the url" do
109
- expect(uploader.url).to eq("/uploads/tmp/#{cache_id}/#{test_file_name}")
110
- end
111
-
112
- it "does nothing when trying to cache an empty file" do
113
- uploader.cache!(nil)
114
- end
115
- end
116
-
117
- describe "with the move_to_cache option" do
118
- let(:tmp_file_name) { "test_move.jpeg" }
119
- let(:tmp_file_path) { file_path(tmp_file_name) }
120
- let(:tmp_file) { File.open(tmp_file_path) }
121
- let(:cached_id) { '1369894322-345-1234-2255' }
122
- let(:cached_path) { public_path("uploads/tmp/#{cached_id}/#{tmp_file_name}") }
123
- let(:workfile_path) { tmp_path("#{cached_id}/#{tmp_file_name}") }
124
-
125
- before do
126
- FileUtils.cp(test_file, File.join(File.dirname(test_file), tmp_file_name))
127
-
128
- allow(CarrierWave).to receive(:generate_cache_id).and_return(cached_id)
129
-
130
- uploader_class.permissions = permission
131
- uploader_class.directory_permissions = permission
132
- end
133
-
134
- after do
135
- FileUtils.rm_f(tmp_file.path)
136
- end
137
-
138
- context "set to true" do
139
- before { uploader_class.move_to_cache = true }
140
-
141
- context "moving from the upload directory to the temporary directory" do
142
- let(:original_path) { tmp_file.path }
143
-
144
- before { uploader.cache!(tmp_file) }
145
-
146
- it { expect(uploader.file.path).to eq(cached_path) }
147
-
148
- it { expect(File.exist?(cached_path)).to be_truthy }
149
-
150
- it { expect(File.exist?(original_path)).to be_falsey }
151
-
152
- end
153
-
154
- describe "method usage" do
155
- after { uploader.cache!(tmp_file) }
156
-
157
- it "uses #move_to during #cache!" do
158
- moved_file = double('moved file').as_null_object
159
-
160
- expect_any_instance_of(CarrierWave::SanitizedFile).to receive(:move_to).with(workfile_path, permission, permission).and_return(moved_file)
161
- expect(moved_file).to receive(:move_to).with(cached_path, permission, permission, true)
162
- end
163
-
164
- it "doesn't use #copy_to during #cache!" do
165
- expect_any_instance_of(CarrierWave::SanitizedFile).not_to receive(:copy_to)
166
- end
167
- end
168
- end
169
-
170
- context "set to false" do
171
- before { uploader_class.move_to_cache = false }
172
-
173
- context "copying from the upload directory to the temporary directory" do
174
- let(:original_path) { tmp_file.path }
175
-
176
- before { uploader.cache!(tmp_file) }
177
-
178
- it { expect(uploader.file.path).to eq(cached_path) }
179
- it { expect(File.exist?(cached_path)).to be_truthy }
180
- it { expect(File.exist?(original_path)).to be_truthy }
181
- end
182
-
183
- describe "method usage" do
184
- after { uploader.cache!(tmp_file) }
185
-
186
- it "uses #move_to during cache!" do
187
- moved_file = double('moved file').as_null_object
188
-
189
- expect_any_instance_of(CarrierWave::SanitizedFile).to receive(:copy_to).with(workfile_path, permission, permission).and_return(moved_file)
190
- expect(moved_file).to receive(:move_to).with(cached_path, permission, permission, true)
191
- end
192
-
193
- it "doesn't use #move_to during #cache!" do
194
- expect_any_instance_of(CarrierWave::SanitizedFile).not_to receive(:move_to).with(workfile_path, permission, permission)
195
- end
196
- end
197
- end
198
- end
199
-
200
- it "uses different workfiles for different versions" do
201
- uploader_class.version(:small)
202
- uploader_class.version(:large)
203
-
204
- uploader.cache!(test_file)
205
-
206
- expect(uploader.small.send(:workfile_path)).not_to eq uploader.large.send(:workfile_path)
207
- end
208
- end
209
-
210
- describe '#retrieve_from_cache!' do
211
- before { uploader.retrieve_from_cache!("#{cache_id}/#{test_file_name}") }
212
-
213
- it "caches a file" do
214
- expect(uploader.file).to be_an_instance_of(CarrierWave::SanitizedFile)
215
- end
216
-
217
- it { expect(uploader).to be_cached }
218
-
219
- it "sets the path to the tmp dir" do
220
- expect(uploader.current_path).to eq(public_path("uploads/tmp/#{cache_id}/#{test_file_name}"))
221
- end
222
-
223
- it "overwrites a file that has already been cached" do
224
- uploader.retrieve_from_cache!("#{cache_id}/#{test_file_name}")
225
- uploader.retrieve_from_cache!("#{cache_id}/bork.txt")
226
-
227
- expect(uploader.current_path).to eq(public_path("uploads/tmp/#{cache_id}/bork.txt"))
228
- end
229
-
230
- it "stores the cache_name" do
231
- expect(uploader.cache_name).to eq("#{cache_id}/#{test_file_name}")
232
- end
233
-
234
- it "stores the filename" do
235
- expect(uploader.filename).to eq(test_file_name)
236
- end
237
-
238
- it "sets the url" do
239
- expect(uploader.url).to eq("/uploads/tmp/#{cache_id}/#{test_file_name}")
240
- end
241
-
242
-
243
- it "supports old format of cache_id (without counter) for backwards compartibility" do
244
- expect(uploader.url).to eq("/uploads/tmp/#{cache_id}/#{test_file_name}")
245
- end
246
-
247
- it "raises an error when the cache_id has an invalid format" do
248
- expect(running {
249
- uploader.retrieve_from_cache!("12345/#{test_file_name}")
250
- }).to raise_error(CarrierWave::InvalidParameter)
251
- end
252
-
253
- context "when the original filename has invalid characters" do
254
- it do
255
- expect(running {
256
- uploader.retrieve_from_cache!('1369894322-345-1234-2255/te/st.jpeg')
257
- }).to raise_error(CarrierWave::InvalidParameter)
258
- end
259
-
260
- it do
261
- expect(running {
262
- uploader.retrieve_from_cache!('1369894322-345-1234-2255/te??%st.jpeg')
263
- }).to raise_error(CarrierWave::InvalidParameter)
264
- end
265
- end
266
- end
267
-
268
- describe 'with an overridden, reversing, filename' do
269
- before do
270
- uploader_class.class_eval do
271
- def filename
272
- super.reverse unless super.blank?
273
- end
274
- end
275
-
276
- allow(CarrierWave).to receive(:generate_cache_id).and_return(cache_id)
277
- uploader.cache!(test_file)
278
- end
279
-
280
- let(:reversed_test_file_name) { test_file_name.reverse }
281
-
282
- describe '#cache!' do
283
- it "sets the filename to the file's reversed filename" do
284
- expect(uploader.filename).to eq(reversed_test_file_name)
285
- end
286
-
287
- it "moves it to the tmp dir with the filename unreversed" do
288
- expect(uploader.current_path).to eq(public_path("uploads/tmp/#{cache_id}/#{test_file_name}"))
289
- expect(uploader.file.exists?).to be_truthy
290
- end
291
- end
292
-
293
- describe '#retrieve_from_cache!' do
294
- it "sets the path to the tmp dir" do
295
- expect(uploader.current_path).to eq(public_path("uploads/tmp/#{cache_id}/#{test_file_name}"))
296
- end
297
-
298
- it "sets the filename to the reversed name of the file" do
299
- expect(uploader.filename).to eq(reversed_test_file_name)
300
- end
301
- end
302
- end
303
-
304
- describe '.generate_cache_id' do
305
- it 'generates dir name based on UTC time' do
306
- Timecop.freeze(Time.at(1369896000)) do
307
- expect(CarrierWave.generate_cache_id).to match(/\A1369896000-\d+-\d+-\d+\Z/)
308
- end
309
- end
310
-
311
- it 'generates dir name with a counter substring' do
312
- counter = CarrierWave.generate_cache_id.split('-')[2].to_i
313
-
314
- expect(CarrierWave.generate_cache_id.split('-')[2].to_i).to eq(counter + 1)
315
- end
316
-
317
- it 'generates dir name with constant length even when counter has big value' do
318
- length = CarrierWave.generate_cache_id.length
319
- allow(CarrierWave::CacheCounter).to receive(:increment).and_return(1234567890)
320
-
321
- expect(CarrierWave.generate_cache_id.length).to eq(length)
322
- end
323
- end
324
- end
@@ -1,30 +0,0 @@
1
- require 'spec_helper'
2
-
3
- describe CarrierWave::Uploader do
4
- describe "callback isolation" do
5
- let(:default_before_callbacks) do
6
- [
7
- :check_extension_whitelist!,
8
- :check_extension_blacklist!,
9
- :check_content_type_whitelist!,
10
- :check_content_type_blacklist!,
11
- :check_size!,
12
- :process!
13
- ]
14
- end
15
-
16
- let(:uploader_class_1) { Class.new(CarrierWave::Uploader::Base) }
17
- let(:uploader_class_2) { Class.new(CarrierWave::Uploader::Base) }
18
-
19
- before { uploader_class_2.before(:cache, :before_cache_callback) }
20
-
21
- it { expect(uploader_class_1._before_callbacks[:cache]).to eq(default_before_callbacks) }
22
-
23
-
24
- it { expect(uploader_class_2._before_callbacks[:cache]).to eq(default_before_callbacks + [:before_cache_callback]) }
25
-
26
- it "doesn't inherit the uploader 2 callback" do
27
- expect(uploader_class_1._before_callbacks[:cache]).to eq(default_before_callbacks)
28
- end
29
- end
30
- end