sys-filesystem 1.3.4 → 1.4.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,344 @@
1
+ ####################################################################
2
+ # sys_filesystem_windows_spec.rb
3
+ #
4
+ # Specs for the Sys::Filesystem.stat method and related stuff.
5
+ # This should be run via the 'rake spec' task.
6
+ ####################################################################
7
+ require 'spec_helper'
8
+ require 'sys/filesystem'
9
+ require 'pathname'
10
+
11
+ RSpec.describe Sys::Filesystem, :windows => true do
12
+ let(:root) { 'C:/' }
13
+
14
+ before do
15
+ @stat = Sys::Filesystem.stat(root)
16
+ @size = 58720256
17
+ end
18
+
19
+ example "version number is set to the expected value" do
20
+ expect(Sys::Filesystem::VERSION).to eq('1.4.0')
21
+ expect(Sys::Filesystem::VERSION).to be_frozen
22
+ end
23
+
24
+ example "stat path works as expected" do
25
+ expect(@stat).to respond_to(:path)
26
+ expect(@stat.path).to eq(root)
27
+ end
28
+
29
+ example "stat block_size works as expected" do
30
+ expect(@stat).to respond_to(:block_size)
31
+ expect(@stat.block_size).to be_kind_of(Numeric)
32
+ end
33
+
34
+ example "stat works with or without trailing slash on standard paths" do
35
+ expect(Sys::Filesystem.stat("C:/").path).to eq("C:/")
36
+ expect(Sys::Filesystem.stat("C:/Users").path).to eq("C:/Users")
37
+ expect(Sys::Filesystem.stat("C:/Users/").path).to eq("C:/Users/")
38
+ expect(Sys::Filesystem.stat("C:/Users/").path).to eq("C:/Users/")
39
+ end
40
+
41
+ example "stat works with or without trailing slash on UNC paths" do
42
+ expect(Sys::Filesystem.stat("//127.0.0.1/C$").path).to eq("//127.0.0.1/C$")
43
+ expect(Sys::Filesystem.stat("//127.0.0.1/C$/").path).to eq("//127.0.0.1/C$/")
44
+ expect(Sys::Filesystem.stat("\\\\127.0.0.1\\C$").path).to eq("\\\\127.0.0.1\\C$")
45
+ expect(Sys::Filesystem.stat("\\\\127.0.0.1\\C$\\").path).to eq("\\\\127.0.0.1\\C$\\")
46
+ end
47
+
48
+ example "stat fragment_size works as expected" do
49
+ expect(@stat).to respond_to(:fragment_size)
50
+ expect(@stat.fragment_size).to be_nil
51
+ end
52
+
53
+ example "stat blocks works as expected" do
54
+ expect(@stat).to respond_to(:blocks)
55
+ expect(@stat.blocks).to be_kind_of(Numeric)
56
+ end
57
+
58
+ example "stat blocks_free works as expected" do
59
+ expect(@stat).to respond_to(:blocks_free)
60
+ expect(@stat.blocks_free).to be_kind_of(Numeric)
61
+ end
62
+
63
+ example "stat blocks_available works as expected" do
64
+ expect(@stat).to respond_to(:blocks_available)
65
+ expect(@stat.blocks_available).to be_kind_of(Numeric)
66
+ end
67
+
68
+ example "block stats return expected relative values" do
69
+ expect(@stat.blocks >= @stat.blocks_free).to be true
70
+ expect(@stat.blocks_free >= @stat.blocks_available).to be true
71
+ end
72
+
73
+ example "stat files works as expected" do
74
+ expect(@stat).to respond_to(:files)
75
+ expect(@stat.files).to be_nil
76
+ end
77
+
78
+ example "stat inodes is an alias for files" do
79
+ expect(@stat.method(:inodes)).to eq(@stat.method(:files))
80
+ end
81
+
82
+ example "stat files_free works as expected" do
83
+ expect(@stat).to respond_to(:files_free)
84
+ expect(@stat.files_free).to be_nil
85
+ end
86
+
87
+ example "stat inodes_free is an alias for files_free" do
88
+ expect(@stat).to respond_to(:inodes_free)
89
+ end
90
+
91
+ example "stat files available works as expected" do
92
+ expect(@stat).to respond_to(:files_available)
93
+ expect(@stat.files_available).to be_nil
94
+ end
95
+
96
+ example "stat inodes_available is an alias for files_available" do
97
+ expect(@stat.method(:inodes_available)).to eq(@stat.method(:files_available))
98
+ end
99
+
100
+ example "stat filesystem_id works as expected" do
101
+ expect(@stat).to respond_to(:filesystem_id)
102
+ expect(@stat.filesystem_id).to be_kind_of(Integer)
103
+ end
104
+
105
+ example "stat flags works as expected" do
106
+ expect(@stat).to respond_to(:flags)
107
+ expect(@stat.flags).to be_kind_of(Numeric)
108
+ end
109
+
110
+ example "stat name_max works as expected" do
111
+ expect(@stat).to respond_to(:name_max)
112
+ expect(@stat.name_max).to be_kind_of(Numeric)
113
+ end
114
+
115
+ example "stat base_type works as expected" do
116
+ expect(@stat).to respond_to(:base_type)
117
+ expect(@stat.base_type).to be_kind_of(String)
118
+ end
119
+
120
+ example "stat bytes_total basic functionality" do
121
+ expect(@stat).to respond_to(:bytes_total)
122
+ expect(@stat.bytes_total).to be_kind_of(Numeric)
123
+ end
124
+
125
+ example "stat bytes_free basic functionality" do
126
+ expect(@stat).to respond_to(:bytes_free)
127
+ expect(@stat.bytes_free).to be_kind_of(Numeric)
128
+ expect(@stat.blocks_free * @stat.block_size).to eq(@stat.bytes_free)
129
+ end
130
+
131
+ example "stat bytes_available basic functionality" do
132
+ expect(@stat).to respond_to(:bytes_available)
133
+ expect(@stat.bytes_available).to be_kind_of(Numeric)
134
+ expect(@stat.blocks_available * @stat.block_size).to eq(@stat.bytes_available)
135
+ end
136
+
137
+ example "stat bytes_used basic functionality" do
138
+ expect(@stat).to respond_to(:bytes_used)
139
+ expect(@stat.bytes_used).to be_kind_of(Numeric)
140
+ end
141
+
142
+ example "stat percent_used basic functionality" do
143
+ expect(@stat).to respond_to(:percent_used)
144
+ expect(@stat.percent_used).to be_kind_of(Float)
145
+ end
146
+
147
+ example "case_insensitive returns expected result" do
148
+ expect(@stat).to respond_to(:case_insensitive?)
149
+ expect(@stat.case_insensitive?).to eq(true)
150
+ end
151
+
152
+ context "Filesystem.stat(Pathname)" do
153
+ before do
154
+ @stat_pathname = Sys::Filesystem.stat(Pathname.new(root))
155
+ end
156
+
157
+ example "stat with Pathname argument works as expected" do
158
+ expect(@stat_pathname.class).to eq(@stat.class)
159
+ expect(@stat_pathname.path).to eq(@stat.path)
160
+ expect(@stat_pathname.block_size).to eq(@stat.block_size)
161
+ expect(@stat_pathname.fragment_size).to eq(@stat.fragment_size)
162
+ expect(@stat_pathname.blocks).to eq(@stat.blocks)
163
+ expect(@stat_pathname.blocks_free).to eq(@stat.blocks_free)
164
+ expect(@stat_pathname.blocks_available).to eq(@stat.blocks_available)
165
+ expect(@stat_pathname.files).to eq(@stat.files)
166
+ expect(@stat_pathname.files_free).to eq(@stat.files_free)
167
+ expect(@stat_pathname.files_available).to eq(@stat.files_available)
168
+ expect(@stat_pathname.filesystem_id).to eq(@stat.filesystem_id)
169
+ expect(@stat_pathname.flags).to eq(@stat.flags)
170
+ expect(@stat_pathname.name_max).to eq(@stat.name_max)
171
+ expect(@stat_pathname.base_type).to eq(@stat.base_type)
172
+ end
173
+ end
174
+
175
+ context "Filesystem.stat(Dir)" do
176
+ before do
177
+ @stat_dir = Dir.open(root){ |dir| Sys::Filesystem.stat(dir) }
178
+ end
179
+
180
+ example "stat with Dir argument works as expected" do
181
+ expect( @stat_dir.class).to eq(@stat.class)
182
+ expect( @stat_dir.path).to eq(@stat.path)
183
+ expect( @stat_dir.block_size).to eq(@stat.block_size)
184
+ expect( @stat_dir.fragment_size).to eq(@stat.fragment_size)
185
+ expect( @stat_dir.blocks).to eq(@stat.blocks)
186
+ expect( @stat_dir.blocks_free).to eq(@stat.blocks_free)
187
+ expect( @stat_dir.blocks_available).to eq(@stat.blocks_available)
188
+ expect( @stat_dir.files).to eq(@stat.files)
189
+ expect( @stat_dir.files_free).to eq(@stat.files_free)
190
+ expect( @stat_dir.files_available).to eq(@stat.files_available)
191
+ expect( @stat_dir.filesystem_id).to eq(@stat.filesystem_id)
192
+ expect( @stat_dir.flags).to eq(@stat.flags)
193
+ expect( @stat_dir.name_max).to eq(@stat.name_max)
194
+ expect( @stat_dir.base_type).to eq(@stat.base_type)
195
+ end
196
+ end
197
+
198
+ context "mount_point" do
199
+ example "mount_point singleton method basic functionality" do
200
+ expect(Sys::Filesystem).to respond_to(:mount_point)
201
+ expect{ Sys::Filesystem.mount_point(Dir.pwd) }.not_to raise_error
202
+ expect(Sys::Filesystem.mount_point(Dir.pwd)).to be_kind_of(String)
203
+ end
204
+
205
+ example "mount_point singleton method returns expected value" do
206
+ expect(Sys::Filesystem.mount_point("C:\\Users\\foo")).to eq("C:\\")
207
+ expect(Sys::Filesystem.mount_point("//foo/bar/baz")).to eq("\\\\foo\\bar")
208
+ end
209
+
210
+ example "mount_point works with Pathname object" do
211
+ expect{ Sys::Filesystem.mount_point(Pathname.new("C:/Users/foo")) }.not_to raise_error
212
+ expect(Sys::Filesystem.mount_point("C:\\Users\\foo")).to eq("C:\\")
213
+ expect(Sys::Filesystem.mount_point("//foo/bar/baz")).to eq("\\\\foo\\bar")
214
+ end
215
+ end
216
+
217
+ example "filesystem constants are defined" do
218
+ expect(Sys::Filesystem::CASE_SENSITIVE_SEARCH).not_to be_nil
219
+ expect(Sys::Filesystem::CASE_PRESERVED_NAMES).not_to be_nil
220
+ expect(Sys::Filesystem::UNICODE_ON_DISK).not_to be_nil
221
+ expect(Sys::Filesystem::PERSISTENT_ACLS).not_to be_nil
222
+ expect(Sys::Filesystem::FILE_COMPRESSION).not_to be_nil
223
+ expect(Sys::Filesystem::VOLUME_QUOTAS).not_to be_nil
224
+ expect(Sys::Filesystem::SUPPORTS_SPARSE_FILES).not_to be_nil
225
+ expect(Sys::Filesystem::SUPPORTS_REPARSE_POINTS).not_to be_nil
226
+ expect(Sys::Filesystem::SUPPORTS_REMOTE_STORAGE).not_to be_nil
227
+ expect(Sys::Filesystem::VOLUME_IS_COMPRESSED).not_to be_nil
228
+ expect(Sys::Filesystem::SUPPORTS_OBJECT_IDS).not_to be_nil
229
+ expect(Sys::Filesystem::SUPPORTS_ENCRYPTION).not_to be_nil
230
+ expect(Sys::Filesystem::NAMED_STREAMS).not_to be_nil
231
+ expect(Sys::Filesystem::READ_ONLY_VOLUME).not_to be_nil
232
+ end
233
+
234
+ example "stat singleton method defaults to root path if proviced" do
235
+ expect{ Sys::Filesystem.stat("C://Program Files") }.not_to raise_error
236
+ end
237
+
238
+ example "stat singleton method accepts a Pathname object" do
239
+ expect{ Sys::Filesystem.stat(Pathname.new("C://Program Files")) }.not_to raise_error
240
+ end
241
+
242
+ example "stat singleton method requires a single argument" do
243
+ expect{ Sys::Filesystem.stat }.to raise_error(ArgumentError)
244
+ expect{ Sys::Filesystem.stat(Dir.pwd, Dir.pwd) }.to raise_error(ArgumentError)
245
+ end
246
+
247
+ example "stat singleton method raises an error if path is not found" do
248
+ expect{ Sys::Filesystem.stat("C://Bogus//Dir") }.to raise_error(Errno::ESRCH)
249
+ end
250
+
251
+ context "Filesystem::Mount" do
252
+ let(:mount){ Sys::Filesystem.mounts[0] }
253
+
254
+ before do
255
+ @array = []
256
+ end
257
+
258
+ example "mount singleton method exists" do
259
+ expect(Sys::Filesystem).to respond_to(:mount)
260
+ end
261
+
262
+ example "umount singleton method exists" do
263
+ expect(Sys::Filesystem).to respond_to(:umount)
264
+ end
265
+
266
+ example "mounts singleton method basic functionality" do
267
+ expect(Sys::Filesystem).to respond_to(:mounts)
268
+ expect{ Sys::Filesystem.mounts }.not_to raise_error
269
+ expect{ Sys::Filesystem.mounts{}.not_to raise_error }
270
+ end
271
+
272
+ example "mounts singleton method returns the expected value" do
273
+ expect(Sys::Filesystem.mounts).to be_kind_of(Array)
274
+ expect(Sys::Filesystem.mounts[0]).to be_kind_of(Sys::Filesystem::Mount)
275
+ end
276
+
277
+ example "mounts singleton method works as expected when a block is provided" do
278
+ expect(Sys::Filesystem.mounts{}).to be_nil
279
+ expect{ Sys::Filesystem.mounts{ |mt| @array << mt } }.not_to raise_error
280
+ expect(@array[0]).to be_kind_of(Sys::Filesystem::Mount)
281
+ end
282
+
283
+ example "mount name works as expected" do
284
+ expect(mount).to respond_to(:name)
285
+ expect(mount.name).to be_kind_of(String)
286
+ end
287
+
288
+ example "mount_time works as expected" do
289
+ expect(mount).to respond_to(:mount_time)
290
+ expect(mount.mount_time).to be_kind_of(Time)
291
+ end
292
+
293
+ example "mount type works as expected" do
294
+ expect(mount).to respond_to(:mount_type)
295
+ expect(mount.mount_type).to be_kind_of(String)
296
+ end
297
+
298
+ example "mount point works as expected" do
299
+ expect(mount).to respond_to(:mount_point)
300
+ expect(mount.mount_point).to be_kind_of(String)
301
+ end
302
+
303
+ example "mount options works as expected" do
304
+ expect(mount).to respond_to(:options)
305
+ expect(mount.options).to be_kind_of(String)
306
+ end
307
+
308
+ example "mount pass_number works as expected" do
309
+ expect(mount).to respond_to(:pass_number)
310
+ expect(mount.pass_number).to be_nil
311
+ end
312
+
313
+ example "mount frequency works as expected" do
314
+ expect(mount).to respond_to(:frequency)
315
+ expect(mount.frequency).to be_nil
316
+ end
317
+
318
+ example "mounts singleton method does not accept any arguments" do
319
+ expect{ Sys::Filesystem.mounts("C:\\") }.to raise_error(ArgumentError)
320
+ end
321
+ end
322
+
323
+ example "custom Numeric#to_kb method works as expected" do
324
+ expect(@size).to respond_to(:to_kb)
325
+ expect(@size.to_kb).to eq(57344)
326
+ end
327
+
328
+ example "custom Numeric#to_mb method works as expected" do
329
+ expect(@size).to respond_to(:to_mb)
330
+ expect(@size.to_mb).to eq(56)
331
+ end
332
+
333
+ example "custom Numeric#to_gb method works as expected" do
334
+ expect(@size).to respond_to(:to_gb)
335
+ expect(@size.to_gb).to eq(0)
336
+ end
337
+
338
+ context "FFI" do
339
+ example "internal ffi functions are not public" do
340
+ expect(Sys::Filesystem.methods.include?(:GetVolumeInformationA)).to eq(false)
341
+ expect(Sys::Filesystem.instance_methods.include?(:GetVolumeInformationA)).to eq(false)
342
+ end
343
+ end
344
+ end
@@ -2,27 +2,25 @@ require 'rubygems'
2
2
 
