swiftrail 0.1.19 → 0.1.20

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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 683bb6db1091cfa48057b1ebd344f271961ef5eee1247a1b2884bc10b28ca5cc
4
- data.tar.gz: 793d2972b483eaa4755540d0677a6723fe20b650fb70e2c6a9a66fb142ab9485
3
+ metadata.gz: 53b7f7b5058880f65ef404413d058907f66b47a105b500199cee1ec1a6372607
4
+ data.tar.gz: f308458914e030279eb35c3bf62e659aefc3cab8c0dce7681ec00017c4161f7e
5
5
  SHA512:
6
- metadata.gz: d019836bbd177d38d47aa4c34475eca9679f58b6dde222043a939da868e54276fbd8d3c5746d213236b6c295bb5783f24212caadb706622de9206c0887a36eb8
7
- data.tar.gz: b6e4dac6cfe201c2181202b74bc8e82498216181ba7e149fc45b2ccf5f089b388c68bd8d876c8be3860a7cf57e382ca5f81fcf4020afc8230da3649e9d7a9bda
6
+ metadata.gz: 2020fd2652b3271f0822dcd8130cc9a6f9f0bc53972dabbce79e6f1e61c07c5c3efd6a4a121fb961ab15c4242b29debac9fba2d67de9ed461125069be3078b05
7
+ data.tar.gz: 49fdbafe009f562bf12fc5cb362c99ebaff0f6f42b5c1314a906fed94a88ec2e9d6e64f7b9782cc790943d16445c8f66c4ec270162adb60a80adecee5a67a719
data/Gemfile.lock CHANGED
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- swiftrail (0.1.19)
4
+ swiftrail (0.1.20)
5
5
  nokogiri (>= 1.10.4)
6
6
  thor (~> 0.20)
7
7
 
@@ -10,7 +10,7 @@ GEM
10
10
  specs:
11
11
  diff-lcs (1.3)
12
12
  mini_portile2 (2.4.0)
13
- nokogiri (1.10.7)
13
+ nokogiri (1.10.8)
14
14
  mini_portile2 (~> 2.4.0)
15
15
  rake (10.5.0)
16
16
  rspec (3.9.0)
@@ -7,19 +7,18 @@ module Swiftrail
7
7
  RegexMatch = Struct.new(:case_ids, :test_name)
8
8
 
9
9
  # return RegexMatch result
10
- def extractInformation(test_name)
11
- extracted_cases = test_name.scan(case_regex)[0]
12
- if !extracted_cases.nil?
13
- case_ids = extracted_cases.split('_').reject { |c| c.empty? }
14
- RegexMatch.new(case_ids, test_name)
15
- else
16
- RegexMatch.new([], test_name)
17
- end
10
+ def extract_information(test_name)
11
+ RegexMatch.new(cases(test_name), test_name)
18
12
  end
19
13
 
20
14
  # find all occurences in string like this example: "C12345"
21
- def case_regex
22
- %r{_(?:_(?:C\d+)+)+__}i
15
+ def cases(test_name)
16
+ test_name
17
+ .split('__')
18
+ .map { |group| group.split('_') }
19
+ .select { |elements| elements.all? { |case_id| case_id =~ /C\d+/i } }
20
+ .flatten
21
+ .map { |case_id| case_id[1..-1] }
23
22
  end
24
23
  end
25
24
  end
@@ -40,7 +40,7 @@ module Swiftrail
40
40
 
41
41
  # lookup case ids in test_case name
42
42
  def search_cases_ids(test_case)
43
- result = QuickNimble::Parser.new().extractInformation(test_case.test_name)
43
+ result = QuickNimble::Parser.new().extract_information(test_case.test_name)
44
44
  if result.case_ids.empty?
45
45
  []
46
46
  else
@@ -1,3 +1,3 @@
1
1
  module Swiftrail
2
- VERSION = '0.1.19'.freeze
2
+ VERSION = '0.1.20'.freeze
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: swiftrail
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.19
4
+ version: 0.1.20
5
5
  platform: ruby
6
6
  authors:
7
7
  - Slavko Krucaj
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2020-02-03 00:00:00.000000000 Z
11
+ date: 2020-02-18 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: nokogiri