ptools 1.3.3-universal-mingw32 → 1.4.1-universal-mingw32
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.
- checksums.yaml +5 -5
- checksums.yaml.gz.sig +3 -1
- data.tar.gz.sig +0 -0
- data/{CHANGES → CHANGES.md} +61 -29
- data/Gemfile +1 -1
- data/MANIFEST.md +27 -0
- data/{README → README.md} +30 -26
- data/Rakefile +32 -80
- data/certs/djberg96_pub.pem +22 -17
- data/lib/ptools.rb +32 -38
- data/ptools.gemspec +15 -9
- data/spec/binary_spec.rb +59 -0
- data/spec/constants_spec.rb +33 -0
- data/spec/head_spec.rb +41 -0
- data/spec/image_spec.rb +51 -0
- data/{test → spec}/img/test.gif +0 -0
- data/spec/img/test.ico +0 -0
- data/{test → spec}/img/test.jpg +0 -0
- data/{test → spec}/img/test.png +0 -0
- data/spec/nlconvert_spec.rb +104 -0
- data/spec/sparse_spec.rb +43 -0
- data/spec/tail_spec.rb +107 -0
- data/spec/touch_spec.rb +47 -0
- data/{.gemtest → spec/txt/empty.txt} +0 -0
- data/{test → spec}/txt/english.txt +0 -0
- data/spec/txt/english.utf16 +0 -0
- data/{test → spec}/txt/korean.txt +0 -0
- data/spec/wc_spec.rb +65 -0
- data/spec/whereis_spec.rb +87 -0
- data/spec/which_spec.rb +112 -0
- metadata +64 -68
- metadata.gz.sig +0 -0
- data/MANIFEST +0 -20
- data/test/test_binary.rb +0 -65
- data/test/test_constants.rb +0 -38
- data/test/test_head.rb +0 -48
- data/test/test_image.rb +0 -57
- data/test/test_is_sparse.rb +0 -53
- data/test/test_nlconvert.rb +0 -110
- data/test/test_null.rb +0 -40
- data/test/test_tail.rb +0 -124
- data/test/test_touch.rb +0 -53
- data/test/test_wc.rb +0 -73
- data/test/test_whereis.rb +0 -98
- data/test/test_which.rb +0 -126
data/certs/djberg96_pub.pem
CHANGED
@@ -1,21 +1,26 @@
|
|
1
1
|
-----BEGIN CERTIFICATE-----
|
2
|
-
|
2
|
+
MIIEcDCCAtigAwIBAgIBATANBgkqhkiG9w0BAQsFADA/MREwDwYDVQQDDAhkamJl
|
3
3
|
cmc5NjEVMBMGCgmSJomT8ixkARkWBWdtYWlsMRMwEQYKCZImiZPyLGQBGRYDY29t
|
4
|
-
|
4
|
+
MB4XDTE4MDMxODE1MjIwN1oXDTI4MDMxNTE1MjIwN1owPzERMA8GA1UEAwwIZGpi
|
5
5
|
ZXJnOTYxFTATBgoJkiaJk/IsZAEZFgVnbWFpbDETMBEGCgmSJomT8ixkARkWA2Nv
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
6
|
+
bTCCAaIwDQYJKoZIhvcNAQEBBQADggGPADCCAYoCggGBALgfaroVM6CI06cxr0/h
|
7
|
+
A+j+pc8fgpRgBVmHFaFunq28GPC3IvW7Nvc3Y8SnAW7pP1EQIbhlwRIaQzJ93/yj
|
8
|
+
u95KpkP7tA9erypnV7dpzBkzNlX14ACaFD/6pHoXoe2ltBxk3CCyyzx70mTqJpph
|
9
|
+
75IB03ni9a8yqn8pmse+s83bFJOAqddSj009sGPcQO+QOWiNxqYv1n5EHcvj2ebO
|
10
|
+
6hN7YTmhx7aSia4qL/quc4DlIaGMWoAhvML7u1fmo53CYxkKskfN8MOecq2vfEmL
|
11
|
+
iLu+SsVVEAufMDDFMXMJlvDsviolUSGMSNRTujkyCcJoXKYYxZSNtIiyd9etI0X3
|
12
|
+
ctu0uhrFyrMZXCedutvXNjUolD5r9KGBFSWH1R9u2I3n3SAyFF2yzv/7idQHLJJq
|
13
|
+
74BMnx0FIq6fCpu5slAipvxZ3ZkZpEXZFr3cIBtO1gFvQWW7E/Y3ijliWJS1GQFq
|
14
|
+
058qERadHGu1yu1dojmFRo6W2KZvY9al2yIlbkpDrD5MYQIDAQABo3cwdTAJBgNV
|
15
|
+
HRMEAjAAMAsGA1UdDwQEAwIEsDAdBgNVHQ4EFgQUFZsMapgzJimzsbaBG2Tm8j5e
|
16
|
+
AzgwHQYDVR0RBBYwFIESZGpiZXJnOTZAZ21haWwuY29tMB0GA1UdEgQWMBSBEmRq
|
17
|
+
YmVyZzk2QGdtYWlsLmNvbTANBgkqhkiG9w0BAQsFAAOCAYEAW2tnYixXQtKxgGXq
|
18
|
+
/3iSWG2bLwvxS4go3srO+aRXZHrFUMlJ5W0mCxl03aazxxKTsVVpZD8QZxvK91OQ
|
19
|
+
h9zr9JBYqCLcCVbr8SkmYCi/laxIZxsNE5YI8cC8vvlLI7AMgSfPSnn/Epq1GjGY
|
20
|
+
6L1iRcEDtanGCIvjqlCXO9+BmsnCfEVehqZkQHeYczA03tpOWb6pon2wzvMKSsKH
|
21
|
+
ks0ApVdstSLz1kzzAqem/uHdG9FyXdbTAwH1G4ZPv69sQAFAOCgAqYmdnzedsQtE
|
22
|
+
1LQfaQrx0twO+CZJPcRLEESjq8ScQxWRRkfuh2VeR7cEU7L7KqT10mtUwrvw7APf
|
23
|
+
DYoeCY9KyjIBjQXfbj2ke5u1hZj94Fsq9FfbEQg8ygCgwThnmkTrrKEiMSs3alYR
|
24
|
+
ORVCZpRuCPpmC8qmqxUnARDArzucjaclkxjLWvCVHeFa9UP7K3Nl9oTjJNv+7/jM
|
25
|
+
WZs4eecIcUc4tKdHxcAJ0MO/Dkqq7hGaiHpwKY76wQ1+8xAh
|
21
26
|
-----END CERTIFICATE-----
|
data/lib/ptools.rb
CHANGED
@@ -3,7 +3,7 @@ require 'win32/file' if File::ALT_SEPARATOR
|
|
3
3
|
|
4
4
|
class File
|
5
5
|
# The version of the ptools library.
|
6
|
-
PTOOLS_VERSION = '1.
|
6
|
+
PTOOLS_VERSION = '1.4.1'.freeze
|
7
7
|
|
8
8
|
# :stopdoc:
|
9
9
|
|
@@ -23,8 +23,8 @@ class File
|
|
23
23
|
|
24
24
|
# :startdoc:
|
25
25
|
|
26
|
-
# Returns whether or not the file is an image. Only JPEG, PNG, BMP
|
27
|
-
# GIF are checked against.
|
26
|
+
# Returns whether or not the file is an image. Only JPEG, PNG, BMP,
|
27
|
+
# GIF, and ICO are checked against.
|
28
28
|
#
|
29
29
|
# This method does some simple read and extension checks. For a version
|
30
30
|
# that is more robust, but which depends on a 3rd party C library (and is
|
@@ -39,46 +39,20 @@ class File
|
|
39
39
|
# http://en.wikipedia.org/wiki/Magic_number_(programming)
|
40
40
|
#
|
41
41
|
def self.image?(file)
|
42
|
-
bool = IMAGE_EXT.include?(File.extname(file).downcase)
|
43
|
-
bool = bmp?(file) || jpg?(file) || png?(file) || gif?(file) || tiff?(file)
|
42
|
+
bool = IMAGE_EXT.include?(File.extname(file).downcase)
|
43
|
+
bool = bmp?(file) || jpg?(file) || png?(file) || gif?(file) || tiff?(file) || ico?(file)
|
44
44
|
bool
|
45
45
|
end
|
46
46
|
|
47
|
-
# Returns the name of the null device (aka bitbucket) on your platform.
|
48
|
-
#
|
49
|
-
# Examples:
|
50
|
-
#
|
51
|
-
# # On Linux
|
52
|
-
# File.null # => '/dev/null'
|
53
|
-
#
|
54
|
-
# # On MS Windows
|
55
|
-
# File.null # => 'NUL'
|
56
|
-
#--
|
57
|
-
# The values I used here are based on information from
|
58
|
-
# http://en.wikipedia.org/wiki//dev/null
|
59
|
-
#
|
60
|
-
def self.null
|
61
|
-
case RbConfig::CONFIG['host_os']
|
62
|
-
when /mswin|win32|msdos|mingw|windows/i
|
63
|
-
'NUL'
|
64
|
-
when /amiga/i
|
65
|
-
'NIL:'
|
66
|
-
when /openvms/i
|
67
|
-
'NL:'
|
68
|
-
else
|
69
|
-
'/dev/null'
|
70
|
-
end
|
71
|
-
end
|
72
|
-
|
73
|
-
class << self
|
74
|
-
alias null_device null
|
75
|
-
end
|
76
|
-
|
77
47
|
# Returns whether or not +file+ is a binary non-image file, i.e. executable,
|
78
48
|
# shared object, ect. Note that this is NOT guaranteed to be 100% accurate.
|
79
49
|
# It performs a "best guess" based on a simple test of the first
|
80
50
|
# +File.blksize+ characters, or 4096, whichever is smaller.
|
81
51
|
#
|
52
|
+
# By default it will check to see if more than 30 percent of the characters
|
53
|
+
# are non-text characters. If so, the method returns true. You can configure
|
54
|
+
# this percentage by passing your own as a second argument.
|
55
|
+
#
|
82
56
|
# Example:
|
83
57
|
#
|
84
58
|
# File.binary?('somefile.exe') # => true
|
@@ -87,13 +61,15 @@ class File
|
|
87
61
|
# Based on code originally provided by Ryan Davis (which, in turn, is
|
88
62
|
# based on Perl's -B switch).
|
89
63
|
#
|
90
|
-
def self.binary?(file)
|
64
|
+
def self.binary?(file, percentage = 0.30)
|
65
|
+
return false if File.stat(file).zero?
|
91
66
|
return false if image?(file)
|
67
|
+
return false if check_bom?(file)
|
92
68
|
bytes = File.stat(file).blksize
|
93
69
|
bytes = 4096 if bytes > 4096
|
94
70
|
s = (File.read(file, bytes) || "")
|
95
71
|
s = s.encode('US-ASCII', :undef => :replace).split(//)
|
96
|
-
((s.size - s.grep(" ".."~").size) / s.size.to_f) >
|
72
|
+
((s.size - s.grep(" ".."~").size) / s.size.to_f) > percentage
|
97
73
|
end
|
98
74
|
|
99
75
|
# Looks for the first occurrence of +program+ within +path+.
|
@@ -428,6 +404,20 @@ class File
|
|
428
404
|
|
429
405
|
private
|
430
406
|
|
407
|
+
# Returns whether or not the given +text+ contains a BOM marker.
|
408
|
+
# If present, we can generally assume it's a text file.
|
409
|
+
#
|
410
|
+
def self.check_bom?(file)
|
411
|
+
text = File.read(file, 4).force_encoding('utf-8')
|
412
|
+
|
413
|
+
bool = false
|
414
|
+
bool = true if text[0,3] == "\xEF\xBB\xBF"
|
415
|
+
bool = true if text[0,4] == "\x00\x00\xFE\xFF" || text[0,4] == "\xFF\xFE\x00\x00"
|
416
|
+
bool = true if text[0,2] == "\xFF\xFE" || text[0,2] == "\xFE\xFF"
|
417
|
+
|
418
|
+
bool
|
419
|
+
end
|
420
|
+
|
431
421
|
def self.nl_for_platform(platform)
|
432
422
|
platform = RbConfig::CONFIG["host_os"] if platform == 'local'
|
433
423
|
|
@@ -465,7 +455,7 @@ class File
|
|
465
455
|
bytes = IO.read(file, 4)
|
466
456
|
|
467
457
|
# II is Intel, MM is Motorola
|
468
|
-
if bytes[0..1] != 'II'&& bytes[0..1] != 'MM'
|
458
|
+
if bytes[0..1] != 'II' && bytes[0..1] != 'MM'
|
469
459
|
return false
|
470
460
|
end
|
471
461
|
|
@@ -479,4 +469,8 @@ class File
|
|
479
469
|
|
480
470
|
true
|
481
471
|
end
|
472
|
+
|
473
|
+
def self.ico?(file)
|
474
|
+
["\000\000\001\000", "\000\000\002\000"].include?(IO.read(file, 4, nil, :encoding => 'binary'))
|
475
|
+
end
|
482
476
|
end
|
data/ptools.gemspec
CHANGED
@@ -1,31 +1,37 @@
|
|
1
|
-
require 'rubygems'
|
2
1
|
require 'rbconfig'
|
3
2
|
|
4
3
|
Gem::Specification.new do |spec|
|
5
4
|
spec.name = 'ptools'
|
6
|
-
spec.version = '1.
|
7
|
-
spec.license = 'Artistic
|
5
|
+
spec.version = '1.4.1'
|
6
|
+
spec.license = 'Artistic-2.0'
|
8
7
|
spec.author = 'Daniel J. Berger'
|
9
8
|
spec.email = 'djberg96@gmail.com'
|
10
9
|
spec.homepage = 'https://github.com/djberg96/ptools'
|
11
10
|
spec.summary = 'Extra methods for the File class'
|
12
|
-
spec.test_files = Dir['
|
13
|
-
spec.files = Dir['**/*']
|
11
|
+
spec.test_files = Dir['spec/_spec*']
|
12
|
+
spec.files = Dir['**/*'].reject{ |f| f.include?('git') }
|
14
13
|
spec.cert_chain = ['certs/djberg96_pub.pem']
|
15
14
|
|
16
|
-
spec.extra_rdoc_files = ['README', 'CHANGES', 'MANIFEST']
|
17
|
-
|
18
15
|
spec.description = <<-EOF
|
19
16
|
The ptools (power tools) library provides several handy methods to
|
20
17
|
Ruby's core File class, such as File.which for finding executables,
|
21
18
|
File.null to return the null device on your platform, and so on.
|
22
19
|
EOF
|
23
20
|
|
21
|
+
spec.metadata = {
|
22
|
+
'homepage_uri' => 'https://github.com/djberg96/ptools',
|
23
|
+
'bug_tracker_uri' => 'https://github.com/djberg96/ptools/issues',
|
24
|
+
'changelog_uri' => 'https://github.com/djberg96/ptools/blob/master/CHANGES.md',
|
25
|
+
'documentation_uri' => 'https://github.com/djberg96/ptools/wiki',
|
26
|
+
'source_code_uri' => 'https://github.com/djberg96/ptools',
|
27
|
+
'wiki_uri' => 'https://github.com/djberg96/ptools/wiki'
|
28
|
+
}
|
29
|
+
|
24
30
|
spec.add_development_dependency('rake')
|
25
|
-
spec.add_development_dependency('
|
31
|
+
spec.add_development_dependency('rspec', '~> 3.9')
|
26
32
|
|
27
33
|
if File::ALT_SEPARATOR
|
28
34
|
spec.platform = Gem::Platform.new(['universal', 'mingw32'])
|
29
|
-
spec.add_dependency('win32-file'
|
35
|
+
spec.add_dependency('win32-file')
|
30
36
|
end
|
31
37
|
end
|
data/spec/binary_spec.rb
ADDED
@@ -0,0 +1,59 @@
|
|
1
|
+
#####################################################################
|
2
|
+
# test_binary.rb
|
3
|
+
#
|
4
|
+
# Test case for the File.binary? method. You should run this test
|
5
|
+
# via the 'rake test_binary' task.
|
6
|
+
#####################################################################
|
7
|
+
require 'rubygems'
|
8
|
+
require 'rspec'
|
9
|
+
require 'ptools'
|
10
|
+
|
11
|
+
RSpec.describe File, :binary do
|
12
|
+
let(:dirname) { File.dirname(__FILE__) }
|
13
|
+
let(:bin_file) { File::ALT_SEPARATOR ? File.join(ENV['windir'], 'notepad.exe') : '/bin/ls' }
|
14
|
+
|
15
|
+
before do
|
16
|
+
@txt_file = File.join(dirname, 'txt', 'english.txt')
|
17
|
+
@emp_file = File.join(dirname, 'txt', 'empty.txt')
|
18
|
+
@uni_file = File.join(dirname, 'txt', 'korean.txt')
|
19
|
+
@utf_file = File.join(dirname, 'txt', 'english.utf16')
|
20
|
+
@png_file = File.join(dirname, 'img', 'test.png')
|
21
|
+
@jpg_file = File.join(dirname, 'img', 'test.jpg')
|
22
|
+
@gif_file = File.join(dirname, 'img', 'test.gif')
|
23
|
+
end
|
24
|
+
|
25
|
+
example "File.binary? basic functionality" do
|
26
|
+
expect(File).to respond_to(:binary?)
|
27
|
+
expect{ File.binary?(@txt_file) }.not_to raise_error
|
28
|
+
end
|
29
|
+
|
30
|
+
example "File.binary? returns true for binary files" do
|
31
|
+
expect(File.binary?(bin_file)).to be true
|
32
|
+
end
|
33
|
+
|
34
|
+
example "File.binary? returns false for text files" do
|
35
|
+
expect(File.binary?(@emp_file)).to be false
|
36
|
+
expect(File.binary?(@txt_file)).to be false
|
37
|
+
expect(File.binary?(@uni_file)).to be false
|
38
|
+
expect(File.binary?(@utf_file)).to be false
|
39
|
+
end
|
40
|
+
|
41
|
+
example "File.binary? returns false for image files" do
|
42
|
+
expect(File.binary?(@png_file)).to be false
|
43
|
+
expect(File.binary?(@jpg_file)).to be false
|
44
|
+
expect(File.binary?(@gif_file)).to be false
|
45
|
+
end
|
46
|
+
|
47
|
+
example "File.binary? accepts an optional percentage argument" do
|
48
|
+
expect(File.binary?(@txt_file, 0.50)).to be false
|
49
|
+
expect(File.binary?(@txt_file, 0.05)).to be true
|
50
|
+
end
|
51
|
+
|
52
|
+
example "File.binary? raises an error if the file cannot be found" do
|
53
|
+
expect{ File.binary?('bogus') }.to raise_error(SystemCallError)
|
54
|
+
end
|
55
|
+
|
56
|
+
example "File.binary? only accepts one argument" do
|
57
|
+
expect{ File.binary?(@txt_file, bin_file) }.to raise_error(ArgumentError)
|
58
|
+
end
|
59
|
+
end
|
@@ -0,0 +1,33 @@
|
|
1
|
+
##############################################################################
|
2
|
+
# constants_spec.rb
|
3
|
+
#
|
4
|
+
# Specs for the constants that have been defined in the ptools library.
|
5
|
+
# This test case should be run via the 'rake spec:constants' task.
|
6
|
+
##############################################################################
|
7
|
+
require 'rubygems'
|
8
|
+
require 'rspec'
|
9
|
+
require 'rbconfig'
|
10
|
+
require 'ptools'
|
11
|
+
|
12
|
+
RSpec.describe File, :constants do
|
13
|
+
let(:windows) { File::ALT_SEPARATOR }
|
14
|
+
|
15
|
+
example "PTOOLS_VERSION constant is set to expected value" do
|
16
|
+
expect(File::PTOOLS_VERSION).to eq('1.4.1')
|
17
|
+
expect(File::PTOOLS_VERSION.frozen?).to be true
|
18
|
+
end
|
19
|
+
|
20
|
+
example "IMAGE_EXT constant is set to array of values" do
|
21
|
+
expect(File::IMAGE_EXT.sort).to eq(%w[.bmp .gif .jpeg .jpg .png])
|
22
|
+
end
|
23
|
+
|
24
|
+
example "WINDOWS constant is defined on MS Windows" do
|
25
|
+
skip "skipped unless MS Windows" unless windows
|
26
|
+
expect(File::MSWINDOWS).not_to be_nil
|
27
|
+
end
|
28
|
+
|
29
|
+
example "WIN32EXTS constant is defined on MS Windows" do
|
30
|
+
skip "skipped unless MS Windows" unless windows
|
31
|
+
expect(File::WIN32EXTS).not_to be_nil
|
32
|
+
end
|
33
|
+
end
|
data/spec/head_spec.rb
ADDED
@@ -0,0 +1,41 @@
|
|
1
|
+
######################################################################
|
2
|
+
# head_spec.rb
|
3
|
+
#
|
4
|
+
# Specs for the File.head method. These specs should be run via
|
5
|
+
# the 'rake spec:head' task.
|
6
|
+
######################################################################
|
7
|
+
require 'rspec'
|
8
|
+
require 'ptools'
|
9
|
+
|
10
|
+
RSpec.describe File, :head do
|
11
|
+
let(:test_file) { 'test_file_head.txt' }
|
12
|
+
|
13
|
+
before do
|
14
|
+
File.open(test_file, 'w'){ |fh| 25.times{ |n| fh.puts "line#{n+1}" } }
|
15
|
+
@expected_head1 = ["line1\n","line2\n","line3\n","line4\n","line5\n"]
|
16
|
+
@expected_head1.push("line6\n","line7\n","line8\n","line9\n","line10\n")
|
17
|
+
@expected_head2 = ["line1\n","line2\n","line3\n","line4\n","line5\n"]
|
18
|
+
end
|
19
|
+
|
20
|
+
example "head method basic functionality" do
|
21
|
+
expect(File).to respond_to(:head)
|
22
|
+
expect{ File.head(test_file) }.not_to raise_error
|
23
|
+
expect{ File.head(test_file, 5) }.not_to raise_error
|
24
|
+
expect{ File.head(test_file){} }.not_to raise_error
|
25
|
+
end
|
26
|
+
|
27
|
+
example "head method returns the expected results" do
|
28
|
+
expect(File.head(test_file)).to be_kind_of(Array)
|
29
|
+
expect(File.head(test_file)).to eq(@expected_head1)
|
30
|
+
expect(File.head(test_file, 5)).to eq(@expected_head2)
|
31
|
+
end
|
32
|
+
|
33
|
+
example "head method requires two arguments" do
|
34
|
+
expect{ File.head(test_file, 5, "foo") }.to raise_error(ArgumentError)
|
35
|
+
expect{ File.head("bogus") }.to raise_error(Errno::ENOENT)
|
36
|
+
end
|
37
|
+
|
38
|
+
after do
|
39
|
+
File.delete(test_file) if File.exists?(test_file)
|
40
|
+
end
|
41
|
+
end
|
data/spec/image_spec.rb
ADDED
@@ -0,0 +1,51 @@
|
|
1
|
+
#####################################################################
|
2
|
+
# image_spec.rb
|
3
|
+
#
|
4
|
+
# Specs for the File.image? method. You should run these specs via
|
5
|
+
# the 'rake spec:image' task.
|
6
|
+
#####################################################################
|
7
|
+
require 'rspec'
|
8
|
+
require 'ptools'
|
9
|
+
|
10
|
+
RSpec.describe File, :image do
|
11
|
+
before do
|
12
|
+
Dir.chdir('spec') if File.exist?('spec')
|
13
|
+
@txt_file = File.join(Dir.pwd, 'txt', 'english.txt')
|
14
|
+
@uni_file = File.join(Dir.pwd, 'txt', 'korean.txt')
|
15
|
+
@jpg_file = File.join(Dir.pwd, 'img', 'test.jpg')
|
16
|
+
@png_file = File.join(Dir.pwd, 'img', 'test.png')
|
17
|
+
@gif_file = File.join(Dir.pwd, 'img', 'test.gif')
|
18
|
+
@ico_file = File.join(Dir.pwd, 'img', 'test.ico')
|
19
|
+
end
|
20
|
+
|
21
|
+
example "image? method basic functionality" do
|
22
|
+
expect(File).to respond_to(:image?)
|
23
|
+
expect{ File.image?(@txt_file) }.not_to raise_error
|
24
|
+
expect(File.image?(@txt_file)).to be(true).or be(false)
|
25
|
+
end
|
26
|
+
|
27
|
+
example "image? method returns false for a text file" do
|
28
|
+
expect(File.image?(@txt_file)).to be false
|
29
|
+
expect(File.image?(@uni_file)).to be false
|
30
|
+
end
|
31
|
+
|
32
|
+
example "image? method returns true for a gif" do
|
33
|
+
expect(File.image?(@gif_file)).to be true
|
34
|
+
end
|
35
|
+
|
36
|
+
example "image? method returns true for a jpeg" do
|
37
|
+
expect(File.image?(@jpg_file)).to be true
|
38
|
+
end
|
39
|
+
|
40
|
+
example "image? method returns true for a png" do
|
41
|
+
expect(File.image?(@png_file)).to be true
|
42
|
+
end
|
43
|
+
|
44
|
+
example "image? method returns true for an ico" do
|
45
|
+
expect(File.image?(@ico_file)).to be true
|
46
|
+
end
|
47
|
+
|
48
|
+
example "image? method raises an error if the file does not exist" do
|
49
|
+
expect{ File.image?('bogus') }.to raise_error(Exception) # Errno::ENOENT or ArgumentError
|
50
|
+
end
|
51
|
+
end
|
data/{test → spec}/img/test.gif
RENAMED
File without changes
|
data/spec/img/test.ico
ADDED
Binary file
|
data/{test → spec}/img/test.jpg
RENAMED
File without changes
|
data/{test → spec}/img/test.png
RENAMED
File without changes
|
@@ -0,0 +1,104 @@
|
|
1
|
+
#####################################################################
|
2
|
+
# test_nlconvert.rb
|
3
|
+
#
|
4
|
+
# Test case for the File.nl_convert method. You should run this
|
5
|
+
# test via the 'rake test_nlconvert' task.
|
6
|
+
#####################################################################
|
7
|
+
require 'rubygems'
|
8
|
+
require 'rspec'
|
9
|
+
require 'ptools'
|
10
|
+
|
11
|
+
RSpec.describe File, :nlconvert do
|
12
|
+
let(:windows) { File::ALT_SEPARATOR }
|
13
|
+
let(:dirname) { File.dirname(__FILE__) }
|
14
|
+
let(:test_file1) { File.join(dirname, 'test_nl_convert1.txt') }
|
15
|
+
let(:test_file2) { File.join(dirname, 'test_nl_convert2.txt') }
|
16
|
+
|
17
|
+
before do
|
18
|
+
File.open(test_file1, 'w'){ |fh| 10.times{ |n| fh.puts "line #{n}" } }
|
19
|
+
File.open(test_file2, 'w'){ |fh| 10.times{ |n| fh.puts "line #{n}" } }
|
20
|
+
@test_file1 = File.join(dirname, 'test_nl_convert1.txt')
|
21
|
+
@test_file2 = File.join(dirname, 'test_nl_convert2.txt')
|
22
|
+
@dos_file = File.join(dirname, 'dos_test_file.txt')
|
23
|
+
@mac_file = File.join(dirname, 'mac_test_file.txt')
|
24
|
+
@unix_file = 'unix_test_file.txt'
|
25
|
+
end
|
26
|
+
|
27
|
+
example "nl_for_platform basic functionality" do
|
28
|
+
expect(File).to respond_to(:nl_for_platform)
|
29
|
+
end
|
30
|
+
|
31
|
+
example "nl_for_platform returns expected results" do
|
32
|
+
expect(File.nl_for_platform('dos') ).to eq( "\cM\cJ")
|
33
|
+
expect(File.nl_for_platform('unix') ).to eq( "\cJ")
|
34
|
+
expect(File.nl_for_platform('mac') ).to eq( "\cM")
|
35
|
+
|
36
|
+
end
|
37
|
+
|
38
|
+
example "nl_for_platform with 'local' platform does not raise an error" do
|
39
|
+
expect{ File.nl_for_platform('local') }.not_to raise_error
|
40
|
+
end
|
41
|
+
|
42
|
+
example "nl_for_platform with unsupported platform raises an error" do
|
43
|
+
expect{ File.nl_for_platform('bogus') }.to raise_error(ArgumentError)
|
44
|
+
end
|
45
|
+
|
46
|
+
example "nl_convert basic functionality" do
|
47
|
+
expect(File).to respond_to(:nl_convert)
|
48
|
+
end
|
49
|
+
|
50
|
+
example "nl_convert accepts one, two or three arguments" do
|
51
|
+
expect{ File.nl_convert(@test_file2) }.not_to raise_error
|
52
|
+
expect{ File.nl_convert(@test_file2, @test_file2) }.not_to raise_error
|
53
|
+
expect{ File.nl_convert(@test_file2, @test_file2, "unix") }.not_to raise_error
|
54
|
+
end
|
55
|
+
|
56
|
+
example "nl_convert with dos platform argument works as expected" do
|
57
|
+
expect{ File.nl_convert(@test_file1, @dos_file, "dos") }.not_to raise_error
|
58
|
+
expect{ File.nl_convert(@test_file1, @dos_file, "dos") }.not_to raise_error
|
59
|
+
expect(File.size(@dos_file)).to be > File.size(@test_file1)
|
60
|
+
expect(IO.readlines(@dos_file).first.split("")[-2..-1]).to eq(["\cM","\cJ"])
|
61
|
+
end
|
62
|
+
|
63
|
+
example "nl_convert with mac platform argument works as expected" do
|
64
|
+
expect{ File.nl_convert(@test_file1, @mac_file, 'mac') }.not_to raise_error
|
65
|
+
expect(IO.readlines(@mac_file).first.split("").last).to eq("\cM")
|
66
|
+
|
67
|
+
skip if windows
|
68
|
+
expect(File.size(@mac_file)).to eq(File.size(@test_file1))
|
69
|
+
end
|
70
|
+
|
71
|
+
example "nl_convert with unix platform argument works as expected" do
|
72
|
+
expect{ File.nl_convert(@test_file1, @unix_file, "unix") }.not_to raise_error
|
73
|
+
expect(IO.readlines(@unix_file).first.split("").last).to eq("\n")
|
74
|
+
|
75
|
+
if windows
|
76
|
+
expect(File.size(@unix_file) >= File.size(@test_file1)).to be true
|
77
|
+
else
|
78
|
+
expect(File.size(@unix_file) <= File.size(@test_file1)).to be true
|
79
|
+
end
|
80
|
+
end
|
81
|
+
|
82
|
+
example "nl_convert requires at least one argument" do
|
83
|
+
expect{ File.nl_convert }.to raise_error(ArgumentError)
|
84
|
+
end
|
85
|
+
|
86
|
+
example "nl_convert requires a valid platform string" do
|
87
|
+
expect{ File.nl_convert(@test_file1, "bogus.txt", "blah") }.to raise_error(ArgumentError)
|
88
|
+
end
|
89
|
+
|
90
|
+
example "nl_convert accepts a maximum of three arguments" do
|
91
|
+
expect{ File.nl_convert(@example_file1, @test_file2, 'dos', 1) }.to raise_error(ArgumentError)
|
92
|
+
expect{ File.nl_convert(@test_file1, @test_file2, 'dos', 1) }.to raise_error(ArgumentError)
|
93
|
+
end
|
94
|
+
|
95
|
+
example "nl_convert will fail on anything but plain files" do
|
96
|
+
expect{ File.nl_convert(IO::NULL, @test_file1) }.to raise_error(ArgumentError)
|
97
|
+
end
|
98
|
+
|
99
|
+
after do
|
100
|
+
[@dos_file, @mac_file, @unix_file].each{ |file| File.delete(file) if File.exist?(file) }
|
101
|
+
File.delete(test_file1) if File.exist?(test_file1)
|
102
|
+
File.delete(test_file2) if File.exist?(test_file2)
|
103
|
+
end
|
104
|
+
end
|