mime-types 3.3.1

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,169 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'mime/types'
4
+ require 'minitest_helper'
5
+
6
+ describe MIME::Types do
7
+ def mime_types
8
+ @mime_types ||= MIME::Types.new.tap { |mt|
9
+ mt.add MIME::Type.new(['text/plain', %w(txt)]),
10
+ MIME::Type.new(['image/jpeg', %w(jpg jpeg)]),
11
+ MIME::Type.new('application/x-wordperfect6.1'),
12
+ MIME::Type.new(
13
+ 'content-type' => 'application/x-www-form-urlencoded',
14
+ 'registered' => true
15
+ ),
16
+ MIME::Type.new(['application/x-gzip', %w(gz)]),
17
+ MIME::Type.new(
18
+ 'content-type' => 'application/gzip',
19
+ 'extensions' => 'gz',
20
+ 'registered' => true
21
+ )
22
+ }
23
+ end
24
+
25
+ describe 'is enumerable' do
26
+ it 'correctly uses an Enumerable method like #any?' do
27
+ assert(mime_types.any? { |type| type.content_type == 'text/plain' })
28
+ end
29
+
30
+ it 'implements each with no parameters to return an Enumerator' do
31
+ assert_kind_of Enumerator, mime_types.each
32
+ assert_kind_of Enumerator, mime_types.map
33
+ end
34
+
35
+ it 'will create a lazy enumerator' do
36
+ assert_kind_of Enumerator::Lazy, mime_types.lazy
37
+ assert_kind_of Enumerator::Lazy, mime_types.map.lazy
38
+ end
39
+
40
+ it 'is countable with an enumerator' do
41
+ assert_equal 6, mime_types.each.count
42
+ assert_equal 6, mime_types.lazy.count
43
+ end
44
+ end
45
+
46
+ describe '#[]' do
47
+ it 'can be searched with a MIME::Type' do
48
+ text_plain = MIME::Type.new('text/plain')
49
+ assert_includes mime_types[text_plain], 'text/plain'
50
+ assert_equal 1, mime_types[text_plain].size
51
+ end
52
+
53
+ it 'can be searched with a regular expression' do
54
+ assert_includes mime_types[/plain$/], 'text/plain'
55
+ assert_equal 1, mime_types[/plain$/].size
56
+ end
57
+
58
+ it 'sorts by priority with multiple matches' do
59
+ assert_equal %w(application/gzip application/x-gzip), mime_types[/gzip$/]
60
+ assert_equal 2, mime_types[/gzip$/].size
61
+ end
62
+
63
+ it 'can be searched with a string' do
64
+ assert_includes mime_types['text/plain'], 'text/plain'
65
+ assert_equal 1, mime_types['text/plain'].size
66
+ end
67
+
68
+ it 'can be searched with the complete flag' do
69
+ assert_empty mime_types[
70
+ 'application/x-www-form-urlencoded',
71
+ complete: true
72
+ ]
73
+ assert_includes mime_types['text/plain', complete: true], 'text/plain'
74
+ assert_equal 1, mime_types['text/plain', complete: true].size
75
+ end
76
+
77
+ it 'can be searched with the registered flag' do
78
+ assert_empty mime_types['application/x-wordperfect6.1', registered: true]
79
+ refute_empty mime_types[
80
+ 'application/x-www-form-urlencoded',
81
+ registered: true
82
+ ]
83
+ refute_empty mime_types[/gzip/, registered: true]
84
+ refute_equal mime_types[/gzip/], mime_types[/gzip/, registered: true]
85
+ end
86
+
87
+ it 'properly returns an empty result on a regular expression miss' do
88
+ assert_empty mime_types[/^foo/]
89
+ assert_empty mime_types[/^foo/, registered: true]
90
+ assert_empty mime_types[/^foo/, complete: true]
91
+ end
92
+ end
93
+
94
+ describe '#add' do
95
+ let(:eruby) { MIME::Type.new('application/x-eruby') }
96
+ let(:jinja) { MIME::Type.new('application/jinja2') }
97
+
98
+ it 'successfully adds a new type' do
99
+ mime_types.add(eruby)
100
+ assert_equal mime_types['application/x-eruby'], [eruby]
101
+ end
102
+
103
+ it 'complains about adding a duplicate type' do
104
+ mime_types.add(eruby)
105
+ assert_output '', /is already registered as a variant/ do
106
+ mime_types.add(eruby)
107
+ end
108
+ assert_equal mime_types['application/x-eruby'], [eruby]
109
+ end
110
+
111
+ it 'does not complain about adding a duplicate type when quiet' do
112
+ mime_types.add(eruby)
113
+ assert_output '', '' do
114
+ mime_types.add(eruby, :silent)
115
+ end
116
+ assert_equal mime_types['application/x-eruby'], [eruby]
117
+ end
118
+
119
+ it 'successfully adds from an array' do
120
+ mime_types.add([eruby, jinja])
121
+ assert_equal mime_types['application/x-eruby'], [eruby]
122
+ assert_equal mime_types['application/jinja2'], [jinja]
123
+ end
124
+
125
+ it 'successfully adds from another MIME::Types' do
126
+ mt = MIME::Types.new
127
+ mt.add(mime_types)
128
+ assert_equal mime_types.count, mt.count
129
+
130
+ mime_types.each do |type|
131
+ assert_equal mt[type.content_type], [type]
132
+ end
133
+ end
134
+ end
135
+
136
+ describe '#type_for' do
137
+ it 'finds all types for a given extension' do
138
+ assert_equal %w(application/gzip application/x-gzip),
139
+ mime_types.type_for('gz')
140
+ end
141
+
142
+ it 'separates the extension from filenames' do
143
+ assert_equal %w(image/jpeg), mime_types.of(['foo.jpeg', 'bar.jpeg'])
144
+ end
145
+
146
+ it 'finds multiple extensions' do
147
+ assert_equal %w(image/jpeg text/plain),
148
+ mime_types.type_for(%w(foo.txt foo.jpeg))
149
+ end
150
+
151
+ it 'does not find unknown extensions' do
152
+ keys = mime_types.instance_variable_get(:@extension_index).keys
153
+ assert_empty mime_types.type_for('zzz')
154
+ assert_equal keys, mime_types.instance_variable_get(:@extension_index).keys
155
+ end
156
+
157
+ it 'modifying type extensions causes reindexing' do
158
+ plain_text = mime_types['text/plain'].first
159
+ plain_text.add_extensions('xtxt')
160
+ assert_includes mime_types.type_for('xtxt'), 'text/plain'
161
+ end
162
+ end
163
+
164
+ describe '#count' do
165
+ it 'can count the number of types inside' do
166
+ assert_equal 6, mime_types.count
167
+ end
168
+ end
169
+ end
@@ -0,0 +1,118 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'mime/types'
4
+ require 'minitest_helper'
5
+
6
+ describe MIME::Types::Cache do
7
+ include Minitest::Hooks
8
+
9
+ MUTEX = Mutex.new
10
+
11
+ def around
12
+ require 'fileutils'
13
+
14
+ MUTEX.synchronize do
15
+ @cache_file = File.expand_path('../cache.tst', __FILE__)
16
+ ENV['RUBY_MIME_TYPES_CACHE'] = @cache_file
17
+ clear_cache_file
18
+
19
+ super
20
+
21
+ clear_cache_file
22
+ ENV.delete('RUBY_MIME_TYPES_CACHE')
23
+ end
24
+ end
25
+
26
+ def reset_mime_types
27
+ MIME::Types.instance_variable_set(:@__types__, nil)
28
+ MIME::Types.send(:load_default_mime_types)
29
+ end
30
+
31
+ def clear_cache_file
32
+ FileUtils.rm @cache_file if File.exist? @cache_file
33
+ end
34
+
35
+ describe '.load' do
36
+ it 'does not use cache when RUBY_MIME_TYPES_CACHE is unset' do
37
+ ENV.delete('RUBY_MIME_TYPES_CACHE')
38
+ assert_nil MIME::Types::Cache.load
39
+ end
40
+
41
+ it 'does not use cache when missing' do
42
+ assert_nil MIME::Types::Cache.load
43
+ end
44
+
45
+ it 'registers the data to be updated by #add_extensions' do
46
+ MIME::Types::Cache.save
47
+ reset_mime_types
48
+ assert_equal([], MIME::Types.type_for('foo.additional'))
49
+ html = MIME::Types['text/html'][0]
50
+ html.add_extensions('additional')
51
+ assert_equal([html], MIME::Types.type_for('foo.additional'))
52
+ end
53
+
54
+ it 'outputs an error when there is an invalid version' do
55
+ v = MIME::Types::Data::VERSION
56
+ MIME::Types::Data.send(:remove_const, :VERSION)
57
+ MIME::Types::Data.const_set(:VERSION, '0.0')
58
+ MIME::Types::Cache.save
59
+ MIME::Types::Data.send(:remove_const, :VERSION)
60
+ MIME::Types::Data.const_set(:VERSION, v)
61
+ MIME::Types.instance_variable_set(:@__types__, nil)
62
+ assert_output '', /MIME::Types cache: invalid version/ do
63
+ MIME::Types['text/html']
64
+ end
65
+ end
66
+
67
+ it 'outputs an error when there is a marshal file incompatibility' do
68
+ MIME::Types::Cache.save
69
+ data = File.binread(@cache_file).reverse
70
+ File.open(@cache_file, 'wb') do |f| f.write(data) end
71
+ MIME::Types.instance_variable_set(:@__types__, nil)
72
+ assert_output '', /incompatible marshal file format/ do
73
+ MIME::Types['text/html']
74
+ end
75
+ end
76
+ end
77
+
78
+ describe '.save' do
79
+ it 'does not create cache when RUBY_MIME_TYPES_CACHE is unset' do
80
+ ENV.delete('RUBY_MIME_TYPES_CACHE')
81
+ assert_nil MIME::Types::Cache.save
82
+ end
83
+
84
+ it 'creates the cache ' do
85
+ assert_equal(false, File.exist?(@cache_file))
86
+ MIME::Types::Cache.save
87
+ assert_equal(true, File.exist?(@cache_file))
88
+ end
89
+
90
+ it 'uses the cache' do
91
+ MIME::Types['text/html'].first.add_extensions('hex')
92
+ MIME::Types::Cache.save
93
+ MIME::Types.instance_variable_set(:@__types__, nil)
94
+
95
+ assert_includes MIME::Types['text/html'].first.extensions, 'hex'
96
+
97
+ reset_mime_types
98
+ end
99
+ end
100
+ end
101
+
102
+ describe MIME::Types::Container do
103
+ it 'marshals and unmarshals correctly' do
104
+ container = MIME::Types::Container.new
105
+ container.add('xyz', 'abc')
106
+
107
+ # default proc should return Set[]
108
+ assert_equal(Set[], container['abc'])
109
+ assert_equal(Set['abc'], container['xyz'])
110
+
111
+ marshalled = Marshal.dump(container)
112
+ loaded_container = Marshal.load(marshalled)
113
+
114
+ # default proc should still return Set[]
115
+ assert_equal(Set[], loaded_container['abc'])
116
+ assert_equal(Set['abc'], container['xyz'])
117
+ end
118
+ end
@@ -0,0 +1,159 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'mime/types'
4
+ require 'minitest_helper'
5
+
6
+ describe MIME::Types, 'registry' do
7
+ def setup
8
+ MIME::Types.send(:load_default_mime_types)
9
+ end
10
+
11
+ describe 'is enumerable' do
12
+ it 'correctly uses an Enumerable method like #any?' do
13
+ assert(MIME::Types.any? { |type| type.content_type == 'text/plain' })
14
+ end
15
+
16
+ it 'implements each with no parameters to return an Enumerator' do
17
+ assert_kind_of Enumerator, MIME::Types.each
18
+ assert_kind_of Enumerator, MIME::Types.map
19
+ end
20
+
21
+ it 'will create a lazy enumerator' do
22
+ assert_kind_of Enumerator::Lazy, MIME::Types.lazy
23
+ assert_kind_of Enumerator::Lazy, MIME::Types.map.lazy
24
+ end
25
+
26
+ it 'is countable with an enumerator' do
27
+ assert MIME::Types.each.count > 999
28
+ assert MIME::Types.lazy.count > 999
29
+ end
30
+ end
31
+
32
+ describe '.[]' do
33
+ it 'can be searched with a MIME::Type' do
34
+ text_plain = MIME::Type.new('text/plain')
35
+ assert_includes MIME::Types[text_plain], 'text/plain'
36
+ assert_equal 1, MIME::Types[text_plain].size
37
+ end
38
+
39
+ it 'can be searched with a regular expression' do
40
+ assert_includes MIME::Types[/plain$/], 'text/plain'
41
+ assert_equal 1, MIME::Types[/plain$/].size
42
+ end
43
+
44
+ it 'sorts by priority with multiple matches' do
45
+ types = MIME::Types[/gzip$/].select { |t|
46
+ %w(application/gzip application/x-gzip multipart/x-gzip).include?(t)
47
+ }
48
+ # This is this way because of a new type ending with gzip that only
49
+ # appears in some data files.
50
+ assert_equal %w(application/gzip application/x-gzip multipart/x-gzip), types
51
+ assert_equal 3, types.size
52
+ end
53
+
54
+ it 'can be searched with a string' do
55
+ assert_includes MIME::Types['text/plain'], 'text/plain'
56
+ assert_equal 1, MIME::Types['text/plain'].size
57
+ end
58
+
59
+ it 'can be searched with the complete flag' do
60
+ assert_empty MIME::Types[
61
+ 'application/x-www-form-urlencoded',
62
+ complete: true
63
+ ]
64
+ assert_includes MIME::Types['text/plain', complete: true], 'text/plain'
65
+ assert_equal 1, MIME::Types['text/plain', complete: true].size
66
+ end
67
+
68
+ it 'can be searched with the registered flag' do
69
+ assert_empty MIME::Types['application/x-wordperfect6.1', registered: true]
70
+ refute_empty MIME::Types[
71
+ 'application/x-www-form-urlencoded',
72
+ registered: true
73
+ ]
74
+ refute_empty MIME::Types[/gzip/, registered: true]
75
+ refute_equal MIME::Types[/gzip/], MIME::Types[/gzip/, registered: true]
76
+ end
77
+ end
78
+
79
+ describe '.type_for' do
80
+ it 'finds all types for a given extension' do
81
+ assert_equal %w(application/gzip application/x-gzip),
82
+ MIME::Types.type_for('gz')
83
+ end
84
+
85
+ it 'separates the extension from filenames' do
86
+ assert_equal %w(image/jpeg), MIME::Types.of(['foo.jpeg', 'bar.jpeg'])
87
+ end
88
+
89
+ it 'finds multiple extensions' do
90
+ assert_equal %w(image/jpeg text/plain),
91
+ MIME::Types.type_for(%w(foo.txt foo.jpeg))
92
+ end
93
+
94
+ it 'does not find unknown extensions' do
95
+ assert_empty MIME::Types.type_for('zzz')
96
+ end
97
+
98
+ it 'modifying type extensions causes reindexing' do
99
+ plain_text = MIME::Types['text/plain'].first
100
+ plain_text.add_extensions('xtxt')
101
+ assert_includes MIME::Types.type_for('xtxt'), 'text/plain'
102
+ end
103
+ end
104
+
105
+ describe '.count' do
106
+ it 'can count the number of types inside' do
107
+ assert MIME::Types.count > 999
108
+ end
109
+ end
110
+
111
+ describe '.add' do
112
+ def setup
113
+ MIME::Types.instance_variable_set(:@__types__, nil)
114
+ MIME::Types.send(:load_default_mime_types)
115
+ end
116
+
117
+ let(:eruby) { MIME::Type.new('application/x-eruby') }
118
+ let(:jinja) { MIME::Type.new('application/jinja2') }
119
+
120
+ it 'successfully adds a new type' do
121
+ MIME::Types.add(eruby)
122
+ assert_equal MIME::Types['application/x-eruby'], [eruby]
123
+ end
124
+
125
+ it 'complains about adding a duplicate type' do
126
+ MIME::Types.add(eruby)
127
+ assert_output '', /is already registered as a variant/ do
128
+ MIME::Types.add(eruby)
129
+ end
130
+ assert_equal MIME::Types['application/x-eruby'], [eruby]
131
+ end
132
+
133
+ it 'does not complain about adding a duplicate type when quiet' do
134
+ MIME::Types.add(eruby)
135
+ assert_silent do
136
+ MIME::Types.add(eruby, :silent)
137
+ end
138
+ assert_equal MIME::Types['application/x-eruby'], [eruby]
139
+ end
140
+
141
+ it 'successfully adds from an array' do
142
+ MIME::Types.add([eruby, jinja])
143
+ assert_equal MIME::Types['application/x-eruby'], [eruby]
144
+ assert_equal MIME::Types['application/jinja2'], [jinja]
145
+ end
146
+
147
+ it 'successfully adds from another MIME::Types' do
148
+ old_count = MIME::Types.count
149
+
150
+ mt = MIME::Types.new
151
+ mt.add(eruby)
152
+
153
+ MIME::Types.add(mt)
154
+ assert_equal old_count + 1, MIME::Types.count
155
+
156
+ assert_equal MIME::Types[eruby.content_type], [eruby]
157
+ end
158
+ end
159
+ end
@@ -0,0 +1,49 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'mime/types'
4
+ require 'minitest_helper'
5
+
6
+ describe MIME::Types, 'lazy loading' do
7
+ def setup
8
+ ENV['RUBY_MIME_TYPES_LAZY_LOAD'] = 'true'
9
+ end
10
+
11
+ def teardown
12
+ reset_mime_types
13
+ ENV.delete('RUBY_MIME_TYPES_LAZY_LOAD')
14
+ end
15
+
16
+ def reset_mime_types
17
+ MIME::Types.instance_variable_set(:@__types__, nil)
18
+ MIME::Types.send(:load_default_mime_types)
19
+ end
20
+
21
+ describe '.lazy_load?' do
22
+ it 'is true when RUBY_MIME_TYPES_LAZY_LOAD is set' do
23
+ assert_output '', /RUBY_MIME_TYPES_LAZY_LOAD/ do
24
+ assert_equal true, MIME::Types.send(:lazy_load?)
25
+ end
26
+ end
27
+
28
+ it 'is nil when RUBY_MIME_TYPES_LAZY_LOAD is unset' do
29
+ ENV['RUBY_MIME_TYPES_LAZY_LOAD'] = nil
30
+ assert_output '', '' do
31
+ assert_nil MIME::Types.send(:lazy_load?)
32
+ end
33
+ end
34
+
35
+ it 'is false when RUBY_MIME_TYPES_LAZY_LOAD is false' do
36
+ ENV['RUBY_MIME_TYPES_LAZY_LOAD'] = 'false'
37
+ assert_output '', /RUBY_MIME_TYPES_LAZY_LOAD/ do
38
+ assert_equal false, MIME::Types.send(:lazy_load?)
39
+ end
40
+ end
41
+ end
42
+
43
+ it 'loads lazily when RUBY_MIME_TYPES_LAZY_LOAD is set' do
44
+ MIME::Types.instance_variable_set(:@__types__, nil)
45
+ assert_nil MIME::Types.instance_variable_get(:@__types__)
46
+ refute_nil MIME::Types['text/html'].first
47
+ refute_nil MIME::Types.instance_variable_get(:@__types__)
48
+ end
49
+ end