mutant 0.9.9 → 0.9.14

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.
Files changed (252) hide show
  1. checksums.yaml +4 -4
  2. data/lib/mutant.rb +2 -4
  3. data/lib/mutant/bootstrap.rb +14 -1
  4. data/lib/mutant/cli.rb +6 -0
  5. data/lib/mutant/isolation.rb +1 -1
  6. data/lib/mutant/isolation/fork.rb +2 -2
  7. data/lib/mutant/isolation/none.rb +1 -1
  8. data/lib/mutant/matcher/config.rb +2 -0
  9. data/lib/mutant/meta/example.rb +16 -4
  10. data/lib/mutant/meta/example/dsl.rb +33 -16
  11. data/lib/mutant/meta/example/verification.rb +70 -28
  12. data/lib/mutant/minitest/coverage.rb +53 -0
  13. data/lib/mutant/mutator/node.rb +2 -2
  14. data/lib/mutant/mutator/node/block_pass.rb +29 -0
  15. data/lib/mutant/mutator/node/{dstr.rb → dynamic_literal.rb} +7 -5
  16. data/lib/mutant/mutator/node/index.rb +4 -4
  17. data/lib/mutant/mutator/node/literal/range.rb +4 -1
  18. data/lib/mutant/mutator/node/noop.rb +1 -1
  19. data/lib/mutant/mutator/node/op_asgn.rb +15 -1
  20. data/lib/mutant/mutator/node/send.rb +25 -1
  21. data/lib/mutant/mutator/node/send/attribute_assignment.rb +1 -0
  22. data/lib/mutant/reporter/cli/printer.rb +2 -2
  23. data/lib/mutant/reporter/cli/printer/isolation_result.rb +9 -3
  24. data/lib/mutant/reporter/cli/printer/mutation_result.rb +1 -1
  25. data/lib/mutant/subject/method/instance.rb +41 -2
  26. data/lib/mutant/version.rb +1 -1
  27. metadata +59 -347
  28. data/.github/workflows/ci.yml +0 -121
  29. data/.gitignore +0 -38
  30. data/.rspec +0 -5
  31. data/.rubocop.yml +0 -7
  32. data/Changelog.md +0 -81
  33. data/Gemfile +0 -7
  34. data/Gemfile.lock +0 -167
  35. data/Gemfile.shared +0 -10
  36. data/README.md +0 -178
  37. data/Rakefile +0 -5
  38. data/config/devtools.yml +0 -2
  39. data/config/reek.yml +0 -139
  40. data/config/rubocop.yml +0 -205
  41. data/config/yardstick.yml +0 -2
  42. data/docs/commercial-support.md +0 -14
  43. data/docs/concurrency.md +0 -39
  44. data/docs/incremental.md +0 -76
  45. data/docs/known-problems.md +0 -30
  46. data/docs/limitations.md +0 -50
  47. data/docs/mutant-minitest.md +0 -149
  48. data/docs/mutant-rspec.md +0 -130
  49. data/docs/nomenclature.md +0 -82
  50. data/docs/reading-reports.md +0 -74
  51. data/lib/mutant/color.rb +0 -40
  52. data/lib/mutant/diff.rb +0 -97
  53. data/lib/mutant/mutator/node/dsym.rb +0 -22
  54. data/meta/and.rb +0 -13
  55. data/meta/and_asgn.rb +0 -14
  56. data/meta/array.rb +0 -27
  57. data/meta/begin.rb +0 -20
  58. data/meta/block.rb +0 -199
  59. data/meta/block_pass.rb +0 -8
  60. data/meta/blockarg.rb +0 -10
  61. data/meta/break.rb +0 -9
  62. data/meta/case.rb +0 -217
  63. data/meta/casgn.rb +0 -25
  64. data/meta/cbase.rb +0 -8
  65. data/meta/class.rb +0 -12
  66. data/meta/const.rb +0 -17
  67. data/meta/csend.rb +0 -10
  68. data/meta/cvar.rb +0 -7
  69. data/meta/cvasgn.rb +0 -9
  70. data/meta/date.rb +0 -59
  71. data/meta/def.rb +0 -196
  72. data/meta/defined.rb +0 -9
  73. data/meta/dstr.rb +0 -13
  74. data/meta/dsym.rb +0 -14
  75. data/meta/ensure.rb +0 -8
  76. data/meta/false.rb +0 -7
  77. data/meta/file.rb +0 -5
  78. data/meta/float.rb +0 -37
  79. data/meta/gvar.rb +0 -7
  80. data/meta/gvasgn.rb +0 -9
  81. data/meta/hash.rb +0 -20
  82. data/meta/if.rb +0 -72
  83. data/meta/index.rb +0 -133
  84. data/meta/indexasgn.rb +0 -31
  85. data/meta/int.rb +0 -18
  86. data/meta/ivar.rb +0 -8
  87. data/meta/ivasgn.rb +0 -22
  88. data/meta/kwarg.rb +0 -10
  89. data/meta/kwbegin.rb +0 -8
  90. data/meta/kwoptarg.rb +0 -13
  91. data/meta/lambda.rb +0 -23
  92. data/meta/line.rb +0 -5
  93. data/meta/lvar.rb +0 -16
  94. data/meta/lvasgn.rb +0 -24
  95. data/meta/masgn.rb +0 -7
  96. data/meta/match_current_line.rb +0 -14
  97. data/meta/next.rb +0 -10
  98. data/meta/nil.rb +0 -5
  99. data/meta/nthref.rb +0 -14
  100. data/meta/op_assgn.rb +0 -17
  101. data/meta/or.rb +0 -13
  102. data/meta/or_asgn.rb +0 -50
  103. data/meta/range.rb +0 -39
  104. data/meta/redo.rb +0 -5
  105. data/meta/regexp.rb +0 -80
  106. data/meta/regopt.rb +0 -10
  107. data/meta/rescue.rb +0 -84
  108. data/meta/return.rb +0 -16
  109. data/meta/sclass.rb +0 -12
  110. data/meta/self.rb +0 -7
  111. data/meta/send.rb +0 -600
  112. data/meta/str.rb +0 -7
  113. data/meta/super.rb +0 -27
  114. data/meta/sym.rb +0 -8
  115. data/meta/true.rb +0 -7
  116. data/meta/until.rb +0 -16
  117. data/meta/while.rb +0 -24
  118. data/meta/yield.rb +0 -9
  119. data/mutant-minitest.gemspec +0 -22
  120. data/mutant-rspec.gemspec +0 -22
  121. data/mutant.gemspec +0 -41
  122. data/mutant.sh +0 -12
  123. data/mutant.yml +0 -6
  124. data/spec/integration/mutant/corpus_spec.rb +0 -15
  125. data/spec/integration/mutant/isolation/fork_spec.rb +0 -28
  126. data/spec/integration/mutant/minitest_spec.rb +0 -11
  127. data/spec/integration/mutant/null_spec.rb +0 -16
  128. data/spec/integration/mutant/rspec_spec.rb +0 -15
  129. data/spec/integration/mutant/test_mutator_handles_types_spec.rb +0 -9
  130. data/spec/integrations.yml +0 -63
  131. data/spec/shared/base_behavior.rb +0 -45
  132. data/spec/shared/framework_integration_behavior.rb +0 -70
  133. data/spec/shared/method_matcher_behavior.rb +0 -47
  134. data/spec/spec_helper.rb +0 -75
  135. data/spec/support/corpus.rb +0 -318
  136. data/spec/support/file_system.rb +0 -62
  137. data/spec/support/ice_nine_config.rb +0 -10
  138. data/spec/support/ruby_vm.rb +0 -84
  139. data/spec/support/shared_context.rb +0 -169
  140. data/spec/support/test_app.rb +0 -7
  141. data/spec/support/warnings.yml +0 -6
  142. data/spec/support/xspec.rb +0 -183
  143. data/spec/unit/mutant/ast/find_metaclass_containing_spec.rb +0 -64
  144. data/spec/unit/mutant/ast/meta/optarg_spec.rb +0 -24
  145. data/spec/unit/mutant/ast/meta/send/proc_predicate_spec.rb +0 -30
  146. data/spec/unit/mutant/ast/meta/send/receiver_possible_top_level_const_predicate_spec.rb +0 -39
  147. data/spec/unit/mutant/ast/meta/send_spec.rb +0 -42
  148. data/spec/unit/mutant/ast/named_children_spec.rb +0 -89
  149. data/spec/unit/mutant/ast/sexp_spec.rb +0 -38
  150. data/spec/unit/mutant/ast_spec.rb +0 -57
  151. data/spec/unit/mutant/bootstrap_spec.rb +0 -216
  152. data/spec/unit/mutant/cli_spec.rb +0 -305
  153. data/spec/unit/mutant/clock_monotonic_spec.rb +0 -52
  154. data/spec/unit/mutant/config_spec.rb +0 -126
  155. data/spec/unit/mutant/context_spec.rb +0 -111
  156. data/spec/unit/mutant/diff_spec.rb +0 -189
  157. data/spec/unit/mutant/env_spec.rb +0 -229
  158. data/spec/unit/mutant/expression/method_spec.rb +0 -62
  159. data/spec/unit/mutant/expression/methods_spec.rb +0 -66
  160. data/spec/unit/mutant/expression/namespace/exact_spec.rb +0 -28
  161. data/spec/unit/mutant/expression/namespace/recursive_spec.rb +0 -66
  162. data/spec/unit/mutant/expression/parser_spec.rb +0 -65
  163. data/spec/unit/mutant/expression_spec.rb +0 -45
  164. data/spec/unit/mutant/integration/rspec_spec.rb +0 -201
  165. data/spec/unit/mutant/integration_spec.rb +0 -150
  166. data/spec/unit/mutant/isolation/fork_spec.rb +0 -309
  167. data/spec/unit/mutant/isolation/none_spec.rb +0 -23
  168. data/spec/unit/mutant/isolation/result_spec.rb +0 -73
  169. data/spec/unit/mutant/license_spec.rb +0 -305
  170. data/spec/unit/mutant/loader_spec.rb +0 -79
  171. data/spec/unit/mutant/matcher/chain_spec.rb +0 -26
  172. data/spec/unit/mutant/matcher/compiler_spec.rb +0 -0
  173. data/spec/unit/mutant/matcher/config_spec.rb +0 -47
  174. data/spec/unit/mutant/matcher/filter_spec.rb +0 -22
  175. data/spec/unit/mutant/matcher/method/instance_spec.rb +0 -164
  176. data/spec/unit/mutant/matcher/method/metaclass_spec.rb +0 -108
  177. data/spec/unit/mutant/matcher/method/singleton_spec.rb +0 -90
  178. data/spec/unit/mutant/matcher/methods/instance_spec.rb +0 -54
  179. data/spec/unit/mutant/matcher/methods/metaclass_spec.rb +0 -62
  180. data/spec/unit/mutant/matcher/methods/singleton_spec.rb +0 -51
  181. data/spec/unit/mutant/matcher/namespace_spec.rb +0 -39
  182. data/spec/unit/mutant/matcher/null_spec.rb +0 -12
  183. data/spec/unit/mutant/matcher/scope_spec.rb +0 -45
  184. data/spec/unit/mutant/matcher/static_spec.rb +0 -13
  185. data/spec/unit/mutant/matcher_spec.rb +0 -102
  186. data/spec/unit/mutant/meta/example/dsl_spec.rb +0 -108
  187. data/spec/unit/mutant/meta/example/verification_spec.rb +0 -154
  188. data/spec/unit/mutant/meta/example_spec.rb +0 -34
  189. data/spec/unit/mutant/mutation_spec.rb +0 -140
  190. data/spec/unit/mutant/mutator/node_spec.rb +0 -47
  191. data/spec/unit/mutant/mutator_spec.rb +0 -21
  192. data/spec/unit/mutant/parallel/driver_spec.rb +0 -126
  193. data/spec/unit/mutant/parallel/source/array_spec.rb +0 -57
  194. data/spec/unit/mutant/parallel/worker_spec.rb +0 -206
  195. data/spec/unit/mutant/parallel_spec.rb +0 -115
  196. data/spec/unit/mutant/parser_spec.rb +0 -26
  197. data/spec/unit/mutant/range_spec.rb +0 -141
  198. data/spec/unit/mutant/registry_spec.rb +0 -74
  199. data/spec/unit/mutant/reporter/cli/printer/config_spec.rb +0 -17
  200. data/spec/unit/mutant/reporter/cli/printer/env_progress_spec.rb +0 -85
  201. data/spec/unit/mutant/reporter/cli/printer/env_result_spec.rb +0 -45
  202. data/spec/unit/mutant/reporter/cli/printer/isolation_result_spec.rb +0 -132
  203. data/spec/unit/mutant/reporter/cli/printer/mutation_progress_result_spec.rb +0 -25
  204. data/spec/unit/mutant/reporter/cli/printer/mutation_result_spec.rb +0 -153
  205. data/spec/unit/mutant/reporter/cli/printer/status_progressive_spec.rb +0 -45
  206. data/spec/unit/mutant/reporter/cli/printer/subject_progress_spec.rb +0 -36
  207. data/spec/unit/mutant/reporter/cli/printer/subject_result_spec.rb +0 -44
  208. data/spec/unit/mutant/reporter/cli/printer/test_result_spec.rb +0 -16
  209. data/spec/unit/mutant/reporter/cli/printer_spec.rb +0 -163
  210. data/spec/unit/mutant/reporter/cli_spec.rb +0 -137
  211. data/spec/unit/mutant/reporter/null_spec.rb +0 -14
  212. data/spec/unit/mutant/reporter/sequence_spec.rb +0 -31
  213. data/spec/unit/mutant/repository/diff/ranges_spec.rb +0 -180
  214. data/spec/unit/mutant/repository/diff_spec.rb +0 -122
  215. data/spec/unit/mutant/repository/subject_filter_spec.rb +0 -30
  216. data/spec/unit/mutant/require_highjack_spec.rb +0 -73
  217. data/spec/unit/mutant/result/class_methods_spec.rb +0 -51
  218. data/spec/unit/mutant/result/env_spec.rb +0 -161
  219. data/spec/unit/mutant/result/mutation_spec.rb +0 -70
  220. data/spec/unit/mutant/result/subject_spec.rb +0 -111
  221. data/spec/unit/mutant/result/test_spec.rb +0 -14
  222. data/spec/unit/mutant/result_spec.rb +0 -33
  223. data/spec/unit/mutant/runner/sink_spec.rb +0 -174
  224. data/spec/unit/mutant/runner_spec.rb +0 -121
  225. data/spec/unit/mutant/selector/expression_spec.rb +0 -62
  226. data/spec/unit/mutant/selector/null_spec.rb +0 -17
  227. data/spec/unit/mutant/subject/method/instance_spec.rb +0 -181
  228. data/spec/unit/mutant/subject/method/metaclass_spec.rb +0 -63
  229. data/spec/unit/mutant/subject/method/singleton_spec.rb +0 -61
  230. data/spec/unit/mutant/subject_spec.rb +0 -93
  231. data/spec/unit/mutant/transform/array_spec.rb +0 -92
  232. data/spec/unit/mutant/transform/bool_spec.rb +0 -63
  233. data/spec/unit/mutant/transform/error_spec.rb +0 -132
  234. data/spec/unit/mutant/transform/exception_spec.rb +0 -44
  235. data/spec/unit/mutant/transform/hash_spec.rb +0 -236
  236. data/spec/unit/mutant/transform/index_spec.rb +0 -92
  237. data/spec/unit/mutant/transform/named_spec.rb +0 -49
  238. data/spec/unit/mutant/transform/primitive_spec.rb +0 -56
  239. data/spec/unit/mutant/transform/sequence_spec.rb +0 -98
  240. data/spec/unit/mutant/util/one_spec.rb +0 -22
  241. data/spec/unit/mutant/warnings_spec.rb +0 -89
  242. data/spec/unit/mutant/world_spec.rb +0 -63
  243. data/spec/unit/mutant/zombifier_spec.rb +0 -122
  244. data/test_app/.rspec +0 -1
  245. data/test_app/Gemfile.minitest +0 -4
  246. data/test_app/Gemfile.rspec3.8 +0 -7
  247. data/test_app/lib/test_app.rb +0 -110
  248. data/test_app/lib/test_app/literal.rb +0 -35
  249. data/test_app/lib/test_app/metaclasses.rb +0 -108
  250. data/test_app/spec/spec_helper.rb +0 -9
  251. data/test_app/spec/unit/test_app/literal_spec.rb +0 -20
  252. data/test_app/test/unit/test_app/literal_test.rb +0 -16
@@ -1,92 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- RSpec.describe Mutant::Transform::Index do
4
- subject { described_class.new(index: index, transform: transform) }
5
-
6
- let(:index) { 1 }
7
- let(:transform) { Mutant::Transform::Boolean.new }
8
-
9
- describe '#slug' do
10
- def apply
11
- subject.slug
12
- end
13
-
14
- it 'retursn expected value' do
15
- expect(apply).to eql('1')
16
- end
17
-
18
- it 'returns frozen value' do
19
- expect(apply.frozen?).to be(true)
20
- end
21
-
22
- it 'returns idempotent value' do
23
- expect(apply).to be(apply)
24
- end
25
- end
26
-
27
- describe '#apply' do
28
- def apply
29
- subject.apply(input)
30
- end
31
-
32
- context 'on valid input' do
33
- let(:input) { true }
34
-
35
- it 'returns sucess' do
36
- expect(apply).to eql(Mutant::Either::Right.new(input))
37
- end
38
- end
39
-
40
- context 'on nvalid input' do
41
- let(:input) { 1 }
42
-
43
- let(:boolean_error) do
44
- Mutant::Transform::Error.new(
45
- cause: nil,
46
- input: input,
47
- message: 'Expected: boolean but got: 1',
48
- transform: transform
49
- )
50
- end
51
-
52
- let(:error) do
53
- Mutant::Transform::Error.new(
54
- cause: boolean_error,
55
- input: input,
56
- message: nil,
57
- transform: subject
58
- )
59
- end
60
-
61
- it 'returns failure' do
62
- expect(apply).to eql(Mutant::Either::Left.new(error))
63
- end
64
- end
65
- end
66
-
67
- describe '.wrap' do
68
- def apply
69
- described_class.wrap(error, index)
70
- end
71
-
72
- let(:error) do
73
- Mutant::Transform::Error.new(
74
- cause: :nil,
75
- input: 1,
76
- message: nil,
77
- transform: transform
78
- )
79
- end
80
-
81
- it 'returns wrapped error' do
82
- expect(apply).to eql(
83
- Mutant::Transform::Error.new(
84
- cause: error,
85
- input: 1,
86
- message: nil,
87
- transform: described_class.new(index: index, transform: transform)
88
- )
89
- )
90
- end
91
- end
92
- end
@@ -1,49 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- RSpec.describe Mutant::Transform::Named do
4
- subject { described_class.new(name, transform) }
5
-
6
- let(:name) { 'transform-name' }
7
- let(:transform) { Mutant::Transform::Boolean.new }
8
-
9
- describe '#slug' do
10
- def apply
11
- subject.slug
12
- end
13
-
14
- it 'returns name' do
15
- expect(apply).to be(name)
16
- end
17
- end
18
-
19
- describe '#apply' do
20
- def apply
21
- subject.apply(input)
22
- end
23
-
24
- context 'on valid input' do
25
- let(:input) { true }
26
-
27
- it 'returns sucess' do
28
- expect(apply).to eql(Mutant::Either::Right.new(input))
29
- end
30
- end
31
-
32
- context 'on invalid input' do
33
- let(:input) { 1 }
34
-
35
- let(:error) do
36
- Mutant::Transform::Error.new(
37
- cause: transform.apply(input).from_left,
38
- input: input,
39
- message: nil,
40
- transform: subject
41
- )
42
- end
43
-
44
- it 'returns failure' do
45
- expect(apply).to eql(Mutant::Either::Left.new(error))
46
- end
47
- end
48
- end
49
- end
@@ -1,56 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- RSpec.describe Mutant::Transform::Primitive do
4
- subject { described_class.new(primitive) }
5
-
6
- let(:primitive) { String }
7
-
8
- describe '#slug' do
9
- def apply
10
- subject.slug
11
- end
12
-
13
- it 'returns strigified primitive' do
14
- expect(apply).to eql('String')
15
- end
16
-
17
- it 'is idempotent' do
18
- expect(apply).to be(apply)
19
- end
20
-
21
- it 'is frozen' do
22
- expect(apply.frozen?).to be(true)
23
- end
24
- end
25
-
26
- describe '#apply' do
27
- def apply
28
- subject.apply(input)
29
- end
30
-
31
- context 'on string input' do
32
- let(:input) { 'some-string' }
33
-
34
- it 'returns sucess' do
35
- expect(apply).to eql(Mutant::Either::Right.new(input))
36
- end
37
- end
38
-
39
- context 'on other input' do
40
- let(:input) { 1 }
41
-
42
- let(:error) do
43
- Mutant::Transform::Error.new(
44
- cause: nil,
45
- input: input,
46
- message: 'Expected: String but got: Integer',
47
- transform: subject
48
- )
49
- end
50
-
51
- it 'returns failure' do
52
- expect(apply).to eql(Mutant::Either::Left.new(error))
53
- end
54
- end
55
- end
56
- end
@@ -1,98 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- RSpec.describe Mutant::Transform::Sequence do
4
- subject { described_class.new(steps) }
5
-
6
- let(:steps) do
7
- [
8
- hash_transform,
9
- hash_symbolize
10
- ]
11
- end
12
-
13
- let(:hash_transform) do
14
- Mutant::Transform::Hash.new(optional: [], required: [key_transform])
15
- end
16
-
17
- let(:key_transform) do
18
- Mutant::Transform::Hash::Key.new('foo', Mutant::Transform::Boolean.new)
19
- end
20
-
21
- let(:boolean_transform) do
22
- Mutant::Transform::Boolean.new
23
- end
24
-
25
- let(:hash_symbolize) do
26
- Mutant::Transform::Hash::Symbolize.new
27
- end
28
-
29
- describe '#apply' do
30
- def apply
31
- subject.apply(input)
32
- end
33
-
34
- context 'on valid input' do
35
- let(:input) { { 'foo' => true } }
36
-
37
- it 'returns success' do
38
- expect(apply).to eql(Mutant::Either::Right.new(foo: true))
39
- end
40
- end
41
-
42
- context 'on invalid input' do
43
- let(:input) { { 'foo' => 1 } }
44
-
45
- let(:boolean_error) do
46
- Mutant::Transform::Error.new(
47
- cause: nil,
48
- input: 1,
49
- message: 'Expected: boolean but got: 1',
50
- transform: boolean_transform
51
- )
52
- end
53
-
54
- let(:key_error) do
55
- Mutant::Transform::Error.new(
56
- cause: boolean_error,
57
- input: 1,
58
- message: nil,
59
- transform: key_transform
60
- )
61
- end
62
-
63
- let(:hash_error) do
64
- Mutant::Transform::Error.new(
65
- cause: key_error,
66
- input: input,
67
- message: nil,
68
- transform: hash_transform
69
- )
70
- end
71
-
72
- let(:index_error) do
73
- Mutant::Transform::Error.new(
74
- cause: hash_error,
75
- input: input,
76
- message: nil,
77
- transform: Mutant::Transform::Index.new(
78
- index: 0,
79
- transform: hash_transform
80
- )
81
- )
82
- end
83
-
84
- let(:error) do
85
- Mutant::Transform::Error.new(
86
- cause: index_error,
87
- input: input,
88
- message: nil,
89
- transform: subject
90
- )
91
- end
92
-
93
- it 'returns failure' do
94
- expect(apply).to eql(Mutant::Either::Left.new(error))
95
- end
96
- end
97
- end
98
- end
@@ -1,22 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- RSpec.describe Mutant::Util, '.one' do
4
- let(:first) { instance_double(Object) }
5
- let(:array) { instance_double(Array, one?: true, first: first) }
6
-
7
- it 'returns first element' do
8
- expect(described_class.one(array)).to be(first)
9
- end
10
-
11
- it 'fails if the list is empty' do
12
- expect { described_class.one([]) }
13
- .to raise_error(described_class::SizeError)
14
- .with_message('expected size to be exactly 1 but size was 0')
15
- end
16
-
17
- it 'fails if the list has more than one element' do
18
- expect { described_class.one([1, 2]) }
19
- .to raise_error(described_class::SizeError)
20
- .with_message('expected size to be exactly 1 but size was 2')
21
- end
22
- end
@@ -1,89 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- RSpec.describe Mutant::Warnings do
4
- subject { described_class.new(warning_module) }
5
-
6
- before do
7
- subject # make sure we infect the module in any case
8
- end
9
-
10
- let(:original_messages) do
11
- []
12
- end
13
-
14
- let(:warning_module) do
15
- original_messages = original_messages()
16
-
17
- # Simulation of corelib `Warning` module
18
- Module.new do
19
- module_function def warn(*arguments)
20
- messages << arguments
21
- end
22
-
23
- module_function define_method(:messages) { original_messages }
24
- end
25
- end
26
-
27
- def cause_warnings
28
- original_messages.clear
29
-
30
- warning_module = warning_module()
31
-
32
- warning_module.warn('warning-a')
33
-
34
- Class
35
- .new { include warning_module }
36
- .new
37
- .instance_eval { warn('warning-b') }
38
- end
39
-
40
- describe '#call' do
41
- def apply
42
- subject.call { cause_warnings }
43
- end
44
-
45
- def expect_captured_messages(captured_messages)
46
- expect(captured_messages).to eql([%w[warning-a], %w[warning-b]])
47
- expect(captured_messages.frozen?).to eql(true)
48
- expect(captured_messages.map(&:frozen?)).to eql([true, true])
49
- expect(captured_messages.flat_map(&:frozen?)).to eql([true, true])
50
- expect(original_messages).to eql([])
51
- end
52
-
53
- def expect_original_messages
54
- expect(original_messages).to eql([%w[warning-a], %w[warning-b]])
55
- end
56
-
57
- it 'captures expected warnings during block execution' do
58
- expect_captured_messages(apply)
59
- expect(original_messages).to eql([])
60
- end
61
-
62
- it 'captures expected warnings during repeated block execution' do
63
- expect_captured_messages(apply)
64
- expect_captured_messages(apply)
65
- end
66
-
67
- it 'does use original implementation without block execution' do
68
- cause_warnings
69
- expect_original_messages
70
- end
71
-
72
- it 'does use original implementation before block execution' do
73
- cause_warnings
74
- expect_original_messages
75
- expect_captured_messages(apply)
76
- end
77
-
78
- it 'does use original implementation after block execution' do
79
- expect_captured_messages(apply)
80
- cause_warnings
81
- expect_original_messages
82
- end
83
-
84
- it 'rejects re-entrant use' do
85
- expect { subject.call { subject.call } }
86
- .to raise_error(described_class::RecursiveUseError)
87
- end
88
- end
89
- end
@@ -1,63 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- RSpec.describe Mutant::World do
4
- subject do
5
- Mutant::WORLD
6
- end
7
-
8
- describe '#inspect' do
9
- def apply
10
- subject.inspect
11
- end
12
-
13
- it 'returns expected value' do
14
- expect(apply).to eql('#<Mutant::World>')
15
- end
16
-
17
- it 'is frozen' do
18
- expect(apply.frozen?).to be(true)
19
- end
20
-
21
- it 'is idempotent' do
22
- expect(apply).to be(apply)
23
- end
24
- end
25
-
26
- describe '#capture_stdout' do
27
- def apply
28
- subject.capture_stdout(command)
29
- end
30
-
31
- let(:open3) { class_double(Open3) }
32
- let(:stdout) { instance_double(String, :stdout) }
33
- let(:subject) { super().with(open3: open3) }
34
- let(:command) { %w[foo bar baz] }
35
-
36
- let(:process_status) do
37
- instance_double(
38
- Process::Status,
39
- success?: success?
40
- )
41
- end
42
-
43
- before do
44
- allow(open3).to receive_messages(capture2: [stdout, process_status])
45
- end
46
-
47
- context 'when process exists successful' do
48
- let(:success?) { true }
49
-
50
- it 'returns stdout' do
51
- expect(apply).to eql(Mutant::Either::Right.new(stdout))
52
- end
53
- end
54
-
55
- context 'when process exists unsuccessful' do
56
- let(:success?) { false }
57
-
58
- it 'returns stdout' do
59
- expect(apply).to eql(Mutant::Either::Left.new("Command #{command.inspect} failed!"))
60
- end
61
- end
62
- end
63
- end