gitarro 0.1.52 → 0.1.53
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 +4 -4
- data/bin/gitarro +0 -2
- data/lib/gitarro/backend.rb +2 -46
- data/lib/gitarro/opt_parser.rb +0 -11
- metadata +34 -34
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: ed7728ce69392b49eb64ed39ead778e1c57c1ff0
|
4
|
+
data.tar.gz: 238ca7702d9a0253f578240a17f225c3abc8c1d4
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 762011a475cc4c1dd77b788cce6d3f0fa6a491be52f7c723ad842689d2cb88121a9b6e128d9d8677bbe35fc76cb1956cb2b73c90b6349d8a2f4c43fb17aba68a
|
7
|
+
data.tar.gz: 2c2d61721b17aa0e1f381e45a441c298d463ca3bb3899fb61c143b2c60196ad698be3a0e6a7b0d8d9b2933dca97558b496ecaa79078b211e198f69b544ace585
|
data/bin/gitarro
CHANGED
@@ -19,8 +19,6 @@ prs.each do |pr|
|
|
19
19
|
break if b.triggered_by_pr_number?(pr)
|
20
20
|
# retrigger if magic word found
|
21
21
|
b.retrigger_check(pr)
|
22
|
-
# check if changelog test was enabled
|
23
|
-
break if b.changelog_active?(pr, comm_st)
|
24
22
|
# 0) do test for unreviewed pr
|
25
23
|
break if b.unreviewed_new_pr?(pr, comm_st)
|
26
24
|
# we run the test in 2 conditions:
|
data/lib/gitarro/backend.rb
CHANGED
@@ -97,40 +97,12 @@ module CachingOctokit
|
|
97
97
|
Octokit.middleware = stack
|
98
98
|
end
|
99
99
|
|
100
|
-
#
|
100
|
+
# if true we dont need the cache
|
101
101
|
def generate_cache?
|
102
102
|
@cachehttp
|
103
103
|
end
|
104
104
|
end
|
105
105
|
|
106
|
-
# this module have helper methods for changelog tests
|
107
|
-
# it will be removed soon, but it helps to extract all
|
108
|
-
# changelog code from backend class
|
109
|
-
module ChangelogTests
|
110
|
-
def magic_comment?(pr_num)
|
111
|
-
@client.issue_comments(@repo, pr_num).any? do |com|
|
112
|
-
com.body.include?('no changelog needed!')
|
113
|
-
end
|
114
|
-
end
|
115
|
-
|
116
|
-
def do_changelog_test(pr)
|
117
|
-
# if the pr contains changes on .changes file, test ok
|
118
|
-
test_status = 'failure'
|
119
|
-
test_status = 'success' if pr_all_files_type(pr.number, @file_type).any?
|
120
|
-
test_status = 'success' if magic_comment?(pr.number)
|
121
|
-
create_status(pr, test_status)
|
122
|
-
test_status
|
123
|
-
end
|
124
|
-
|
125
|
-
# do the changelog test and set status
|
126
|
-
def changelog_changed?(pr, comm_st)
|
127
|
-
return false unless @changelog_test
|
128
|
-
# only execute 1 time, don"t run if test is failed, or ok
|
129
|
-
return false if failed_status?(comm_st) || success_status?(comm_st)
|
130
|
-
do_changelog_test(pr)
|
131
|
-
end
|
132
|
-
end
|
133
|
-
|
134
106
|
# This is a private class, which has the task to execute/run tests
|
135
107
|
# called by Backend
|
136
108
|
class TestExecutor
|
@@ -169,6 +141,7 @@ class TestExecutor
|
|
169
141
|
ENV['GITARRO_PR_AUTHOR'] = pr.head.user.login.to_s
|
170
142
|
ENV['GITARRO_PR_TITLE'] = pr.title.to_s
|
171
143
|
ENV['GITARRO_PR_NUMBER'] = pr.number.to_s
|
144
|
+
ENV['GITARRO_PR_TARGET_REPO'] = @repo
|
172
145
|
end
|
173
146
|
|
174
147
|
def script_exists?(script)
|
@@ -181,10 +154,7 @@ end
|
|
181
154
|
# were we execute the tests and so on
|
182
155
|
class Backend
|
183
156
|
attr_accessor :options, :client, :gbexec
|
184
|
-
# changelog tests module ( FIXME remove this once changelog
|
185
|
-
# tests are gone from backend and run separately
|
186
157
|
include CachingOctokit
|
187
|
-
include ChangelogTests
|
188
158
|
include GitHubPrOperations
|
189
159
|
|
190
160
|
# public method of backend
|
@@ -229,14 +199,6 @@ class Backend
|
|
229
199
|
launch_test_and_setup_status(pr)
|
230
200
|
end
|
231
201
|
|
232
|
-
# FIXME: remove this pub. method once changelog test are separated
|
233
|
-
# public method, trigger changelogtest if option active
|
234
|
-
def changelog_active?(pr, comm_st)
|
235
|
-
return false unless @changelog_test
|
236
|
-
return false unless changelog_changed?(pr, comm_st)
|
237
|
-
true
|
238
|
-
end
|
239
|
-
|
240
202
|
def unreviewed_new_pr?(pr, comm_st)
|
241
203
|
return unless commit_is_unreviewed?(comm_st)
|
242
204
|
pr_all_files_type(pr.number, @file_type)
|
@@ -253,7 +215,6 @@ class Backend
|
|
253
215
|
# we dont run the tests
|
254
216
|
return false unless context_present?(comm_st) == false ||
|
255
217
|
pending_pr?(comm_st)
|
256
|
-
return true if changelog_active?(pr, comm_st)
|
257
218
|
return false unless pr_all_files_type(pr.number, @file_type).any?
|
258
219
|
print_test_required
|
259
220
|
exit(0) if @check
|
@@ -340,11 +301,6 @@ class Backend
|
|
340
301
|
def retrigger_needed?(pr)
|
341
302
|
# we want redo sometimes tests
|
342
303
|
return false unless retriggered_by_comment?(pr.number, @context)
|
343
|
-
# changelog trigger
|
344
|
-
if @changelog_test
|
345
|
-
do_changelog_test(pr)
|
346
|
-
return false
|
347
|
-
end
|
348
304
|
# if check is set, the comment in the trigger job will be del.
|
349
305
|
# so setting it to pending, it will be remembered
|
350
306
|
pr_all_files_type(pr.number, @file_type).any?
|
data/lib/gitarro/opt_parser.rb
CHANGED
@@ -81,14 +81,6 @@ module OptionalOptions
|
|
81
81
|
end
|
82
82
|
end
|
83
83
|
|
84
|
-
def changelog_opt(opt)
|
85
|
-
desc = 'Check if the PR includes a changelog entry ' \
|
86
|
-
'(Automatically sets --file ".changes").'
|
87
|
-
opt.on('--changelogtest', desc) do |changelogtest|
|
88
|
-
@options[:changelog_test] = changelogtest
|
89
|
-
end
|
90
|
-
end
|
91
|
-
|
92
84
|
def pr_number(opt)
|
93
85
|
desc = 'Specify the PR number instead of checking all of them. ' \
|
94
86
|
'Force to rerun against a specific PR number,' \
|
@@ -112,7 +104,6 @@ module OptionalOptions
|
|
112
104
|
desc_opt(opt)
|
113
105
|
check_opt(opt)
|
114
106
|
file_opt(opt)
|
115
|
-
changelog_opt(opt)
|
116
107
|
url_opt(opt)
|
117
108
|
pr_number(opt)
|
118
109
|
https_opt(opt)
|
@@ -178,7 +169,6 @@ class OptParserInternal
|
|
178
169
|
# set some default values
|
179
170
|
def defaults_false
|
180
171
|
@options[:check] = false if @options[:check].nil?
|
181
|
-
@options[:changelog_test] = false if @options[:changelog_test].nil?
|
182
172
|
@options[:target_url] = '' if @options[:target_url].nil?
|
183
173
|
@options[:https] = false if @options[:https].nil?
|
184
174
|
@options[:changed_since] = -1 if @options[:changed_since].nil?
|
@@ -187,7 +177,6 @@ class OptParserInternal
|
|
187
177
|
|
188
178
|
def defaults_to_text
|
189
179
|
desc = 'use option -d to set a custom test description.'
|
190
|
-
@options[:file_type] = '.changes' if @options[:changelog_test]
|
191
180
|
@options[:description] = desc if @options[:description].nil?
|
192
181
|
@options[:file_type] = 'notype' if @options[:file_type].nil?
|
193
182
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: gitarro
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.53
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Dario Maiocchi
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2017-10-
|
11
|
+
date: 2017-10-18 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: english
|
@@ -25,131 +25,131 @@ dependencies:
|
|
25
25
|
- !ruby/object:Gem::Version
|
26
26
|
version: '0.6'
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
|
-
name:
|
28
|
+
name: netrc
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
30
30
|
requirements:
|
31
31
|
- - "~>"
|
32
32
|
- !ruby/object:Gem::Version
|
33
|
-
version: '
|
33
|
+
version: '0.11'
|
34
34
|
type: :runtime
|
35
35
|
prerelease: false
|
36
36
|
version_requirements: !ruby/object:Gem::Requirement
|
37
37
|
requirements:
|
38
38
|
- - "~>"
|
39
39
|
- !ruby/object:Gem::Version
|
40
|
-
version: '
|
40
|
+
version: '0.11'
|
41
41
|
- !ruby/object:Gem::Dependency
|
42
|
-
name:
|
42
|
+
name: octokit
|
43
43
|
requirement: !ruby/object:Gem::Requirement
|
44
44
|
requirements:
|
45
45
|
- - "~>"
|
46
46
|
- !ruby/object:Gem::Version
|
47
|
-
version: '
|
47
|
+
version: '4.7'
|
48
48
|
type: :runtime
|
49
49
|
prerelease: false
|
50
50
|
version_requirements: !ruby/object:Gem::Requirement
|
51
51
|
requirements:
|
52
52
|
- - "~>"
|
53
53
|
- !ruby/object:Gem::Version
|
54
|
-
version: '
|
54
|
+
version: '4.7'
|
55
55
|
- !ruby/object:Gem::Dependency
|
56
|
-
name:
|
56
|
+
name: activesupport
|
57
57
|
requirement: !ruby/object:Gem::Requirement
|
58
58
|
requirements:
|
59
59
|
- - "~>"
|
60
60
|
- !ruby/object:Gem::Version
|
61
|
-
version: '
|
61
|
+
version: '5.1'
|
62
62
|
type: :runtime
|
63
63
|
prerelease: false
|
64
64
|
version_requirements: !ruby/object:Gem::Requirement
|
65
65
|
requirements:
|
66
66
|
- - "~>"
|
67
67
|
- !ruby/object:Gem::Version
|
68
|
-
version: '
|
68
|
+
version: '5.1'
|
69
69
|
- !ruby/object:Gem::Dependency
|
70
|
-
name:
|
70
|
+
name: faraday-http-cache
|
71
71
|
requirement: !ruby/object:Gem::Requirement
|
72
72
|
requirements:
|
73
73
|
- - "~>"
|
74
74
|
- !ruby/object:Gem::Version
|
75
|
-
version: '
|
75
|
+
version: '2.0'
|
76
76
|
type: :runtime
|
77
77
|
prerelease: false
|
78
78
|
version_requirements: !ruby/object:Gem::Requirement
|
79
79
|
requirements:
|
80
80
|
- - "~>"
|
81
81
|
- !ruby/object:Gem::Version
|
82
|
-
version: '
|
82
|
+
version: '2.0'
|
83
83
|
- !ruby/object:Gem::Dependency
|
84
|
-
name:
|
84
|
+
name: minitest
|
85
85
|
requirement: !ruby/object:Gem::Requirement
|
86
86
|
requirements:
|
87
87
|
- - "~>"
|
88
88
|
- !ruby/object:Gem::Version
|
89
|
-
version: '
|
90
|
-
type: :
|
89
|
+
version: '5.9'
|
90
|
+
type: :development
|
91
91
|
prerelease: false
|
92
92
|
version_requirements: !ruby/object:Gem::Requirement
|
93
93
|
requirements:
|
94
94
|
- - "~>"
|
95
95
|
- !ruby/object:Gem::Version
|
96
|
-
version: '
|
96
|
+
version: '5.9'
|
97
97
|
- !ruby/object:Gem::Dependency
|
98
|
-
name:
|
98
|
+
name: minitest-reporters
|
99
99
|
requirement: !ruby/object:Gem::Requirement
|
100
100
|
requirements:
|
101
101
|
- - "~>"
|
102
102
|
- !ruby/object:Gem::Version
|
103
|
-
version: '
|
104
|
-
type: :
|
103
|
+
version: '1.1'
|
104
|
+
type: :development
|
105
105
|
prerelease: false
|
106
106
|
version_requirements: !ruby/object:Gem::Requirement
|
107
107
|
requirements:
|
108
108
|
- - "~>"
|
109
109
|
- !ruby/object:Gem::Version
|
110
|
-
version: '
|
110
|
+
version: '1.1'
|
111
111
|
- !ruby/object:Gem::Dependency
|
112
|
-
name:
|
112
|
+
name: rake
|
113
113
|
requirement: !ruby/object:Gem::Requirement
|
114
114
|
requirements:
|
115
115
|
- - "~>"
|
116
116
|
- !ruby/object:Gem::Version
|
117
|
-
version: '
|
118
|
-
type: :
|
117
|
+
version: '10.5'
|
118
|
+
type: :development
|
119
119
|
prerelease: false
|
120
120
|
version_requirements: !ruby/object:Gem::Requirement
|
121
121
|
requirements:
|
122
122
|
- - "~>"
|
123
123
|
- !ruby/object:Gem::Version
|
124
|
-
version: '
|
124
|
+
version: '10.5'
|
125
125
|
- !ruby/object:Gem::Dependency
|
126
|
-
name:
|
126
|
+
name: rubocop
|
127
127
|
requirement: !ruby/object:Gem::Requirement
|
128
128
|
requirements:
|
129
129
|
- - "~>"
|
130
130
|
- !ruby/object:Gem::Version
|
131
|
-
version: '
|
132
|
-
type: :
|
131
|
+
version: '0.49'
|
132
|
+
type: :development
|
133
133
|
prerelease: false
|
134
134
|
version_requirements: !ruby/object:Gem::Requirement
|
135
135
|
requirements:
|
136
136
|
- - "~>"
|
137
137
|
- !ruby/object:Gem::Version
|
138
|
-
version: '
|
138
|
+
version: '0.49'
|
139
139
|
- !ruby/object:Gem::Dependency
|
140
|
-
name:
|
140
|
+
name: rspec
|
141
141
|
requirement: !ruby/object:Gem::Requirement
|
142
142
|
requirements:
|
143
143
|
- - "~>"
|
144
144
|
- !ruby/object:Gem::Version
|
145
|
-
version: '
|
146
|
-
type: :
|
145
|
+
version: '3.6'
|
146
|
+
type: :development
|
147
147
|
prerelease: false
|
148
148
|
version_requirements: !ruby/object:Gem::Requirement
|
149
149
|
requirements:
|
150
150
|
- - "~>"
|
151
151
|
- !ruby/object:Gem::Version
|
152
|
-
version: '
|
152
|
+
version: '3.6'
|
153
153
|
description: gitarro run tests on GitHub PRs using almost any script,language or binary,
|
154
154
|
it integrate easy with other tools.
|
155
155
|
email: dmaiocchi@suse.com
|