3
3
  Gem::Specification.new do |spec|
4
4
  spec.name = 'sys-filesystem'
5
- spec.version = '1.3.4'
5
+ spec.version = '1.4.0'
6
6
  spec.author = 'Daniel J. Berger'
7
7
  spec.email = 'djberg96@gmail.com'
8
8
  spec.homepage = 'https://github.com/djberg96/sys-filesystem'
9
9
  spec.summary = 'A Ruby interface for getting file system information.'
10
10
  spec.license = 'Apache-2.0'
11
- spec.test_files = Dir['test/*.rb']
11
+ spec.test_files = Dir['spec/*_spec.rb']
12
12
  spec.files = Dir['**/*'].reject{ |f| f.include?('git') }
13
13
  spec.cert_chain = Dir['certs/*']
14
14
 
15
- spec.extra_rdoc_files = Dir['*.rdoc']
16
-
17
- spec.add_dependency('ffi')
15
+ spec.add_dependency('ffi', '~> 1.1')
16
+ spec.add_development_dependency('mkmf-lite', '~> 0.4')
18
17
  spec.add_development_dependency('rake')
19
- spec.add_development_dependency('test-unit', '~> 3.3')
20
- spec.add_development_dependency('mkmf-lite', '~> 0.3')
18
+ spec.add_development_dependency('rspec', '~> 3.9')
21
19
 
