eitil 1.2.0 → 1.2.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (26) hide show
  1. checksums.yaml +4 -4
  2. data/lib/eitil/version.rb +1 -1
  3. data/spec/eitil_core/argument_helpers/all_args_to_ivars_bang_spec.rb +19 -0
  4. data/spec/eitil_core/argument_helpers/all_args_to_ivars_spec.rb +19 -0
  5. data/spec/eitil_core/argument_helpers/all_kwargs_to_ivars_bang_spec.rb +34 -0
  6. data/spec/eitil_core/argument_helpers/all_kwargs_to_ivars_spec.rb +34 -0
  7. data/spec/eitil_core/argument_helpers/args_to_h_bang_spec.rb +16 -0
  8. data/spec/eitil_core/argument_helpers/args_to_h_spec.rb +16 -0
  9. data/spec/eitil_core/argument_helpers/args_to_ivars_bang_spec.rb +49 -0
  10. data/spec/eitil_core/argument_helpers/args_to_ivars_spec.rb +49 -0
  11. data/spec/eitil_core/array/map_strings_spec.rb +24 -0
  12. data/spec/eitil_core/array/slice_hashes_spec.rb +13 -0
  13. data/spec/eitil_core/datetime/prettify_spec.rb +11 -0
  14. data/spec/eitil_core/errors/raise_error_spec.rb +33 -0
  15. data/spec/eitil_core/float/safe_to_i_spec.rb +24 -0
  16. data/spec/eitil_core/formatters/duck_set_spec.rb +139 -0
  17. data/spec/eitil_core/formatters/sql_spec.rb +90 -0
  18. data/spec/eitil_core/hash/auto_dig_spec.rb +17 -0
  19. data/spec/eitil_core/hash/transform_string_values_spec.rb +25 -0
  20. data/spec/eitil_core/safe_executions/safe_call.rb +23 -0
  21. data/spec/eitil_core/safe_executions/safe_send.rb +25 -0
  22. data/spec/eitil_core/setters/set_ivars_spec.rb +28 -0
  23. data/spec/eitil_core/string/strip_base64_header_spec.rb +22 -0
  24. data/spec/eitil_core/string/to_filename_spec.rb +34 -0
  25. data/spec/eitil_core/type_checkers/is_num_or_nan_spec.rb +146 -0
  26. metadata +24 -1
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: bec9e917368ae2247d207eabbf6d0f8280e4ac5d27999245f81bc6d47e7a1a8e
4
- data.tar.gz: d5dac1b85a0dff5143180c0d49db8c6773a45539a4f799ddb07b18a6de657594
3
+ metadata.gz: 591930a48096cb26f7ccc1b0cac2ef947fbb98c9598e87a0e81d4dd8fdc90dda
4
+ data.tar.gz: 7b96c9a9eee4295e46e46c28e1a41a51e90908506eca9153a8f6d88c3812cd9b
5
5
  SHA512:
6
- metadata.gz: 2f095b69404768be104b743042e746ea08713275ffb26d39bf7f3d35612c9fd9b2d84800ab304230b3c96cd0b4902e0bd9f8b32a2786016d6efb3b23dbe74b1a
7
- data.tar.gz: f49522248b51c3a377469ef267c584fc5f855a57040e8e5e88cc87b092ae7bb0672e4b8acf1fd5f59166296c797f5c74d050791cb08cce1f5eebd1f8155cca28
6
+ metadata.gz: 218952e25bec69b4677ff12cff4b597266cd1538a4c01a806f6dafcbc6e6ca0e18a474db2a07f33d13bc82539ff282a92ff4ae3f13f13184c64f7d25d58d1483
7
+ data.tar.gz: '010814956180e66acc2fc5669d666201e617563fde6fdb04d2ba83b801c7a04d7d3ada715f7965dfbf2bb7df04736ccd770a1c0c401a1f3b70cf3630762d46bc'
data/lib/eitil/version.rb CHANGED
@@ -1,5 +1,5 @@
1
1
  module Eitil
2
2
 
3
- VERSION = '1.2.0'
3
+ VERSION = '1.2.1'
4
4
 
5
5
  end
