grift 2.2.0 → 3.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/dependabot.yml +1 -1
- data/.github/workflows/ci.yml +4 -4
- data/.gitignore +1 -1
- data/CHANGELOG.md +40 -27
- data/Gemfile +9 -9
- data/README.md +6 -6
- data/lib/grift/config/restricted.yml +3 -0
- data/lib/grift/minitest_plugin.rb +1 -1
- data/lib/grift/mock_method.rb +80 -2
- data/lib/grift/version.rb +1 -1
- data/lib/grift.rb +14 -14
- metadata +6 -7
- data/Gemfile.lock +0 -86
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: bf2421884afdf8fff5e1b01f197d7249352312fcd7463818f54dee8bd665b251
|
4
|
+
data.tar.gz: 2491a5140014420c3ee5324c30caa32f8911b5b618417fa525dd9e34b82e6c4f
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 554d8d9425f55e7c8dd803db4311e76153614e13415aaaba44ccab586b4699a2192891f3c731b404f8cb5d4acaef796460ff15f6dca4fa50911e22590b236a97
|
7
|
+
data.tar.gz: f6fa5b36f3c80ec589a1e6d51c833611cd6ea1170765750a8623e84916d8c2ae9d795ed06474f0c4411d8828bb715845e78cf688d45b60581e480a630229d6c9
|
data/.github/dependabot.yml
CHANGED
data/.github/workflows/ci.yml
CHANGED
@@ -33,7 +33,7 @@ jobs:
|
|
33
33
|
strategy:
|
34
34
|
fail-fast: false
|
35
35
|
matrix:
|
36
|
-
ruby: ["2.7", "3.0", "3.1", "3.2", "3.3"]
|
36
|
+
ruby: ["2.7", "3.0", "3.1", "3.2", "3.3", "3.4"]
|
37
37
|
|
38
38
|
steps:
|
39
39
|
- uses: actions/checkout@v4
|
@@ -43,11 +43,11 @@ jobs:
|
|
43
43
|
bundler-cache: true
|
44
44
|
|
45
45
|
- name: Test
|
46
|
-
|
47
|
-
run: bundle exec rake test
|
46
|
+
run: bundle exec rake --trace test
|
48
47
|
|
49
48
|
- name: Upload coverage to Codecov
|
50
|
-
|
49
|
+
if: always()
|
50
|
+
uses: codecov/codecov-action@v4
|
51
51
|
with:
|
52
52
|
token: ${{ secrets.CODECOV_TOKEN }}
|
53
53
|
files: ./coverage/.resultset.json
|
data/.gitignore
CHANGED
data/CHANGELOG.md
CHANGED
@@ -8,27 +8,40 @@ This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.htm
|
|
8
8
|
|
9
9
|
None
|
10
10
|
|
11
|
+
## [3.0.0](https://github.com/clarkedb/grift/releases/tag/v3.0.0) - 2024-12-26
|
12
|
+
|
13
|
+
### Breaking
|
14
|
+
|
15
|
+
- All mocks are now scoped to the current thread for thread-safety ([#256](https://github.com/clarkedb/grift/pull/256))
|
16
|
+
- For parallelized test suites using processes this is not a breaking change
|
17
|
+
- This fixes intermittent test failures sometimes seen when codebases have threads calling mocked methods
|
18
|
+
|
19
|
+
### Added
|
20
|
+
|
21
|
+
- Official support for Ruby 3.4 ([#257](https://github.com/clarkedb/grift/pull/257))
|
22
|
+
- Direct access to mock results/calls without calling `mock` ([#258](https://github.com/clarkedb/grift/pull/258))
|
23
|
+
|
11
24
|
## [2.2.0](https://github.com/clarkedb/grift/releases/tag/v2.2.0) - 2024-01-13
|
12
25
|
|
13
26
|
### Added
|
14
27
|
|
15
|
-
|
28
|
+
- Official support for Ruby 3.3 ([#203](https://github.com/clarkedb/grift/pull/203))
|
16
29
|
|
17
30
|
## [2.1.0](https://github.com/clarkedb/grift/releases/tag/v2.1.0) - 2022-12-27
|
18
31
|
|
19
32
|
### Added
|
20
33
|
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
34
|
+
- Official support for Ruby 3.2 ([#126](https://github.com/clarkedb/grift/pull/126))
|
35
|
+
- Support for finite/self-terminating mocking for more precision in testing where a method may get called multiple times
|
36
|
+
- The Grift API now supports `mock_return_value_once`, `mock_return_value_n_times`, and `mock_return_values_in_order` ([#135](https://github.com/clarkedb/grift/pull/135))
|
37
|
+
- The Grift API now supports `mock_implementation_once` and `mock_implementation_n_times` ([#136](https://github.com/clarkedb/grift/pull/136))
|
25
38
|
|
26
39
|
## [2.0.1](https://github.com/clarkedb/grift/releases/tag/v2.0.1) - 2022-03-27
|
27
40
|
|
28
41
|
### Fixed
|
29
42
|
|
30
|
-
|
31
|
-
|
43
|
+
- When spying on a method that takes a block, the block now gets forwarded to the original method ([#78](https://github.com/clarkedb/grift/pull/78))
|
44
|
+
- When mocking the implementation, if a block is not provided a `Grift::Error` is raised instead of a `LocalJumpError` ([#77](https://github.com/clarkedb/grift/pull/77))
|
32
45
|
|
33
46
|
## [2.0.0](https://github.com/clarkedb/grift/releases/tag/v2.0.0) - 2022-03-14
|
34
47
|
|
@@ -36,23 +49,23 @@ This version adds true keyword argument support for Ruby 3. See below for how to
|
|
36
49
|
|
37
50
|
### Changed
|
38
51
|
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
52
|
+
- Dropped support for Ruby 2.5 ([#69](https://github.com/clarkedb/grift/pull/69))
|
53
|
+
- Dropped support for Ruby 2.6 ([#72](https://github.com/clarkedb/grift/pull/72))
|
54
|
+
- To support keyword arguments, records of call arguments are no longer stored in simple arrays but in a custom Enumerable ([#72](https://github.com/clarkedb/grift/pull/72))
|
55
|
+
- This changes the way that your tests will interact with mock calls
|
56
|
+
- When before `calls` returned an array, it returns a `Grift::MockMethod::MockExecutions::MockArguments` object
|
57
|
+
- Migrating to maintain previous behavior just requires appending `.args` to `calls[i]`
|
45
58
|
|
46
59
|
### Added
|
47
60
|
|
48
|
-
|
49
|
-
|
61
|
+
- Support for mocking private instance and class methods ([#68](https://github.com/clarkedb/grift/pull/68))
|
62
|
+
- Support for mocking methods that take positional and keyword arguments ([#72](https://github.com/clarkedb/grift/pull/72))
|
50
63
|
|
51
64
|
### Fixed
|
52
65
|
|
53
|
-
|
54
|
-
|
55
|
-
|
66
|
+
- When mocking protected methods, the method now remains protected while mocked and after unmocking ([#68](https://github.com/clarkedb/grift/pull/68))
|
67
|
+
- When mocking inherited methods, the method goes back to the ancestor's definition after unmocking ([#69](https://github.com/clarkedb/grift/pull/69))
|
68
|
+
- When mocking methods with keyword arugments in Ruby 3.x, no error is thrown ([#72](https://github.com/clarkedb/grift/pull/72))
|
56
69
|
|
57
70
|
## [1.1.0](https://github.com/clarkedb/grift/releases/tag/v1.1.0) - 2022-02-03
|
58
71
|
|
@@ -60,7 +73,7 @@ This version adds support for Ruby 3.1 and updates various dependencies.
|
|
60
73
|
|
61
74
|
### Added
|
62
75
|
|
63
|
-
|
76
|
+
- Support Ruby 3.1 ([#52](https://github.com/clarkedb/grift/pull/52))
|
64
77
|
|
65
78
|
## [1.0.2](https://github.com/clarkedb/grift/releases/tag/v1.0.2) - 2021-11-11
|
66
79
|
|
@@ -68,7 +81,7 @@ This version fixes a bug that prevented the mocking of methods defined by a clas
|
|
68
81
|
|
69
82
|
### Fixed
|
70
83
|
|
71
|
-
|
84
|
+
- Allow mocks of inherited methods ([#34](https://github.com/clarkedb/grift/pull/34))
|
72
85
|
|
73
86
|
## [1.0.1](https://github.com/clarkedb/grift/releases/tag/v1.0.1) - 2021-11-10
|
74
87
|
|
@@ -76,7 +89,7 @@ This version fixes a bug that prevented most mocking features in Grift from func
|
|
76
89
|
|
77
90
|
### Fixed
|
78
91
|
|
79
|
-
|
92
|
+
- Uses relative path for yaml config files ([#28](https://github.com/clarkedb/grift/pull/28))
|
80
93
|
|
81
94
|
## [1.0.0](https://github.com/clarkedb/grift/releases/tag/v1.0.0) - 2021-11-06
|
82
95
|
|
@@ -84,12 +97,12 @@ The first major version of Grift! 100% documentation and 100% code coverage.
|
|
84
97
|
|
85
98
|
### Added
|
86
99
|
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
100
|
+
- Spying on method ([#9](https://github.com/clarkedb/grift/pull/9))
|
101
|
+
- Mocking method return values ([#9](https://github.com/clarkedb/grift/pull/9))
|
102
|
+
- Mocking method implementation ([#13](https://github.com/clarkedb/grift/pull/13))
|
103
|
+
- Restricted methods that cannot be mocked ([#20](https://github.com/clarkedb/grift/pull/20))
|
104
|
+
- MiniTest Plugin to use hooks and clean up after tests ([#17](https://github.com/clarkedb/grift/pull/17))
|
105
|
+
- Documentation! ([#23](https://github.com/clarkedb/grift/pull/23))
|
93
106
|
|
94
107
|
## [0.1.0](https://github.com/clarkedb/grift/releases/tag/v0.1.0) - 2021-10-12
|
95
108
|
|
data/Gemfile
CHANGED
@@ -8,16 +8,16 @@ gemspec
|
|
8
8
|
gem 'rake', '>= 12.0'
|
9
9
|
|
10
10
|
group :development, :test do
|
11
|
-
gem '
|
12
|
-
gem 'minitest', '
|
13
|
-
gem '
|
14
|
-
gem 'simplecov', '
|
11
|
+
gem 'minitest', '~> 5.25'
|
12
|
+
gem 'minitest-reporters', '~> 1.7'
|
13
|
+
gem 'simplecov', '~> 0.22'
|
14
|
+
gem 'simplecov-cobertura', '~> 2.1'
|
15
15
|
end
|
16
16
|
|
17
17
|
group :development, :lint do
|
18
|
-
gem 'overcommit'
|
19
|
-
gem 'rubocop'
|
20
|
-
gem 'rubocop-minitest'
|
21
|
-
gem 'rubocop-packaging', '
|
22
|
-
gem 'rubocop-performance', '
|
18
|
+
gem 'overcommit', '>= 0.64'
|
19
|
+
gem 'rubocop', '~> 1.69.2'
|
20
|
+
gem 'rubocop-minitest', '~> 0.36.0'
|
21
|
+
gem 'rubocop-packaging', '~> 0.5.2'
|
22
|
+
gem 'rubocop-performance', '~> 1.23.0'
|
23
23
|
end
|
data/README.md
CHANGED
@@ -100,29 +100,29 @@ end
|
|
100
100
|
|
101
101
|
### Results
|
102
102
|
|
103
|
-
To get the results and details of the calls, call `
|
103
|
+
To get the results and details of the calls, call `calls` or `results` on your mock method object.
|
104
104
|
|
105
105
|
```ruby
|
106
106
|
# get the number of times the mocked method has been called
|
107
|
-
my_mock.
|
107
|
+
my_mock.count
|
108
108
|
#=> 2
|
109
109
|
|
110
110
|
# get args for each call to the method while mocked
|
111
|
-
my_mock.
|
111
|
+
my_mock.calls[0].args
|
112
112
|
#=> ['first_arg1', 'second_arg1']
|
113
113
|
|
114
114
|
# get kwargs for each call to the method while mocked
|
115
|
-
my_mock.
|
115
|
+
my_mock.calls[0].kwargs
|
116
116
|
#=> { first_arg1: 'value' }
|
117
117
|
|
118
118
|
# get results (return value) for each call to the method while mocked
|
119
|
-
my_mock.
|
119
|
+
my_mock.results
|
120
120
|
#=> ['result1', 'result2']
|
121
121
|
```
|
122
122
|
|
123
123
|
## Requirements
|
124
124
|
|
125
|
-
Grift supports all Ruby versions >= 2.7 (including 3.
|
125
|
+
Grift supports all Ruby versions >= 2.7 (including 3.4).
|
126
126
|
|
127
127
|
## Development
|
128
128
|
|
@@ -7,7 +7,7 @@ module Grift
|
|
7
7
|
# needing to cleanup the mocks after each test.
|
8
8
|
#
|
9
9
|
# To setup the plugin for your tests, you should include the
|
10
|
-
# following code in your
|
10
|
+
# following code in your +test_helper+
|
11
11
|
#
|
12
12
|
# class Minitest::Test
|
13
13
|
# include Grift::MinitestPlugin
|
data/lib/grift/mock_method.rb
CHANGED
@@ -101,7 +101,7 @@ module Grift
|
|
101
101
|
|
102
102
|
##
|
103
103
|
# Clears the mock execution and calls data for this mock, and
|
104
|
-
# mocks the method to return
|
104
|
+
# mocks the method to return +nil+.
|
105
105
|
#
|
106
106
|
# @return [Grift::MockMethod::MockExecutions]
|
107
107
|
#
|
@@ -455,6 +455,84 @@ module Grift
|
|
455
455
|
Grift::MockMethod.hash_key(@klass, @method_name)
|
456
456
|
end
|
457
457
|
|
458
|
+
##
|
459
|
+
# Returns an array of the args used in each call to the mocked method
|
460
|
+
# This is syntactical sugar equivalent to calling +mock+ and then +calls+.
|
461
|
+
#
|
462
|
+
# @see Grift::MockMethod::MockExecutions#calls
|
463
|
+
#
|
464
|
+
# @example
|
465
|
+
# my_mock = Grift.spy_on(Number, :+)
|
466
|
+
# x = (3 + 4) + 5
|
467
|
+
# my_mock.calls.map(&:values)
|
468
|
+
# #=> [[4], [5]]
|
469
|
+
#
|
470
|
+
# @return [Array<Grift::MockMethod::MockExecutions::MockArguments>] an array of MockArguments
|
471
|
+
#
|
472
|
+
def calls
|
473
|
+
@mock_executions.calls
|
474
|
+
end
|
475
|
+
|
476
|
+
##
|
477
|
+
# Returns true if there have been no calls to the mock.
|
478
|
+
# This is syntactical sugar equivalent to calling +mock+ and then +empty?+.
|
479
|
+
#
|
480
|
+
# @see Grift::MockMethod::MockExecutions#empty?
|
481
|
+
#
|
482
|
+
# @example
|
483
|
+
# my_mock = Grift.mock(String, :upcase)
|
484
|
+
# my_mock.mock.empty?
|
485
|
+
# #=> true
|
486
|
+
# "apple".upcase
|
487
|
+
# #=> "APPLE"
|
488
|
+
# my_mock.empty?
|
489
|
+
# #=> false
|
490
|
+
#
|
491
|
+
# @return [Boolean] if the executions are empty
|
492
|
+
#
|
493
|
+
def empty?
|
494
|
+
@mock_executions.empty?
|
495
|
+
end
|
496
|
+
|
497
|
+
##
|
498
|
+
# Returns the count of mock executions.
|
499
|
+
# This is syntactical sugar equivalent to calling +mock+ and then +count+.
|
500
|
+
#
|
501
|
+
# @see Grift::MockMethod::MockExecutions#count
|
502
|
+
#
|
503
|
+
# @example
|
504
|
+
# my_mock = Grift.mock(String, :upcase)
|
505
|
+
# my_mock.mock.count
|
506
|
+
# #=> 0
|
507
|
+
# "apple".upcase
|
508
|
+
# #=> "APPLE"
|
509
|
+
# my_mock.count
|
510
|
+
# #=> 1
|
511
|
+
#
|
512
|
+
# @return [Number] the number of executions
|
513
|
+
#
|
514
|
+
def count
|
515
|
+
@mock_executions.count
|
516
|
+
end
|
517
|
+
|
518
|
+
##
|
519
|
+
# Returns an array of the results of each call to the mocked method
|
520
|
+
# This is syntactical sugar equivalent to calling +mock+ and then +results+.
|
521
|
+
#
|
522
|
+
# @see Grift::MockMethod::MockExecutions#results
|
523
|
+
#
|
524
|
+
# @example
|
525
|
+
# my_mock = Grift.spy_on(Number, :+)
|
526
|
+
# x = (3 + 4) + 5
|
527
|
+
# my_mock.results
|
528
|
+
# #=> [7, 12]
|
529
|
+
#
|
530
|
+
# @return [Array] an array of results
|
531
|
+
#
|
532
|
+
def results
|
533
|
+
@mock_executions.results
|
534
|
+
end
|
535
|
+
|
458
536
|
private
|
459
537
|
|
460
538
|
##
|
@@ -547,7 +625,7 @@ module Grift
|
|
547
625
|
##
|
548
626
|
# Checks for the original access of the method (public, protected, private),
|
549
627
|
# and if that definition is inherited from an ancestor (super) class.
|
550
|
-
# Returns
|
628
|
+
# Returns +nil+ if no definition for the method is found.
|
551
629
|
#
|
552
630
|
# @return [Symbol] the method access
|
553
631
|
# @return [Boolean] true if the method is inherited
|
data/lib/grift/version.rb
CHANGED
data/lib/grift.rb
CHANGED
@@ -14,18 +14,18 @@ require 'grift/version'
|
|
14
14
|
# through this base module.
|
15
15
|
#
|
16
16
|
module Grift
|
17
|
-
@mock_store = Grift::MockStore.new
|
18
|
-
|
19
17
|
class << self
|
20
18
|
# @example
|
21
19
|
# Grift.mock_store
|
22
|
-
# @return [Grift::MockStore] the current store of mocked methods
|
23
|
-
|
20
|
+
# @return [Grift::MockStore] the current store of mocked methods scoped to the thread
|
21
|
+
def mock_store
|
22
|
+
Thread.current[:grift_internal_mock_store] ||= Grift::MockStore.new
|
23
|
+
end
|
24
24
|
|
25
25
|
##
|
26
26
|
# Mocks the given method to return the provided value.
|
27
27
|
# This is syntactical sugar equivalent to calling
|
28
|
-
#
|
28
|
+
# +spy_on+ and then +mock_return_value+.
|
29
29
|
#
|
30
30
|
# @example
|
31
31
|
# my_mock = Grift.mock(MyClass, :some_method, true)
|
@@ -79,7 +79,7 @@ module Grift
|
|
79
79
|
#
|
80
80
|
def mock_method?(klass, method)
|
81
81
|
hash_key = Grift::MockMethod.hash_key(klass, method)
|
82
|
-
|
82
|
+
mock_store.include?(hash_key)
|
83
83
|
end
|
84
84
|
|
85
85
|
##
|
@@ -121,7 +121,7 @@ module Grift
|
|
121
121
|
# @return [Array<Grift::MockMethod::MockExecutions>]
|
122
122
|
#
|
123
123
|
def clear_mocks(klass)
|
124
|
-
|
124
|
+
mock_store.mocks(klass: klass).each(&:mock_clear)
|
125
125
|
end
|
126
126
|
|
127
127
|
##
|
@@ -134,7 +134,7 @@ module Grift
|
|
134
134
|
# @return [Array<Grift::MockMethod::MockExecutions>]
|
135
135
|
#
|
136
136
|
def clear_all_mocks
|
137
|
-
|
137
|
+
mock_store.mocks.each(&:mock_clear)
|
138
138
|
end
|
139
139
|
|
140
140
|
##
|
@@ -149,7 +149,7 @@ module Grift
|
|
149
149
|
# @return [Array<Grift::MockMethod::MockExecutions>]
|
150
150
|
#
|
151
151
|
def reset_mocks(klass)
|
152
|
-
|
152
|
+
mock_store.mocks(klass: klass).each(&:mock_reset)
|
153
153
|
end
|
154
154
|
|
155
155
|
##
|
@@ -162,7 +162,7 @@ module Grift
|
|
162
162
|
# @return [Array<Grift::MockMethod::MockExecutions>]
|
163
163
|
#
|
164
164
|
def reset_all_mocks
|
165
|
-
|
165
|
+
mock_store.mocks.each(&:mock_reset)
|
166
166
|
end
|
167
167
|
|
168
168
|
##
|
@@ -183,9 +183,9 @@ module Grift
|
|
183
183
|
#
|
184
184
|
def restore_mocks(klass, watch: false)
|
185
185
|
if watch
|
186
|
-
|
186
|
+
mock_store.mocks(klass: klass).each { |m| m.mock_restore(watch: true) }
|
187
187
|
else
|
188
|
-
|
188
|
+
mock_store.remove(klass: klass)
|
189
189
|
end
|
190
190
|
end
|
191
191
|
|
@@ -206,9 +206,9 @@ module Grift
|
|
206
206
|
#
|
207
207
|
def restore_all_mocks(watch: false)
|
208
208
|
if watch
|
209
|
-
|
209
|
+
mock_store.mocks.each { |m| m.mock_restore(watch: true) }
|
210
210
|
else
|
211
|
-
|
211
|
+
mock_store.remove
|
212
212
|
end
|
213
213
|
end
|
214
214
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: grift
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version:
|
4
|
+
version: 3.0.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Clark Brown
|
8
|
-
autorequire:
|
8
|
+
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2024-
|
11
|
+
date: 2024-12-26 00:00:00.000000000 Z
|
12
12
|
dependencies: []
|
13
13
|
description: A gem for simple mocking and spying in Ruby's MiniTest framework.
|
14
14
|
email:
|
@@ -28,7 +28,6 @@ files:
|
|
28
28
|
- ".yardopts"
|
29
29
|
- CHANGELOG.md
|
30
30
|
- Gemfile
|
31
|
-
- Gemfile.lock
|
32
31
|
- LICENSE
|
33
32
|
- README.md
|
34
33
|
- Rakefile
|
@@ -55,7 +54,7 @@ metadata:
|
|
55
54
|
homepage_uri: https://github.com/clarkedb/grift
|
56
55
|
rubygems_mfa_required: 'true'
|
57
56
|
source_code_uri: https://github.com/clarkedb/grift
|
58
|
-
post_install_message:
|
57
|
+
post_install_message:
|
59
58
|
rdoc_options: []
|
60
59
|
require_paths:
|
61
60
|
- lib
|
@@ -70,8 +69,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
70
69
|
- !ruby/object:Gem::Version
|
71
70
|
version: '0'
|
72
71
|
requirements: []
|
73
|
-
rubygems_version: 3.
|
74
|
-
signing_key:
|
72
|
+
rubygems_version: 3.3.26
|
73
|
+
signing_key:
|
75
74
|
specification_version: 4
|
76
75
|
summary: Mocking and spying in MiniTest
|
77
76
|
test_files: []
|
data/Gemfile.lock
DELETED
@@ -1,86 +0,0 @@
|
|
1
|
-
PATH
|
2
|
-
remote: .
|
3
|
-
specs:
|
4
|
-
grift (2.2.0)
|
5
|
-
|
6
|
-
GEM
|
7
|
-
remote: https://rubygems.org/
|
8
|
-
specs:
|
9
|
-
ansi (1.5.0)
|
10
|
-
ast (2.4.2)
|
11
|
-
builder (3.2.4)
|
12
|
-
childprocess (4.1.0)
|
13
|
-
codecov (0.2.12)
|
14
|
-
json
|
15
|
-
simplecov
|
16
|
-
docile (1.4.0)
|
17
|
-
iniparse (1.5.0)
|
18
|
-
json (2.7.1)
|
19
|
-
language_server-protocol (3.17.0.3)
|
20
|
-
minitest (5.20.0)
|
21
|
-
minitest-reporters (1.6.1)
|
22
|
-
ansi
|
23
|
-
builder
|
24
|
-
minitest (>= 5.0)
|
25
|
-
ruby-progressbar
|
26
|
-
overcommit (0.60.0)
|
27
|
-
childprocess (>= 0.6.3, < 5)
|
28
|
-
iniparse (~> 1.4)
|
29
|
-
rexml (~> 3.2)
|
30
|
-
parallel (1.24.0)
|
31
|
-
parser (3.3.0.3)
|
32
|
-
ast (~> 2.4.1)
|
33
|
-
racc
|
34
|
-
racc (1.7.3)
|
35
|
-
rainbow (3.1.1)
|
36
|
-
rake (13.1.0)
|
37
|
-
regexp_parser (2.9.0)
|
38
|
-
rexml (3.2.6)
|
39
|
-
rubocop (1.59.0)
|
40
|
-
json (~> 2.3)
|
41
|
-
language_server-protocol (>= 3.17.0)
|
42
|
-
parallel (~> 1.10)
|
43
|
-
parser (>= 3.2.2.4)
|
44
|
-
rainbow (>= 2.2.2, < 4.0)
|
45
|
-
regexp_parser (>= 1.8, < 3.0)
|
46
|
-
rexml (>= 3.2.5, < 4.0)
|
47
|
-
rubocop-ast (>= 1.30.0, < 2.0)
|
48
|
-
ruby-progressbar (~> 1.7)
|
49
|
-
unicode-display_width (>= 2.4.0, < 3.0)
|
50
|
-
rubocop-ast (1.30.0)
|
51
|
-
parser (>= 3.2.1.0)
|
52
|
-
rubocop-minitest (0.34.4)
|
53
|
-
rubocop (>= 1.39, < 2.0)
|
54
|
-
rubocop-ast (>= 1.30.0, < 2.0)
|
55
|
-
rubocop-packaging (0.5.2)
|
56
|
-
rubocop (>= 1.33, < 2.0)
|
57
|
-
rubocop-performance (1.19.1)
|
58
|
-
rubocop (>= 1.7.0, < 2.0)
|
59
|
-
rubocop-ast (>= 0.4.0)
|
60
|
-
ruby-progressbar (1.13.0)
|
61
|
-
simplecov (0.22.0)
|
62
|
-
docile (~> 1.1)
|
63
|
-
simplecov-html (~> 0.11)
|
64
|
-
simplecov_json_formatter (~> 0.1)
|
65
|
-
simplecov-html (0.12.3)
|
66
|
-
simplecov_json_formatter (0.1.4)
|
67
|
-
unicode-display_width (2.5.0)
|
68
|
-
|
69
|
-
PLATFORMS
|
70
|
-
ruby
|
71
|
-
|
72
|
-
DEPENDENCIES
|
73
|
-
codecov
|
74
|
-
grift!
|
75
|
-
minitest (>= 5.0)
|
76
|
-
minitest-reporters (>= 1.4.3)
|
77
|
-
overcommit
|
78
|
-
rake (>= 12.0)
|
79
|
-
rubocop
|
80
|
-
rubocop-minitest
|
81
|
-
rubocop-packaging (>= 0.5)
|
82
|
-
rubocop-performance (>= 1.0)
|
83
|
-
simplecov (>= 0.21.2)
|
84
|
-
|
85
|
-
BUNDLED WITH
|
86
|
-
2.2.32
|