22
20
  spec.metadata = {
23
21
  'homepage_uri' => 'https://github.com/djberg96/sys-filesystem',
24
22
  'bug_tracker_uri' => 'https://github.com/djberg96/sys-filesystem/issues',
25
- 'changelog_uri' => 'https://github.com/djberg96/sys-filesystem/blob/ffi/CHANGES',
23
+ 'changelog_uri' => 'https://github.com/djberg96/sys-filesystem/blob/ffi/CHANGES.rdoc',
26
24
  'documentation_uri' => 'https://github.com/djberg96/sys-filesystem/wiki',
27
25
  'source_code_uri' => 'https://github.com/djberg96/sys-filesystem',
28
26
  'wiki_uri' => 'https://github.com/djberg96/sys-filesystem/wiki'
metadata CHANGED
@@ -1,11 +1,11 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: sys-filesystem
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.3.4
4
+ version: 1.4.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Daniel J. Berger
8
- autorequire:
8
+ autorequire:
9
9
  bindir: bin
10
10
  cert_chain:
11
11
  - |
@@ -35,119 +35,106 @@ cert_chain:
35
35
  ORVCZpRuCPpmC8qmqxUnARDArzucjaclkxjLWvCVHeFa9UP7K3Nl9oTjJNv+7/jM
36
36
  WZs4eecIcUc4tKdHxcAJ0MO/Dkqq7hGaiHpwKY76wQ1+8xAh
37
37
  -----END CERTIFICATE-----
38
- date:
38
+ date: 2020-11-06 00:00:00.000000000 Z
39
39
  dependencies:
40
40
  - !ruby/object:Gem::Dependency
41
41
  name: ffi
42
42
  requirement: !ruby/object:Gem::Requirement
43
43
  requirements:
44
- - - ">="
44
+ - - "~>"
45
45
  - !ruby/object:Gem::Version
46
- version: '0'
46
+ version: '1.1'
47
47
  type: :runtime
48
48
  prerelease: false
49
49
  version_requirements: !ruby/object:Gem::Requirement
50
50
  requirements:
51
- - - ">="
51
+ - - "~>"
52
52
  - !ruby/object:Gem::Version
53
- version: '0'
53
+ version: '1.1'
54
54
  - !ruby/object:Gem::Dependency
55
- name: rake
55
+ name: mkmf-lite
56
56
  requirement: !ruby/object:Gem::Requirement
57
57
  requirements:
58
- - - ">="
58
+ - - "~>"
59
59
  - !ruby/object:Gem::Version
60
- version: '0'
60
+ version: '0.4'
61
61
  type: :development
62
62
  prerelease: false
63
63
  version_requirements: !ruby/object:Gem::Requirement
64
64
  requirements:
65
- - - ">="
65
+ - - "~>"
66
66
  - !ruby/object:Gem::Version
67
- version: '0'
67
+ version: '0.4'
68
68
  - !ruby/object:Gem::Dependency
69
- name: test-unit
69
+ name: rake
70
70
  requirement: !ruby/object:Gem::Requirement
71
71
  requirements:
72
- - - "~>"
72
+ - - ">="
73
73
  - !ruby/object:Gem::Version
74
- version: '3.3'
74
+ version: '0'
75
75
  type: :development
76
76
  prerelease: false
77
77
  version_requirements: !ruby/object:Gem::Requirement
78
78
  requirements:
79
- - - "~>"
79
+ - - ">="
80
80
  - !ruby/object:Gem::Version
81
- version: '3.3'
81
+ version: '0'
82
82
  - !ruby/object:Gem::Dependency
83
- name: mkmf-lite
83
+ name: rspec
84
84
  requirement: !ruby/object:Gem::Requirement
85
85
  requirements:
86
86
  - - "~>"
87
87
  - !ruby/object:Gem::Version
88
- version: '0.3'
88
+ version: '3.9'
89
89
  type: :development
90
90
  prerelease: false
91
91
  version_requirements: !ruby/object:Gem::Requirement
92
92
  requirements:
93
93
  - - "~>"
94
94
  - !ruby/object:Gem::Version
95
- version: '0.3'
95
+ version: '3.9'
96
96
  description: |2
97
97
  The sys-filesystem library provides a cross-platform interface for
98
98
  gathering filesystem information, such as disk space and mount point data.
99
99
  email: djberg96@gmail.com
100
100
  executables: []
101
101
  extensions: []
102
- extra_rdoc_files:
103
- - CHANGES.rdoc
104
- - MANIFEST.rdoc
105
- - README.rdoc
102
+ extra_rdoc_files: []
106
103
  files:
104
+ - CHANGES.md
105
+ - Gemfile
107
106
  - LICENSE
108
- - test
109
- - test/test_sys_filesystem_windows.rb
110
- - test/test_sys_filesystem_unix.rb
111
- - test/test_sys_filesystem.rb
107
+ - MANIFEST.md
108
+ - README.md
112
109
  - Rakefile
113
- - sys-filesystem.gemspec
114
- - certs
115
110
  - certs/djberg96_pub.pem
116
- - examples
117
- - examples/example_stat.rb
118
111
  - examples/example_mount.rb
119
- - lib
112
+ - examples/example_stat.rb
120
113
  - lib/sys-filesystem.rb
121
- - lib/sys
122
- - lib/sys/unix
123
- - lib/sys/unix/sys
124
- - lib/sys/unix/sys/filesystem
125
- - lib/sys/unix/sys/filesystem/structs.rb
114
+ - lib/sys/filesystem.rb
115
+ - lib/sys/unix/sys/filesystem.rb
126
116
  - lib/sys/unix/sys/filesystem/constants.rb
127
117
  - lib/sys/unix/sys/filesystem/functions.rb
128
- - lib/sys/unix/sys/filesystem.rb
129
- - lib/sys/filesystem.rb
130
- - lib/sys/windows
131
- - lib/sys/windows/sys
132
- - lib/sys/windows/sys/filesystem
133
- - lib/sys/windows/sys/filesystem/helper.rb
118
+ - lib/sys/unix/sys/filesystem/structs.rb
119
+ - lib/sys/windows/sys/filesystem.rb
134
120
  - lib/sys/windows/sys/filesystem/constants.rb
135
121
  - lib/sys/windows/sys/filesystem/functions.rb
136
- - lib/sys/windows/sys/filesystem.rb
137
- - CHANGES.rdoc
138
- - MANIFEST.rdoc
139
- - README.rdoc
122
+ - lib/sys/windows/sys/filesystem/helper.rb
123
+ - spec/spec_helper.rb
124
+ - spec/sys_filesystem_unix_spec.rb
125
+ - spec/sys_filesystem_windows_spec.rb
126
+ - sys-filesystem.gemspec
140
127
  homepage: https://github.com/djberg96/sys-filesystem
141
128
  licenses:
142
129
  - Apache-2.0
143
130
  metadata:
144
131
  homepage_uri: https://github.com/djberg96/sys-filesystem
145
132
  bug_tracker_uri: https://github.com/djberg96/sys-filesystem/issues
146
- changelog_uri: https://github.com/djberg96/sys-filesystem/blob/ffi/CHANGES
133
+ changelog_uri: https://github.com/djberg96/sys-filesystem/blob/ffi/CHANGES.rdoc
147
134
  documentation_uri: https://github.com/djberg96/sys-filesystem/wiki
148
135
  source_code_uri: https://github.com/djberg96/sys-filesystem
149
136
  wiki_uri: https://github.com/djberg96/sys-filesystem/wiki
150
- post_install_message:
137
+ post_install_message:
151
138
  rdoc_options: []
152
139
  require_paths:
153
140
  - lib
@@ -162,11 +149,10 @@ required_rubygems_version: !ruby/object:Gem::Requirement
162
149
  - !ruby/object:Gem::Version
163
150
  version: '0'
164
151
  requirements: []
165
- rubygems_version: 3.0.6
166
- signing_key:
152
+ rubygems_version: 3.1.4
153
+ signing_key:
167
154
  specification_version: 4
168
155
  summary: A Ruby interface for getting file system information.
169
156
  test_files:
170
- - test/test_sys_filesystem_windows.rb
171
- - test/test_sys_filesystem_unix.rb
172
- - test/test_sys_filesystem.rb
157
+ - spec/sys_filesystem_windows_spec.rb
158
+ - spec/sys_filesystem_unix_spec.rb