lazylead 0.3.1 → 0.5.0
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/.0pdd.yml +4 -1
- data/.docs/accuracy.md +107 -0
- data/.docs/accuracy_email.jpg +0 -0
- data/.docs/accuracy_jira_comment.jpg +0 -0
- data/.docs/duedate_expired.md +3 -3
- data/.docs/propagate_down.md +4 -4
- data/.gitattributes +1 -0
- data/.github/dependabot.yml +6 -0
- data/.pdd +1 -1
- data/.rubocop.yml +6 -0
- data/Rakefile +2 -0
- data/bin/lazylead +7 -4
- data/lazylead.gemspec +5 -4
- data/lib/lazylead/exchange.rb +16 -9
- data/lib/lazylead/log.rb +30 -8
- data/lib/lazylead/model.rb +78 -22
- data/lib/lazylead/opts.rb +80 -0
- data/lib/lazylead/postman.rb +1 -1
- data/lib/lazylead/schedule.rb +18 -17
- data/lib/lazylead/smtp.rb +1 -1
- data/lib/lazylead/system/jira.rb +55 -14
- data/lib/lazylead/system/synced.rb +2 -1
- data/lib/lazylead/task/accuracy/accuracy.rb +136 -0
- data/lib/lazylead/task/accuracy/affected_build.rb +39 -0
- data/lib/lazylead/task/accuracy/attachment.rb +44 -0
- data/lib/lazylead/task/accuracy/environment.rb +39 -0
- data/lib/lazylead/task/accuracy/logs.rb +40 -0
- data/lib/lazylead/task/accuracy/records.rb +45 -0
- data/lib/lazylead/task/accuracy/requirement.rb +49 -0
- data/lib/lazylead/task/accuracy/servers.rb +50 -0
- data/lib/lazylead/task/accuracy/stacktrace.rb +63 -0
- data/lib/lazylead/task/accuracy/testcase.rb +75 -0
- data/lib/lazylead/task/accuracy/wiki.rb +41 -0
- data/lib/lazylead/task/alert.rb +8 -6
- data/lib/lazylead/task/confluence_ref.rb +4 -3
- data/lib/lazylead/task/echo.rb +22 -0
- data/lib/lazylead/task/fix_version.rb +18 -7
- data/lib/lazylead/task/missing_comment.rb +7 -5
- data/lib/lazylead/task/propagate_down.rb +11 -3
- data/lib/lazylead/task/savepoint.rb +1 -1
- data/lib/lazylead/task/touch.rb +119 -0
- data/lib/lazylead/version.rb +1 -1
- data/lib/messages/accuracy.erb +118 -0
- data/lib/messages/svn_log.erb +117 -0
- data/lib/messages/svn_touch.erb +147 -0
- data/license.txt +1 -1
- data/readme.md +20 -19
- data/test/lazylead/cc_test.rb +2 -2
- data/test/lazylead/cli/app_test.rb +12 -12
- data/test/lazylead/exchange_test.rb +3 -3
- data/test/lazylead/model_test.rb +4 -4
- data/test/lazylead/opts_test.rb +70 -0
- data/test/lazylead/postman_test.rb +1 -1
- data/test/lazylead/smtp_test.rb +1 -1
- data/test/lazylead/system/jira_test.rb +65 -1
- data/test/lazylead/task/accuracy/accuracy_test.rb +73 -0
- data/test/lazylead/task/accuracy/affected_build_test.rb +42 -0
- data/test/lazylead/task/accuracy/attachment_test.rb +50 -0
- data/test/lazylead/task/accuracy/environment_test.rb +42 -0
- data/test/lazylead/task/accuracy/logs_test.rb +78 -0
- data/test/lazylead/task/accuracy/records_test.rb +60 -0
- data/test/lazylead/task/accuracy/servers_test.rb +66 -0
- data/test/lazylead/task/accuracy/stacktrace_test.rb +113 -0
- data/test/lazylead/task/accuracy/testcase_test.rb +205 -0
- data/test/lazylead/task/accuracy/wiki_test.rb +40 -0
- data/test/lazylead/task/assignee_alert_test.rb +2 -2
- data/test/lazylead/task/duedate_test.rb +36 -26
- data/test/lazylead/task/fix_version_test.rb +9 -6
- data/test/lazylead/task/missing_comment_test.rb +11 -9
- data/test/lazylead/task/propagate_down_test.rb +4 -2
- data/test/lazylead/task/touch_test.rb +88 -0
- data/test/test.rb +25 -0
- data/upgrades/sqlite/001-install-main-lazylead-tables.sql +1 -5
- data/upgrades/sqlite/999.testdata.sql +12 -16
- metadata +65 -8
- data/.travis.yml +0 -16
@@ -34,8 +34,8 @@ require_relative "../../../lib/lazylead/task/alert"
|
|
34
34
|
|
35
35
|
module Lazylead
|
36
36
|
class AssigneeAlertTest < Lazylead::Test
|
37
|
-
test "issue #154
|
38
|
-
CLI::App.new(Log
|
37
|
+
test "issue #154 undefined method to_hash for nil object" do
|
38
|
+
CLI::App.new(Log.new, NoSchedule.new).run(
|
39
39
|
home: ".",
|
40
40
|
sqlite: "test/resources/#{no_ext(__FILE__)}.#{__method__}.db",
|
41
41
|
vcs4sql: "upgrades/sqlite",
|
@@ -41,10 +41,12 @@ module Lazylead
|
|
41
41
|
Task::AssigneeAlert.new.run(
|
42
42
|
NoAuthJira.new("https://jira.spring.io"),
|
43
43
|
Postman.new,
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
44
|
+
Opts.new(
|
45
|
+
"from" => "fake@email.com",
|
46
|
+
"sql" => "filter=16743",
|
47
|
+
"subject" => "[DD] PDTN!",
|
48
|
+
"template" => "lib/messages/due_date_expired.erb"
|
49
|
+
)
|
48
50
|
)
|
49
51
|
assert_equal 2,
|
50
52
|
Mail::TestMailer.deliveries
|
@@ -53,7 +55,7 @@ module Lazylead
|
|
53
55
|
end
|
54
56
|
|
55
57
|
test "configuration properties merged successfully" do
|
56
|
-
CLI::App.new(Log
|
58
|
+
CLI::App.new(Log.new, NoSchedule.new).run(
|
57
59
|
home: ".",
|
58
60
|
sqlite: "test/resources/#{no_ext(__FILE__)}.#{__method__}.db",
|
59
61
|
vcs4sql: "upgrades/sqlite",
|
@@ -75,10 +77,12 @@ module Lazylead
|
|
75
77
|
Task::AssigneeAlert.new.run(
|
76
78
|
NoAuthJira.new("https://jira.spring.io"),
|
77
79
|
Postman.new,
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
80
|
+
Opts.new(
|
81
|
+
"from" => "fake@email.com",
|
82
|
+
"sql" => "key in ('STS-3599')",
|
83
|
+
"subject" => "[DD] HMCHT!",
|
84
|
+
"template" => "lib/messages/due_date_expired.erb"
|
85
|
+
)
|
82
86
|
)
|
83
87
|
assert_email "[DD] HMCHT!",
|
84
88
|
%w[STS-3599 2013-11-08 Major Miles\ Parker Use JavaFX WebView]
|
@@ -89,12 +93,14 @@ module Lazylead
|
|
89
93
|
Task::Alert.new.run(
|
90
94
|
NoAuthJira.new("https://jira.spring.io"),
|
91
95
|
Postman.new,
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
96
|
+
Opts.new(
|
97
|
+
"from" => "fake@email.com",
|
98
|
+
"sql" => "key in ('STS-3599')",
|
99
|
+
"subject" => "ALRT: Frozen",
|
100
|
+
"template" => "lib/messages/due_date_expired.erb",
|
101
|
+
"to" => "big.boss@example.com",
|
102
|
+
"addressee" => "Boss"
|
103
|
+
)
|
98
104
|
)
|
99
105
|
assert_email "ALRT: Frozen",
|
100
106
|
%w[Hi Boss STS-3599 2013-11-08 Major Miles\ Parker Use JavaFX WebView]
|
@@ -105,13 +111,15 @@ module Lazylead
|
|
105
111
|
Task::Alert.new.run(
|
106
112
|
NoAuthJira.new("https://jira.spring.io"),
|
107
113
|
Postman.new,
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
114
|
+
Opts.new(
|
115
|
+
"from" => "fake@email.com",
|
116
|
+
"sql" => "key in ('STS-3599')",
|
117
|
+
"subject" => "CC: Watching",
|
118
|
+
"template" => "lib/messages/due_date_expired.erb",
|
119
|
+
"to" => "big.boss@example.com",
|
120
|
+
"addressee" => "Boss",
|
121
|
+
"cc" => "another.boss@example.com,mom@home.com"
|
122
|
+
)
|
115
123
|
)
|
116
124
|
assert_equal %w[another.boss@example.com mom@home.com],
|
117
125
|
Mail::TestMailer.deliveries
|
@@ -124,10 +132,12 @@ module Lazylead
|
|
124
132
|
Task::ReporterAlert.new.run(
|
125
133
|
NoAuthJira.new("https://jira.spring.io"),
|
126
134
|
Postman.new,
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
135
|
+
Opts.new(
|
136
|
+
"from" => "fake@email.com",
|
137
|
+
"sql" => "filter=16743",
|
138
|
+
"subject" => "DD Expired!",
|
139
|
+
"template" => "lib/messages/due_date_expired.erb"
|
140
|
+
)
|
131
141
|
)
|
132
142
|
assert_equal 2,
|
133
143
|
Mail::TestMailer.deliveries
|
@@ -26,6 +26,7 @@ require "mail"
|
|
26
26
|
|
27
27
|
require_relative "../../test"
|
28
28
|
require_relative "../../../lib/lazylead/smtp"
|
29
|
+
require_relative "../../../lib/lazylead/opts"
|
29
30
|
require_relative "../../../lib/lazylead/postman"
|
30
31
|
require_relative "../../../lib/lazylead/task/fix_version"
|
31
32
|
|
@@ -36,12 +37,14 @@ module Lazylead
|
|
36
37
|
Task::FixVersion.new.run(
|
37
38
|
NoAuthJira.new("https://jira.spring.io"),
|
38
39
|
Postman.new,
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
40
|
+
Opts.new(
|
41
|
+
"to" => "lead@company.com",
|
42
|
+
"from" => "ll@company.com",
|
43
|
+
"jql" => "key in ('DATAJDBC-480') and fixVersion is not empty",
|
44
|
+
"allowed" => "tom,mike,bob",
|
45
|
+
"subject" => "FixVersion: How dare you?",
|
46
|
+
"template" => "lib/messages/illegal_fixversion_change.erb"
|
47
|
+
)
|
45
48
|
)
|
46
49
|
assert_email "FixVersion: How dare you?",
|
47
50
|
%w[DATAJDBC-480 01-Apr-2020 Minor Mark\ Paluch tom,mike,bob EntityInstantiators]
|
@@ -37,15 +37,17 @@ module Lazylead
|
|
37
37
|
Task::MissingComment.new.run(
|
38
38
|
NoAuthJira.new("https://jira.spring.io"),
|
39
39
|
Postman.new,
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
40
|
+
Opts.new(
|
41
|
+
"to" => "lead@company.com",
|
42
|
+
"addressee" => "Tom",
|
43
|
+
"from" => "ll@company.com",
|
44
|
+
"jql" => "key=DATAJDBC-523",
|
45
|
+
"text" => "ftp.com/demo.avi",
|
46
|
+
"details" => "reference to <code>ftp.com/demo.avi</code>",
|
47
|
+
"subject" => "Expected ftp link is missing",
|
48
|
+
"template" => "lib/messages/missing_comment.erb",
|
49
|
+
"template_details" => "reference to <a href='file://ftp/path'>ftp</a>"
|
50
|
+
)
|
49
51
|
)
|
50
52
|
assert_email "Expected ftp link is missing",
|
51
53
|
%w[DATAJDBC-523 Major Mark\ Paluch https://github.com/spring-projects/spring-data-jdbc/commit/aadbb667ed1d61139d5ac51a06eb3dd1b39316db#diff-510a5041bb8a0575e97fedf105606b83R130]
|
@@ -66,8 +66,10 @@ module Lazylead
|
|
66
66
|
Task::PropagateDown.new.run(
|
67
67
|
Fake.new([parent, child]),
|
68
68
|
[],
|
69
|
-
|
70
|
-
|
69
|
+
Opts.new(
|
70
|
+
"jql" => "type=Defect and updated>-1h and subtasks without fields",
|
71
|
+
"propagate" => "customfield_101,customfield_102"
|
72
|
+
)
|
71
73
|
)
|
72
74
|
assert_entries(
|
73
75
|
{
|
@@ -0,0 +1,88 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# The MIT License
|
4
|
+
#
|
5
|
+
# Copyright (c) 2019-2020 Yurii Dubinka
|
6
|
+
#
|
7
|
+
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
8
|
+
# of this software and associated documentation files (the "Software"),
|
9
|
+
# to deal in the Software without restriction, including without limitation
|
10
|
+
# the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
11
|
+
# and/or sell copies of the Software, and to permit persons to whom
|
12
|
+
# the Software is furnished to do so, subject to the following conditions:
|
13
|
+
#
|
14
|
+
# The above copyright notice and this permission notice shall be included
|
15
|
+
# in all copies or substantial portions of the Software.
|
16
|
+
#
|
17
|
+
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
18
|
+
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
19
|
+
# FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE
|
20
|
+
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
21
|
+
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
22
|
+
# ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE
|
23
|
+
# OR OTHER DEALINGS IN THE SOFTWARE.
|
24
|
+
|
25
|
+
require "mail"
|
26
|
+
require_relative "../../test"
|
27
|
+
require_relative "../../../lib/lazylead/smtp"
|
28
|
+
require_relative "../../../lib/lazylead/opts"
|
29
|
+
require_relative "../../../lib/lazylead/postman"
|
30
|
+
require_relative "../../../lib/lazylead/task/touch"
|
31
|
+
|
32
|
+
module Lazylead
|
33
|
+
class SvnTouchTest < Lazylead::Test
|
34
|
+
test "important files changed in svn repo" do
|
35
|
+
skip "No svn credentials provided" unless env? "svn_touch_user",
|
36
|
+
"svn_touch_password"
|
37
|
+
skip "No internet connection to riouxsvn.com" unless ping? "riouxsvn.com"
|
38
|
+
Lazylead::Smtp.new.enable
|
39
|
+
Task::SvnTouch.new.run(
|
40
|
+
[],
|
41
|
+
Postman.new,
|
42
|
+
Opts.new(
|
43
|
+
"svn_url" => "https://svn.riouxsvn.com/touch4ll",
|
44
|
+
"svn_user" => ENV["svn_touch_user"],
|
45
|
+
"svn_password" => ENV["svn_touch_password"],
|
46
|
+
"commit_url" => "https://view.commit.com?rev=",
|
47
|
+
"user" => "https://user.com?id=",
|
48
|
+
"to" => "lead@fake.com",
|
49
|
+
"from" => "ll@fake.com",
|
50
|
+
"now" => "2020-08-17T00:00:00+01:00",
|
51
|
+
"period" => "864000",
|
52
|
+
"files" => "189.md,absent.txt",
|
53
|
+
"subject" => "[SVN] Important files have been changed!",
|
54
|
+
"template" => "lib/messages/svn_touch.erb"
|
55
|
+
)
|
56
|
+
)
|
57
|
+
assert_email "[SVN] Important files have been changed!",
|
58
|
+
%w[3 dgroup /189.md Add\ description\ for\ 189\ issue]
|
59
|
+
end
|
60
|
+
end
|
61
|
+
|
62
|
+
class SvnLogTest < Lazylead::Test
|
63
|
+
test "changes since revision" do
|
64
|
+
skip "No svn credentials provided" unless env? "svn_log_user",
|
65
|
+
"svn_log_password"
|
66
|
+
skip "No internet connection to riouxsvn.com" unless ping? "riouxsvn.com"
|
67
|
+
Lazylead::Smtp.new.enable
|
68
|
+
Task::SvnLog.new.run(
|
69
|
+
[],
|
70
|
+
Postman.new,
|
71
|
+
Opts.new(
|
72
|
+
"from" => "svnlog@test.com",
|
73
|
+
"svn_url" => "https://svn.riouxsvn.com/touch4ll",
|
74
|
+
"svn_user" => ENV["svn_log_user"],
|
75
|
+
"svn_password" => ENV["svn_log_password"],
|
76
|
+
"commit_url" => "https://view.commit.com?rev=",
|
77
|
+
"user" => "https://user.com?id=",
|
78
|
+
"to" => "lead@fake.com",
|
79
|
+
"since_rev" => "1",
|
80
|
+
"subject" => "[SVN] Changed since rev1",
|
81
|
+
"template" => "lib/messages/svn_log.erb"
|
82
|
+
)
|
83
|
+
)
|
84
|
+
assert_email_line "[SVN] Changed since rev1",
|
85
|
+
%w[r2 by dgroup at 2020-08-16]
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|
data/test/test.rb
CHANGED
@@ -110,5 +110,30 @@ module Lazylead
|
|
110
110
|
.first
|
111
111
|
.body.parts.first.body.raw_source
|
112
112
|
end
|
113
|
+
|
114
|
+
# Assert that email sent using 'mail' gem in test mode
|
115
|
+
# has expected subject and line with expected words
|
116
|
+
# @todo #/DEV Gem 'mail' sends email as a single line, find a way how to add
|
117
|
+
# symbol '\n' to each line for email during unit testing.
|
118
|
+
def assert_email_line(subject, words)
|
119
|
+
words = [words] unless words.respond_to? :each
|
120
|
+
mail = Mail::TestMailer.deliveries
|
121
|
+
.filter { |m| m.subject.eql? subject }
|
122
|
+
.first
|
123
|
+
.body.parts.first.body.raw_source
|
124
|
+
.split("\n")
|
125
|
+
.reject(&:blank?)
|
126
|
+
assert mail.any? { |line| words.all? { |w| line.include? w } },
|
127
|
+
"Words '#{words.join(',')}' wasn't found in '#{mail.join('\n')}'"
|
128
|
+
end
|
129
|
+
|
130
|
+
# Ping remote host
|
131
|
+
# https://github.com/eitoball/net-ping
|
132
|
+
# https://stackoverflow.com/a/35508446/6916890
|
133
|
+
# https://rubygems.org/gems/net-ping/versions/2.0.8
|
134
|
+
def ping?(host)
|
135
|
+
require "net/ping"
|
136
|
+
Net::Ping::External.new(host).ping?
|
137
|
+
end
|
113
138
|
end
|
114
139
|
end
|
@@ -46,11 +46,7 @@ create table if not exists tasks
|
|
46
46
|
(
|
47
47
|
id integer primary key,
|
48
48
|
name text not null,
|
49
|
-
|
50
|
-
-- @todo #/DEV task.cron - add support for non-cron based schedule like at, once, every.
|
51
|
-
-- More details:
|
52
|
-
-- https://github.com/jmettraux/rufus-scheduler
|
53
|
-
-- https://stackoverflow.com/questions/46691666/using-constantize-to-invoke-both-a-class-and-method-from-separate-strings
|
49
|
+
schedule text not null,
|
54
50
|
system integer not null,
|
55
51
|
action text not null,
|
56
52
|
team_id integer not null,
|
@@ -22,23 +22,19 @@
|
|
22
22
|
* OR OTHER DEALINGS IN THE SOFTWARE.
|
23
23
|
*/
|
24
24
|
insert into systems(id, properties)
|
25
|
-
values (1,
|
26
|
-
|
27
|
-
(2,
|
28
|
-
'{"type":"Lazylead::Jira", "username":"${jsi_usr}", "password":"${jsi_psw}", "site":"https://jira.spring.io", "context_path":""}');
|
25
|
+
values (1,'{"type":"Lazylead::Jira", "username":"", "password":"", "site":"https://jira.spring.io", "context_path":""}'),
|
26
|
+
(2,'{"type":"Lazylead::Jira", "username":"${jsi_usr}", "password":"${jsi_psw}", "site":"https://jira.spring.io", "context_path":""}');
|
29
27
|
insert into teams(id, name, properties)
|
30
28
|
values (1, 'BA squad', '{"from":"basquad@fake.com", "usr":"${usr}"}'),
|
31
29
|
(154, 'Team for issue #154', '{"cc":"lead@fake.com"}');
|
32
|
-
insert into tasks(name,
|
33
|
-
values ('echo', '
|
34
|
-
('expired due date', '
|
35
|
-
|
36
|
-
|
37
|
-
('task with cc', '* * * * *', 'false', 3, 1, 1, 'Lazylead::Task::Echo',
|
38
|
-
'{"cc":"leelakenny@mail.com,maciecrane@mail.com"}'),
|
39
|
-
('task', '* * * * *', 'false', 4, 2, 1, 'Lazylead::Task::Echo', '{}'),
|
30
|
+
insert into tasks(name, schedule, enabled, id, system, team_id, action, properties)
|
31
|
+
values ('echo', 'cron:* * * * *', 'false', 1, 1, 1, 'Lazylead::Task::Echo', '{}'),
|
32
|
+
('expired due date', 'cron:* * * * *', 'false', 2, 1, 1,'Lazylead::Task::Notification','{"sql":"filter=100500","subject":"[DD] PDTN!","template":"lib/messages/due_date_expired.erb"}'),
|
33
|
+
('task with cc', 'cron:* * * * *', 'false', 3, 1, 1, 'Lazylead::Task::Echo','{"cc":"leelakenny@mail.com,maciecrane@mail.com"}'),
|
34
|
+
('task', 'cron:* * * * *', 'false', 4, 2, 1, 'Lazylead::Task::Echo', '{}'),
|
40
35
|
('pman', '', '', 5, 2, 1, '', '{"postman":"Lazylead::Postman"}'),
|
41
|
-
('issue 154', '
|
42
|
-
('task with complex cc', '
|
43
|
-
|
44
|
-
('issue
|
36
|
+
('issue 154', '', 'false', 154, 1, 154, 'Lazylead::Task::AssigneeAlert', '{}'),
|
37
|
+
('task with complex cc', '', 'false', 165, 1, 1, 'Lazylead::Task::Echo','{"cc":{"type":"Lazylead::PredefinedCC","opts": {"jvm":"tom@fake.com","jdbc":"mike@fake.com"}}}'),
|
38
|
+
('issue 171', '', 'false', 171, 1, 1, 'Lazylead::Task::Echo', '{"envkey":"${key171}"}'),
|
39
|
+
('issue 195', '', 'false', 195, 1, 1, 'Lazylead::Task::Accuracy', '{"key":"value"}'),
|
40
|
+
('issue 130', 'in:0.001s', 'true', 130, 1, 1, 'Lazylead::Task::EchoIO', '{}');
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: lazylead
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.5.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Yurii Dubinka
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2020-
|
11
|
+
date: 2020-10-05 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activerecord
|
@@ -86,14 +86,14 @@ dependencies:
|
|
86
86
|
requirements:
|
87
87
|
- - '='
|
88
88
|
- !ruby/object:Gem::Version
|
89
|
-
version: 2.
|
89
|
+
version: 2.3.0
|
90
90
|
type: :runtime
|
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: 2.
|
96
|
+
version: 2.3.0
|
97
97
|
- !ruby/object:Gem::Dependency
|
98
98
|
name: logging
|
99
99
|
requirement: !ruby/object:Gem::Requirement
|
@@ -296,14 +296,14 @@ dependencies:
|
|
296
296
|
requirements:
|
297
297
|
- - '='
|
298
298
|
- !ruby/object:Gem::Version
|
299
|
-
version: 0.
|
299
|
+
version: 0.2.3
|
300
300
|
type: :development
|
301
301
|
prerelease: false
|
302
302
|
version_requirements: !ruby/object:Gem::Requirement
|
303
303
|
requirements:
|
304
304
|
- - '='
|
305
305
|
- !ruby/object:Gem::Version
|
306
|
-
version: 0.
|
306
|
+
version: 0.2.3
|
307
307
|
- !ruby/object:Gem::Dependency
|
308
308
|
name: guard
|
309
309
|
requirement: !ruby/object:Gem::Requirement
|
@@ -388,6 +388,20 @@ dependencies:
|
|
388
388
|
- - '='
|
389
389
|
- !ruby/object:Gem::Version
|
390
390
|
version: 1.3.6
|
391
|
+
- !ruby/object:Gem::Dependency
|
392
|
+
name: net-ping
|
393
|
+
requirement: !ruby/object:Gem::Requirement
|
394
|
+
requirements:
|
395
|
+
- - '='
|
396
|
+
- !ruby/object:Gem::Version
|
397
|
+
version: 2.0.8
|
398
|
+
type: :development
|
399
|
+
prerelease: false
|
400
|
+
version_requirements: !ruby/object:Gem::Requirement
|
401
|
+
requirements:
|
402
|
+
- - '='
|
403
|
+
- !ruby/object:Gem::Version
|
404
|
+
version: 2.0.8
|
391
405
|
- !ruby/object:Gem::Dependency
|
392
406
|
name: rake
|
393
407
|
requirement: !ruby/object:Gem::Requirement
|
@@ -541,6 +555,9 @@ files:
|
|
541
555
|
- ".docker/docker-compose.yml"
|
542
556
|
- ".docker/readme.md"
|
543
557
|
- ".docker/vcs.dockerfile"
|
558
|
+
- ".docs/accuracy.md"
|
559
|
+
- ".docs/accuracy_email.jpg"
|
560
|
+
- ".docs/accuracy_jira_comment.jpg"
|
544
561
|
- ".docs/duedate_expired.md"
|
545
562
|
- ".docs/propagate_down.md"
|
546
563
|
- ".gitattributes"
|
@@ -550,6 +567,7 @@ files:
|
|
550
567
|
- ".github/ISSUE_TEMPLATE/bug_report.md"
|
551
568
|
- ".github/ISSUE_TEMPLATE/feature_request.md"
|
552
569
|
- ".github/PULL_REQUEST_TEMPLATE.md"
|
570
|
+
- ".github/dependabot.yml"
|
553
571
|
- ".github/tasks.yml"
|
554
572
|
- ".github/trello.md"
|
555
573
|
- ".gitignore"
|
@@ -558,7 +576,6 @@ files:
|
|
558
576
|
- ".ruby-version"
|
559
577
|
- ".rultor.yml"
|
560
578
|
- ".simplecov"
|
561
|
-
- ".travis.yml"
|
562
579
|
- CNAME
|
563
580
|
- Gemfile
|
564
581
|
- Guardfile
|
@@ -578,6 +595,7 @@ files:
|
|
578
595
|
- lib/lazylead/home.rb
|
579
596
|
- lib/lazylead/log.rb
|
580
597
|
- lib/lazylead/model.rb
|
598
|
+
- lib/lazylead/opts.rb
|
581
599
|
- lib/lazylead/postman.rb
|
582
600
|
- lib/lazylead/salt.rb
|
583
601
|
- lib/lazylead/schedule.rb
|
@@ -586,6 +604,17 @@ files:
|
|
586
604
|
- lib/lazylead/system/fake.rb
|
587
605
|
- lib/lazylead/system/jira.rb
|
588
606
|
- lib/lazylead/system/synced.rb
|
607
|
+
- lib/lazylead/task/accuracy/accuracy.rb
|
608
|
+
- lib/lazylead/task/accuracy/affected_build.rb
|
609
|
+
- lib/lazylead/task/accuracy/attachment.rb
|
610
|
+
- lib/lazylead/task/accuracy/environment.rb
|
611
|
+
- lib/lazylead/task/accuracy/logs.rb
|
612
|
+
- lib/lazylead/task/accuracy/records.rb
|
613
|
+
- lib/lazylead/task/accuracy/requirement.rb
|
614
|
+
- lib/lazylead/task/accuracy/servers.rb
|
615
|
+
- lib/lazylead/task/accuracy/stacktrace.rb
|
616
|
+
- lib/lazylead/task/accuracy/testcase.rb
|
617
|
+
- lib/lazylead/task/accuracy/wiki.rb
|
589
618
|
- lib/lazylead/task/alert.rb
|
590
619
|
- lib/lazylead/task/confluence_ref.rb
|
591
620
|
- lib/lazylead/task/echo.rb
|
@@ -593,11 +622,15 @@ files:
|
|
593
622
|
- lib/lazylead/task/missing_comment.rb
|
594
623
|
- lib/lazylead/task/propagate_down.rb
|
595
624
|
- lib/lazylead/task/savepoint.rb
|
625
|
+
- lib/lazylead/task/touch.rb
|
596
626
|
- lib/lazylead/version.rb
|
627
|
+
- lib/messages/accuracy.erb
|
597
628
|
- lib/messages/due_date_expired.erb
|
598
629
|
- lib/messages/illegal_fixversion_change.erb
|
599
630
|
- lib/messages/missing_comment.erb
|
600
631
|
- lib/messages/savepoint.erb
|
632
|
+
- lib/messages/svn_log.erb
|
633
|
+
- lib/messages/svn_touch.erb
|
601
634
|
- license.txt
|
602
635
|
- readme.md
|
603
636
|
- test/lazylead/allocated_test.rb
|
@@ -606,11 +639,22 @@ files:
|
|
606
639
|
- test/lazylead/confluence_test.rb
|
607
640
|
- test/lazylead/exchange_test.rb
|
608
641
|
- test/lazylead/model_test.rb
|
642
|
+
- test/lazylead/opts_test.rb
|
609
643
|
- test/lazylead/postman_test.rb
|
610
644
|
- test/lazylead/salt_test.rb
|
611
645
|
- test/lazylead/smoke_test.rb
|
612
646
|
- test/lazylead/smtp_test.rb
|
613
647
|
- test/lazylead/system/jira_test.rb
|
648
|
+
- test/lazylead/task/accuracy/accuracy_test.rb
|
649
|
+
- test/lazylead/task/accuracy/affected_build_test.rb
|
650
|
+
- test/lazylead/task/accuracy/attachment_test.rb
|
651
|
+
- test/lazylead/task/accuracy/environment_test.rb
|
652
|
+
- test/lazylead/task/accuracy/logs_test.rb
|
653
|
+
- test/lazylead/task/accuracy/records_test.rb
|
654
|
+
- test/lazylead/task/accuracy/servers_test.rb
|
655
|
+
- test/lazylead/task/accuracy/stacktrace_test.rb
|
656
|
+
- test/lazylead/task/accuracy/testcase_test.rb
|
657
|
+
- test/lazylead/task/accuracy/wiki_test.rb
|
614
658
|
- test/lazylead/task/assignee_alert_test.rb
|
615
659
|
- test/lazylead/task/confluence_ref_test.rb
|
616
660
|
- test/lazylead/task/duedate_test.rb
|
@@ -619,6 +663,7 @@ files:
|
|
619
663
|
- test/lazylead/task/missing_comment_test.rb
|
620
664
|
- test/lazylead/task/propagate_down_test.rb
|
621
665
|
- test/lazylead/task/savepoint_test.rb
|
666
|
+
- test/lazylead/task/touch_test.rb
|
622
667
|
- test/lazylead/version_test.rb
|
623
668
|
- test/sqlite_test.rb
|
624
669
|
- test/test.rb
|
@@ -629,7 +674,7 @@ licenses:
|
|
629
674
|
- MIT
|
630
675
|
metadata: {}
|
631
676
|
post_install_message: |-
|
632
|
-
Thanks for installing Lazylead v0.
|
677
|
+
Thanks for installing Lazylead v0.5.0!
|
633
678
|
Read our blog posts: https://lazylead.org
|
634
679
|
Stay in touch with the community in Telegram: https://t.me/lazylead
|
635
680
|
Follow us on Twitter: https://twitter.com/lazylead
|
@@ -660,11 +705,22 @@ test_files:
|
|
660
705
|
- test/lazylead/confluence_test.rb
|
661
706
|
- test/lazylead/exchange_test.rb
|
662
707
|
- test/lazylead/model_test.rb
|
708
|
+
- test/lazylead/opts_test.rb
|
663
709
|
- test/lazylead/postman_test.rb
|
664
710
|
- test/lazylead/salt_test.rb
|
665
711
|
- test/lazylead/smoke_test.rb
|
666
712
|
- test/lazylead/smtp_test.rb
|
667
713
|
- test/lazylead/system/jira_test.rb
|
714
|
+
- test/lazylead/task/accuracy/accuracy_test.rb
|
715
|
+
- test/lazylead/task/accuracy/affected_build_test.rb
|
716
|
+
- test/lazylead/task/accuracy/attachment_test.rb
|
717
|
+
- test/lazylead/task/accuracy/environment_test.rb
|
718
|
+
- test/lazylead/task/accuracy/logs_test.rb
|
719
|
+
- test/lazylead/task/accuracy/records_test.rb
|
720
|
+
- test/lazylead/task/accuracy/servers_test.rb
|
721
|
+
- test/lazylead/task/accuracy/stacktrace_test.rb
|
722
|
+
- test/lazylead/task/accuracy/testcase_test.rb
|
723
|
+
- test/lazylead/task/accuracy/wiki_test.rb
|
668
724
|
- test/lazylead/task/assignee_alert_test.rb
|
669
725
|
- test/lazylead/task/confluence_ref_test.rb
|
670
726
|
- test/lazylead/task/duedate_test.rb
|
@@ -673,6 +729,7 @@ test_files:
|
|
673
729
|
- test/lazylead/task/missing_comment_test.rb
|
674
730
|
- test/lazylead/task/propagate_down_test.rb
|
675
731
|
- test/lazylead/task/savepoint_test.rb
|
732
|
+
- test/lazylead/task/touch_test.rb
|
676
733
|
- test/lazylead/version_test.rb
|
677
734
|
- test/sqlite_test.rb
|
678
735
|
- test/test.rb
|