@@ -0,0 +1,19 @@
1
+
2
+ RSpec.describe "Kernel#all_args_to_ivars!" do
3
+
4
+ it "should set all positional arguments as instance variables" do
5
+
6
+ def test_method(a, b, c)
7
+ all_args_to_ivars!
8
+ end
9
+
10
+ test_method(1, "two", :three)
11
+
12
+ expect(@a).to eq 1
13
+ expect(@b).to eq "two"
14
+ expect(@c).to eq :three
15
+ expect(@d).to be_nil
16
+
17
+ end
18
+
19
+ end
@@ -0,0 +1,19 @@
1
+
2
+ RSpec.describe "Kernel#all_args_to_ivars" do
3
+
4
+ it "should set all positional arguments as instance variables" do
5
+
6
+ def test_method(a, b, c)
7
+ all_args_to_ivars binding
8
+ end
9
+
10
+ test_method(1, "two", :three)
11
+
12
+ expect(@a).to eq 1
13
+ expect(@b).to eq "two"
14
+ expect(@c).to eq :three
15
+ expect(@d).to be_nil
16
+
17
+ end
18
+
19
+ end
@@ -0,0 +1,34 @@
1
+
2
+ RSpec.describe "Kernel#all_kwargs_to_ivars!" do
3
+
4
+ it "should set all hash keys, nested within a positional hash, to instance variables" do
5
+
6
+ def test_method(a, b, c, kwargs)
7
+ all_kwargs_to_ivars! :kwargs
8
+ end
9
+
10
+ test_method(1, "two", :three, {a: 0, b: "not_two", c: :not_three})
11
+
12
+ expect(@a).to eq 0
13
+ expect(@b).to eq "not_two"
14
+ expect(@c).to eq :not_three
15
+ expect(@d).to be_nil
16
+
17
+ end
18
+
19
+ it "should set all hash keys, nested within a keyword hash, to instance variables" do
20
+
21
+ def test_method(a, b, c, kwargs:)
22
+ all_kwargs_to_ivars! :kwargs
23
+ end
24
+
25
+ test_method(1, "two", :three, kwargs: {a: 0, b: "not_two", c: :not_three})
26
+
27
+ expect(@a).to eq 0
28
+ expect(@b).to eq "not_two"
29
+ expect(@c).to eq :not_three
30
+ expect(@d).to be_nil
31
+
32
+ end
33
+
34
+ end
@@ -0,0 +1,34 @@
1
+
2
+ RSpec.describe "Kernel#all_kwargs_to_ivars" do
3
+
4
+ it "should set all hash keys, nested within a positional hash, to instance variables" do
5
+
6
+ def test_method(a, b, c, kwargs)
7
+ all_kwargs_to_ivars binding, :kwargs
8
+ end
9
+
10
+ test_method(1, "two", :three, {a: 0, b: "not_two", c: :not_three})
11
+
12
+ expect(@a).to eq 0
13
+ expect(@b).to eq "not_two"
14
+ expect(@c).to eq :not_three
15
+ expect(@d).to be_nil
16
+
17
+ end
18
+
19
+ it "should set all hash keys, nested within a keyword hash, to instance variables" do
20
+
21
+ def test_method(a, b, c, kwargs:)
22
+ all_kwargs_to_ivars binding, :kwargs
23
+ end
24
+
25
+ test_method(1, "two", :three, kwargs: {a: 0, b: "not_two", c: :not_three})
26
+
27
+ expect(@a).to eq 0
28
+ expect(@b).to eq "not_two"
29
+ expect(@c).to eq :not_three
30
+ expect(@d).to be_nil
31
+
32
+ end
33
+
34
+ end
@@ -0,0 +1,16 @@
1
+
2
+ RSpec.describe "Kernel#args_to_h!" do
3
+
4
+ it "should create an hash, with the local variables as key / value pairs" do
5
+
6
+ a = 1
7
+ b = "two"
8
+ c = :three
9
+
10
+ created_hash = args_to_h! :a, :c
11
+ expected_hash = {a: 1, c: :three}
12
+
13
+ expect(created_hash).to eq expected_hash
14
+
15
+ end
16
+ end
@@ -0,0 +1,16 @@
1
+
2
+ RSpec.describe "Kernel#args_to_h" do
3
+
4
+ it "should create an hash, with the local variables as key / value pairs" do
5
+
6
+ a = 1
7
+ b = "two"
8
+ c = :three
9
+
10
+ created_hash = args_to_h(binding, :a, :c)
11
+ expected_hash = {a: 1, c: :three}
12
+
13
+ expect(created_hash).to eq expected_hash
14
+
15
+ end
16
+ end
@@ -0,0 +1,49 @@
1
+
2
+ RSpec.describe "Kernel#args_to_ivars!" do
3
+
4
+ it "should set the given positional arguments to instance variables" do
5
+
6
+ def test_method(a, b, c)
7
+ args_to_ivars! :a, :c
8
+ end
9
+
10
+ test_method(1, "two", :three)
11
+
12
+ expect(@a).to eq 1
13
+ expect(@b).to be_nil
14
+ expect(@c).to eq :three
15
+ expect(@d).to be_nil
16
+
17
+ end
18
+
19
+ it "should set the given keyword arguments to instance variables" do
20
+
21
+ def test_method(a:, b:, c:)
22
+ args_to_ivars! :a, :c
23
+ end
24
+
25
+ test_method(a: 1, b: "two", c: :three)
26
+
27
+ expect(@a).to eq 1
28
+ expect(@b).to be_nil
29
+ expect(@c).to eq :three
30
+ expect(@d).to be_nil
31
+
32
+ end
33
+
34
+ it "should set the given local variables to instance variables" do
35
+
36
+ a = 1
37
+ b = "two"
38
+ c = :three
39
+
40
+ args_to_ivars! :a, :c
41
+
42
+ expect(@a).to eq 1
43
+ expect(@b).to be_nil
44
+ expect(@c).to eq :three
45
+ expect(@d).to be_nil
46
+
47
+ end
48
+
49
+ end
@@ -0,0 +1,49 @@
1
+
2
+ RSpec.describe "Kernel#args_to_ivars" do
3
+
4
+ it "should set the given positional arguments to instance variables" do
5
+
6
+ def test_method(a, b, c)
7
+ args_to_ivars binding, :a, :c
8
+ end
9
+
10
+ test_method(1, "two", :three)
11
+
12
+ expect(@a).to eq 1
13
+ expect(@b).to be_nil
14
+ expect(@c).to eq :three
15
+ expect(@d).to be_nil
16
+
17
+ end
18
+
19
+ it "should set the given keyword arguments to instance variables" do
20
+
21
+ def test_method(a:, b:, c:)
22
+ args_to_ivars binding, :a, :c
23
+ end
24
+
25
+ test_method(a: 1, b: "two", c: :three)
26
+
27
+ expect(@a).to eq 1
28
+ expect(@b).to be_nil
29
+ expect(@c).to eq :three
30
+ expect(@d).to be_nil
31
+
32
+ end
33
+
34
+ it "should set the given local variables to instance variables" do
35
+
36
+ a = 1
37
+ b = "two"
38
+ c = :three
39
+
40
+ args_to_ivars binding, :a, :c
41
+
42
+ expect(@a).to eq 1
43
+ expect(@b).to be_nil
44
+ expect(@c).to eq :three
45
+ expect(@d).to be_nil
46
+
47
+ end
48
+
49
+ end
@@ -0,0 +1,24 @@
1
+
2
+ RSpec.describe "Array#map_strings" do
3
+
4
+ it "should transforms all strings in infinite recursion" do
5
+
6
+ array = ["hey", ["hi", {a: "ho", b: {d: "he"}}]]
7
+ result = array.map_strings { |str| str.upcase }
8
+
9
+ expect(result).to eq ["HEY", ["HI", {a: "HO", b: {d: "HE"}}]]
10
+
11
+ end
12
+ end
13
+
14
+ RSpec.describe "Array#map_strings!" do
15
+
16
+ it "should transforms all strings in infinite recursion" do
17
+
18
+ array = ["hey", ["hi", {a: "ho", b: {d: "he"}}]]
19
+ array.map_strings! { |str| str.upcase }
20
+
21
+ expect(array).to eq ["HEY", ["HI", {a: "HO", b: {d: "HE"}}]]
22
+
23
+ end
24
+ end
@@ -0,0 +1,13 @@
1
+
2
+ RSpec.describe "Array#slice_hashes" do
3
+
4
+ it "should slice each hash in an array of hashes with the given keys" do
5
+
6
+ array = [{"a"=>1, "b"=>2, "c"=>3}, {"a"=>1, "b"=>2, "c"=>3}]
7
+ result = array.slice_hashes("a", "b")
8
+ expected = [{"a"=>1, "b"=>2}, {"a"=>1, "b"=>2}]
9
+
10
+ expect(result).to eq expected
11
+
12
+ end
13
+ end
@@ -0,0 +1,11 @@
1
+
2
+ RSpec.describe "DateTime#prettify" do
3
+
4
+ it "should represent a DateTime instance in the '%Y-%m-%d.%H:%M:%S' format" do
5
+
6
+ datetime = DateTime.parse("01-01-2020, 10:00:00, +0200")
7
+
8
+ expect(datetime.prettify).to eq "2020-01-01.10:00:00"
9
+
10
+ end
11
+ end
@@ -0,0 +1,33 @@
1
+
2
+ RSpec.describe "Kernel#raise_error" do
3
+
4
+ # Call specs directly on Kernel, which you would usually do implicit
5
+ # instead of explicit, in order to escape the RSpec namespace, which has
6
+ # it's own effects for raised errors
7
+
8
+ it "should define a new constant, if the error class does not yet exist" do
9
+
10
+ begin
11
+ Kernel.raise_error "ThisErrorWillProbablyNotExistError"
12
+ rescue
13
+ end
14
+
15
+ expect(Kernel.const_defined?('ThisErrorWillProbablyNotExistError')).to eq true
16
+
17
+ end
18
+
19
+ it "should call an existing constant, if the error class already exists" do
20
+
21
+ expect(Kernel.const_defined?('StandardError'))
22
+ initial_const_count = Module.constants.count
23
+
24
+ begin
25
+ Kernel.raise_error "StandardError"
26
+ rescue
27
+ end
28
+
29
+ expect(Module.constants.count).to eq initial_const_count
30
+
31
+ end
32
+
33
+ end
@@ -0,0 +1,24 @@
1
+
2
+ RSpec.describe "Float#safe_to_i" do
3
+
4
+ it "should convert a float to an integer, if the float is rounded (e.g. 7.0)" do
5
+
6
+ float = 7.0
7
+ result = float.safe_to_i
8
+
9
+ expect(result).to eq 7
10
+ expect(result).to be_a Integer
11
+
12
+ end
13
+
14
+ it "should not convert a float to an integer, if the float is not rounded (e.g. 7.1)" do
15
+
16
+ float = 7.1
17
+ result = float.safe_to_i
18
+
19
+ expect(result).to eq 7.1
20
+ expect(result).to be_a Float
21
+
22
+ end
23
+
24
+ end
@@ -0,0 +1,139 @@
1
+
2
+ RSpec.describe "Date.duck_set(object)" do
3
+
4
+ let(:date) { Date.duck_set(@object) }
5
+
6
+ it "should return the object, if the object is a Date instance" do
7
+ @object = Date.today
8
+ expect(date).to eq @object
9
+ expect(date).to be_a Date
10
+ end
11
+
12
+ it "should return a Date instance, if the object is a String instance" do
13
+ @object = "2020-01-01"
14
+ expect(@object).to be_a String
15
+ expect(date).to be_a Date
16
+ end
17
+
18
+
19
+ it "should return a Date instance, if the object is a DateTime instance" do
20
+ @object = DateTime.now
21
+ expect(@object).to be_a DateTime
22
+ expect(date).to be_a Date
23
+ end
24
+
25
+
26
+ it "should return a Date instance, if the object is a Time instance" do
27
+ @object = Time.now
28
+ expect(@object).to be_a Time
29
+ expect(date).to be_a Date
30
+ end
31
+
32
+
33
+ it "should raise an error, if the object's class is not one of: String, Date, DateTime, Time" do
34
+ @object = 2020
35
+ expect(@object).to be_a Integer
36
+ begin
37
+ error_raised = false
38
+ date
39
+ rescue
40
+ error_raised = true
41
+ end
42
+ expect(error_raised).to eq true
43
+ end
44
+
45
+ end
46
+
47
+
48
+ RSpec.describe "DateTime.duck_set(object)" do
49
+
50
+ let(:datetime) { DateTime.duck_set(@object) }
51
+
52
+ it "should return the object, if the object is a DateTime instance" do
53
+ @object = DateTime.now
54
+ expect(datetime).to eq @object
55
+ expect(datetime).to be_a DateTime
56
+ end
57
+
58
+ it "should return a DateTime instance, if the object is a String instance" do
59
+ @object = "2020-01-01"
60
+ expect(@object).to be_a String
61
+ expect(datetime).to be_a DateTime
62
+ end
63
+
64
+
65
+ it "should return a DateTime instance, if the object is a Date instance" do
66
+ @object = Date.today
67
+ expect(@object).to be_a Date
68
+ expect(datetime).to be_a DateTime
69
+ end
70
+
71
+
72
+ it "should return a DateTime instance, if the object is a Time instance" do
73
+ @object = Time.now
74
+ expect(@object).to be_a Time
75
+ expect(datetime).to be_a DateTime
76
+ end
77
+
78
+
79
+ it "should raise an error, if the object's class is not one of: String, DateTime, Date, Time" do
80
+ @object = 2020
81
+ expect(@object).to be_a Integer
82
+ begin
83
+ error_raised = false
84
+ datetime
85
+ rescue
86
+ error_raised = true
87
+ end
88
+ expect(error_raised).to eq true
89
+ end
90
+
91
+ end
92
+
93
+
94
+
95
+ RSpec.describe "Time.duck_set(object)" do
96
+
97
+ let(:time) { Time.duck_set(@object) }
98
+
99
+ it "should return the object, if the object is a Time instance" do
100
+ @object = Time.now
101
+ expect(time).to eq @object
102
+ expect(time).to be_a Time
103
+ end
104
+
105
+ it "should return a Time instance, if the object is a String instance" do
106
+ @object = "20:00"
107
+ expect(@object).to be_a String
108
+ expect(time).to be_a Time
109
+ end
110
+
111
+
112
+ it "should return a Time instance, if the object is a Date instance" do
113
+ @object = Date.today
114
+ expect(@object).to be_a Date
115
+ expect(time).to be_a Time
116
+ end
117
+
118
+
119
+ it "should return a Time instance, if the object is a DateTime instance" do
120
+ @object = DateTime.now
121
+ expect(@object).to be_a DateTime
122
+ expect(time).to be_a Time
123
+ end
124
+
125
+
126
+ it "should raise an error, if the object's class is not one of: String, DateTime, Date, Time" do
127
+ @object = 2020
128
+ expect(@object).to be_a Integer
129
+ begin
130
+ error_raised = false
131
+ time
132
+ rescue
133
+ error_raised = true
134
+ end
135
+ expect(error_raised).to eq true
136
+ end
137
+
138
+ end
139
+
@@ -0,0 +1,90 @@
1
+
2
+ RSpec.describe "Date#strfsql(type)" do
3
+
4
+ let(:date) { Date.parse('01-01-2020').strfsql(@type) }
5
+
6
+ it "should by default format a Date instance to '%Y-%m-%d'" do
7
+ date = Date.parse('01-01-2020').strfsql
8
+ expect(date).to eq '2020-01-01'
9
+ end
10
+
11
+ it "should format a Date instance to '%Y-%m-%d', if :date is given as type" do
12
+ @type = :date
13
+ expect(date).to eq '2020-01-01'
14
+ end
15
+
16
+ it "should simply return nil if an invalid type is given" do
17
+ @type = 666
18
+ expect(date).to be_nil
19
+ end
20
+
21
+ end
22
+
23
+
24
+ RSpec.describe "DateTime#strfsql(type)" do
25
+
26
+ let(:datetime) { DateTime.parse('01-01-2020').strfsql(@type) }
27
+
28
+ it "should by default format a DateTime instance to '%Y-%m-%d %H:%M:%S.%6N'" do
29
+ datetime = DateTime.parse('01-01-2020').strfsql
30
+ expect(datetime).to eq "2020-01-01 00:00:00.000000"
31
+ end
32
+
33
+ it "should format a DateTime instance to '%Y-%m-%d %H:%M:%S.%6N', if :datetime is given as type" do
34
+ @type = :datetime
35
+ expect(datetime).to eq "2020-01-01 00:00:00.000000"
36
+ end
37
+
38
+
39
+ it "should format a DateTime instance to '%Y-%m-%d', if :date is given as type" do
40
+ @type = :date
41
+ expect(datetime).to eq "2020-01-01"
42
+ end
43
+
44
+
45
+ it "should format a DateTime instance to '%H:%M:%S', if :time is given as type" do
46
+ @type = :time
47
+ expect(datetime).to eq "00:00:00"
48
+ end
49
+
50
+ it "should simply return nil if an invalid type is given" do
51
+ @type = 666
52
+ expect(datetime).to be_nil
53
+ end
54
+
55
+ end
56
+
57
+
58
+
59
+ RSpec.describe "Time#strfsql(type)" do
60
+
61
+ let(:time) { Time.parse('01-01-2020 20:00:00 +0200').strfsql(@type) }
62
+
63
+ it "should by default format a Time instance to '%Y-%m-%d %H:%M:%S.%6N'" do
64
+ time = Time.parse('01-01-2020 20:00:00 +0200').strfsql
65
+ expect(time).to eq "20:00:00"
66
+ end
67
+
68
+ it "should format a Time instance to '%Y-%m-%d %H:%M:%S.%6N', if :datetime is given as type" do
69
+ @type = :datetime
70
+ expect(time).to eq "2020-01-01 20:00:00.000000"
71
+ end
72
+
73
+
74
+ it "should format a Time instance to '%Y-%m-%d', if :date is given as type" do
75
+ @type = :date
76
+ expect(time).to eq "2020-01-01"
77
+ end
78
+
79
+
80
+ it "should format a Time instance to '%H:%M:%S', if :time is given as type" do
81
+ @type = :time
82
+ expect(time).to eq "20:00:00"
83
+ end
84
+
85
+ it "should simply return nil if an invalid type is given" do
86
+ @type = 666
87
+ expect(time).to be_nil
88
+ end
89
+
90
+ end
@@ -0,0 +1,17 @@
1
+
2
+ RSpec.describe "Hash#auto_dig" do
3
+
4
+ it "should recursively find the value for the given hash key" do
5
+ hash = {a: 1, b: {c: 2, d: {e: 3}}}
6
+ result = hash.auto_dig :e
7
+ expect(result).to eq 3
8
+ end
9
+
10
+
11
+ it "should return nil if the given hash key is not present" do
12
+ hash = {a: 1, b: {c: 2, d: {e: 3}}}
13
+ result = hash.auto_dig :f
14
+ expect(result).to be_nil
15
+ end
16
+
17
+ end
@@ -0,0 +1,25 @@
1
+
2
+ RSpec.describe "Hash#transform_string_values" do
3
+
4
+ it "should transforms all strings in infinite recursion" do
5
+ hash = {a: "hey", b: {c: "hi", d: ["ho"]}}
6
+ expected = {a: "HEY", b: {c: "HI", d: ["HO"]}}
7
+ result = hash.transform_string_values { |str| str.upcase }
8
+
9
+ expect(result).to eq expected
10
+ end
11
+
12
+ end
13
+
14
+
15
+ RSpec.describe "Hash#transform_string_values!" do
16
+
17
+ it "should transforms all strings in infinite recursion" do
18
+ hash = {a: "hey", b: {c: "hi", d: ["ho"]}}
19
+ expected = {a: "HEY", b: {c: "HI", d: ["HO"]}}
20
+
21
+ hash.transform_string_values! { |str| str.upcase }
22
+ expect(hash).to eq expected
23
+ end
24
+
25
+ end
@@ -0,0 +1,23 @@
1
+
2
+ # For some reason, the Kernel patches – which ruby mixes into Object – are not
3
+ # available to the tests, therefore load the file manually.
4
+ load (Eitil::Root + "/eitil_core/lib/eitil_core/safe_executions/safe_call.rb")
5
+
6
+ RSpec.describe "Object#safe_call" do
7
+
8
+ it "should return the block's yield value, if no error is raised" do
9
+ result = Object.new.safe_call { 1 + 1 }
10
+ expect(result).to eq 2
11
+ end
12
+
13
+ it "should by default return nil, if an error is raised" do
14
+ result = Object.new.safe_call { raise(StandardError) }
15
+ expect(result).to be_nil
16
+ end
17
+
18
+ it "should return the specified :return_value, if an error is raised" do
19
+ result = Object.new.safe_call(return_value: :something_else) { raise(StandardError) }
20
+ expect(result).to eq :something_else
21
+ end
22
+
23
+ end
@@ -0,0 +1,25 @@
1
+
2
+ # For some reason, the Kernel patches – which ruby mixes into string – are not
3
+ # available to the tests, therefore load the file manually.
4
+ load (Eitil::Root + "/eitil_core/lib/eitil_core/safe_executions/safe_send.rb")
5
+
6
+ RSpec.describe "Object#safe_send" do
7
+
8
+ let(:string) { "Hiya, Cowboy!" }
9
+
10
+ it "should return the method's return value, if no error is raised" do
11
+ result = string.safe_send(:upcase)
12
+ expect(result).to eq "HIYA, COWBOY!"
13
+ end
14
+
15
+ it "should by default return nil, if an error is raised" do
16
+ result = string.safe_send(:this_method_does_probably_not_exist)
17
+ expect(result).to be_nil
18
+ end
19
+
20
+ it "should return the specified :return_value, if an error is raised" do
21
+ result = string.safe_send(:this_method_does_probably_not_exist, return_value: :something_else)
22
+ expect(result).to eq :something_else
23
+ end
24
+
25
+ end
@@ -0,0 +1,28 @@
1
+
2
+ RSpec.describe "Object#set_ivars" do
3
+
4
+ def set_ivar_one
5
+ :one
6
+ end
7
+
8
+ def set_ivar_two
9
+ 2
10
+ end
11
+
12
+ it 'should call a method .set_#{ivar_name}, for every :ivar_name passed' do
13
+ set_ivars :ivar_one, :ivar_two
14
+ expect(@ivar_one).to eq :one
15
+ expect(@ivar_two).to eq 2
16
+ end
17
+
18
+ it "should return an array of symbols, which the names of all ivars being set" do
19
+ return_value = set_ivars :ivar_one, :ivar_two
20
+ expect(return_value).to eq [:ivar_one, :ivar_two]
21
+ end
22
+
23
+ it "should return an empty array, if no arguments are passed" do
24
+ expect(set_ivars).to eq []
25
+ end
26
+
27
+
28
+ end
@@ -0,0 +1,22 @@
1
+
2
+ RSpec.describe "String#strip_base64_header" do
3
+
4
+ let(:regex) { EitilStore::Regex::LeadingBase64Data }
5
+ let(:b64_string) { "" }
6
+ let(:normal_string) { "IAmJustANormalStringDoingNormalThings" }
7
+
8
+ it "should retrieve the Regexp LeadingBase64Data" do
9
+ expect(regex).to be_a Regexp
10
+ end
11
+
12
+ it "should detect a base_64 string" do
13
+ result = b64_string =~ regex
14
+ expect(result).to be_a Integer
15
+ end
16
+
17
+ it "should leave a normal string untouched" do
18
+ result = normal_string =~ regex
19
+ expect(result).to be_nil
20
+ end
21
+
22
+ end
@@ -0,0 +1,34 @@
1
+
2
+ RSpec.describe "String#to_filename(substitute='_')" do
3
+
4
+ it "should substitute all spaces with, by default, lowdashes" do
5
+ string = "this is a filename"
6
+ expect(string.to_filename).to eq "this_is_a_filename"
7
+ end
8
+
9
+ it "should substitute all spaces with, if given, the substitute argument" do
10
+ string = "this is a filename"
11
+ expect(string.to_filename('-')).to eq "this-is-a-filename"
12
+ end
13
+
14
+ it "should substitute all slashes with, by default, lowdashes" do
15
+ string = "this/is/a/filename"
16
+ expect(string.to_filename).to eq "this_is_a_filename"
17
+ end
18
+
19
+ it "should substitute all slashes with, if given, the substitute argument" do
20
+ string = "this/is/a/filename"
21
+ expect(string.to_filename('-')).to eq "this-is-a-filename"
22
+ end
23
+
24
+ it "should substitute all backslashes with, by default, lowdashes" do
25
+ string = 'this\is\a\filename'
26
+ expect(string.to_filename).to eq "this_is_a_filename"
27
+ end
28
+
29
+ it "should substitute all backslashes with, if given, the substitute argument" do
30
+ string = 'this\is\a\filename'
31
+ expect(string.to_filename('-')).to eq "this-is-a-filename"
32
+ end
33
+
34
+ end
@@ -0,0 +1,146 @@
1
+
2
+ RSpec.describe "#is_num? and #is_nan?" do
3
+
4
+ context "for String" do
5
+
6
+ it "#is_num? should return true for '5' (integers)" do
7
+ expect('5'.is_num?).to be_truthy
8
+ end
9
+
10
+ it "#is_num? should return true for '5.0' (floats) " do
11
+ expect('5.0'.is_num?).to be_truthy
12
+ end
13
+
14
+ it "#is_num? should return true for '5,0' (floats, separated by comma) " do
15
+ expect('5,0'.is_num?).to be_truthy
16
+ end
17
+
18
+ it "#is_num? should return false for valid values, '5a' (concatenated with additional letters)" do
19
+ expect('5a'.is_num?).to be_falsy
20
+ expect('5.0a'.is_num?).to be_falsy
21
+ expect('5,0a'.is_num?).to be_falsy
22
+ end
23
+
24
+ it "#is_nan? should return the opposite" do
25
+ expect('5'.is_nan?).to be_falsy
26
+ expect('5.0'.is_nan?).to be_falsy
27
+ expect('5,0'.is_nan?).to be_falsy
28
+ expect('5a'.is_nan?).to be_truthy
29
+ expect('5.0a'.is_nan?).to be_truthy
30
+ expect('5,0a'.is_nan?).to be_truthy
31
+ end
32
+
33
+ end
34
+
35
+ context "for Numeric" do
36
+
37
+ it "#is_num? should always return true" do
38
+ expect(1.is_num?).to be_truthy
39
+ expect(1.0.is_num?).to be_truthy
40
+ end
41
+
42
+ it "#is_nan? should always return false" do
43
+ expect(1.is_nan?).to be_falsy
44
+ expect(1.0.is_nan?).to be_falsy
45
+ end
46
+
47
+ end
48
+
49
+ context "for NilClass" do
50
+
51
+ it "#is_num? should always return false" do
52
+ expect(nil.is_num?).to be_falsy
53
+ end
54
+
55
+ it "#is_nan? should always return true" do
56
+ expect(nil.is_nan?).to be_truthy
57
+ end
58
+
59
+ end
60
+
61
+ context "for TrueClass" do
62
+
63
+ it "#is_num? should always return false" do
64
+ expect(true.is_num?).to be_falsy
65
+ end
66
+
67
+ it "#is_nan? should always return true" do
68
+ expect(true.is_nan?).to be_truthy
69
+ end
70
+
71
+ end
72
+
73
+ context "for FalseClass" do
74
+
75
+ it "#is_num? should always return false" do
76
+ expect(false.is_num?).to be_falsy
77
+ end
78
+
79
+ it "#is_nan? should always return true" do
80
+ expect(false.is_nan?).to be_truthy
81
+ end
82
+
83
+ end
84
+
85
+ context "for Hash" do
86
+
87
+ it "#is_num? should always return false" do
88
+ expect({}.is_num?).to be_falsy
89
+ end
90
+
91
+ it "#is_nan? should always return true" do
92
+ expect({}.is_nan?).to be_truthy
93
+ end
94
+
95
+ end
96
+
97
+ context "for Array" do
98
+
99
+ it "#is_num? should always return false" do
100
+ expect([].is_num?).to be_falsy
101
+ end
102
+
103
+ it "#is_nan? should always return true" do
104
+ expect([].is_nan?).to be_truthy
105
+ end
106
+
107
+ end
108
+
109
+ context "for Date" do
110
+
111
+ it "#is_num? should always return false" do
112
+ expect(Date.today.is_num?).to be_falsy
113
+ end
114
+
115
+ it "#is_nan? should always return true" do
116
+ expect(Date.today.is_nan?).to be_truthy
117
+ end
118
+
119
+ end
120
+
121
+ context "for Time" do
122
+
123
+ it "#is_num? should always return false" do
124
+ expect(Time.now.is_num?).to be_falsy
125
+ end
126
+
127
+ it "#is_nan? should always return true" do
128
+ expect(Time.now.is_nan?).to be_truthy
129
+ end
130
+
131
+ end
132
+
133
+ context "for DateTime" do
134
+
135
+ it "#is_num? should always return false" do
136
+ expect(DateTime.now.is_num?).to be_falsy
137
+ end
138
+
139
+ it "#is_nan? should always return true" do
140
+ expect(DateTime.now.is_nan?).to be_truthy
141
+ end
142
+
143
+ end
144
+
145
+ end
146
+
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: eitil
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.2.0
4
+ version: 1.2.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Jurriaan Schrofer
@@ -247,6 +247,29 @@ files:
247
247
  - lib/eitil/all.rb
