mime-types 3.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -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