summaryrefslogtreecommitdiff
path: root/rubocop/cop/qa/duplicate_testcase_link.rb
diff options
context:
space:
mode:
Diffstat (limited to 'rubocop/cop/qa/duplicate_testcase_link.rb')
-rw-r--r--rubocop/cop/qa/duplicate_testcase_link.rb46
1 files changed, 0 insertions, 46 deletions
diff --git a/rubocop/cop/qa/duplicate_testcase_link.rb b/rubocop/cop/qa/duplicate_testcase_link.rb
deleted file mode 100644
index 82549707a83..00000000000
--- a/rubocop/cop/qa/duplicate_testcase_link.rb
+++ /dev/null
@@ -1,46 +0,0 @@
-# frozen_string_literal: true
-
-module RuboCop
- module Cop
- module QA
- # This cop checks for duplicate testcase links across e2e specs
- #
- # @example
- #
- # # bad
- # it 'some test', testcase: '(...)/quality/test_cases/1892'
- # it 'another test, testcase: '(...)/quality/test_cases/1892'
- #
- # # good
- # it 'some test', testcase: '(...)/quality/test_cases/1892'
- # it 'another test, testcase: '(...)/quality/test_cases/1894'
- class DuplicateTestcaseLink < RuboCop::Cop::Cop
- MESSAGE = "Don't reuse the same testcase link in different tests. Replace one of `%s`."
-
- @testcase_set = Set.new
-
- def_node_matcher :duplicate_testcase_link, <<~PATTERN
- (block
- (send nil? ...
- ...
- (hash
- (pair
- (sym :testcase)
- (str $_))...)...)...)
- PATTERN
-
- def on_block(node)
- duplicate_testcase_link(node) do |link|
- break unless self.class.duplicate?(link)
-
- add_offense(node, message: MESSAGE % link)
- end
- end
-
- def self.duplicate?(link)
- !@testcase_set.add?(link)
- end
- end
- end
- end
-end