248
248
  - lib/eitil/railtie.rb
249
249
  - lib/eitil/version.rb
250
+ - spec/eitil_core/argument_helpers/all_args_to_ivars_bang_spec.rb
251
+ - spec/eitil_core/argument_helpers/all_args_to_ivars_spec.rb
252
+ - spec/eitil_core/argument_helpers/all_kwargs_to_ivars_bang_spec.rb
253
+ - spec/eitil_core/argument_helpers/all_kwargs_to_ivars_spec.rb
254
+ - spec/eitil_core/argument_helpers/args_to_h_bang_spec.rb
255
+ - spec/eitil_core/argument_helpers/args_to_h_spec.rb
256
+ - spec/eitil_core/argument_helpers/args_to_ivars_bang_spec.rb
257
+ - spec/eitil_core/argument_helpers/args_to_ivars_spec.rb
258
+ - spec/eitil_core/array/map_strings_spec.rb
259
+ - spec/eitil_core/array/slice_hashes_spec.rb
260
+ - spec/eitil_core/datetime/prettify_spec.rb
261
+ - spec/eitil_core/errors/raise_error_spec.rb
262
+ - spec/eitil_core/float/safe_to_i_spec.rb
263
+ - spec/eitil_core/formatters/duck_set_spec.rb
264
+ - spec/eitil_core/formatters/sql_spec.rb
265
+ - spec/eitil_core/hash/auto_dig_spec.rb
266
+ - spec/eitil_core/hash/transform_string_values_spec.rb
267
+ - spec/eitil_core/safe_executions/safe_call.rb
268
+ - spec/eitil_core/safe_executions/safe_send.rb
269
+ - spec/eitil_core/setters/set_ivars_spec.rb
270
+ - spec/eitil_core/string/strip_base64_header_spec.rb
271
+ - spec/eitil_core/string/to_filename_spec.rb
272
+ - spec/eitil_core/type_checkers/is_num_or_nan_spec.rb
250
273
  - spec/spec_helper.rb
251
274
  homepage: https://github.com/eitje-app/eitil_engine
252
275
  licenses: