lazylead 0.3.1 → 0.5.0
Sign up to get free protection for your applications and to get access to all the features.
- 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
@@ -0,0 +1,117 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html lang="en">
|
3
|
+
<head>
|
4
|
+
<style>
|
5
|
+
/* CSS styles taken from https://github.com/yegor256/tacit */
|
6
|
+
pre, code, kbd, samp, var, output {
|
7
|
+
font-family: Menlo, Monaco, Consolas, "Courier New", monospace;
|
8
|
+
font-size: 14.4px
|
9
|
+
}
|
10
|
+
|
11
|
+
pre code {
|
12
|
+
background: none;
|
13
|
+
border: 0;
|
14
|
+
line-height: 29.7px;
|
15
|
+
padding: 0
|
16
|
+
}
|
17
|
+
|
18
|
+
code, kbd {
|
19
|
+
background: #daf1e0;
|
20
|
+
border-radius: 3.6px;
|
21
|
+
color: #2a6f3b;
|
22
|
+
display: inline-block;
|
23
|
+
line-height: 18px;
|
24
|
+
padding: 3.6px 6.3px 2.7px
|
25
|
+
}
|
26
|
+
|
27
|
+
a {
|
28
|
+
color: #275a90;
|
29
|
+
text-decoration: none
|
30
|
+
}
|
31
|
+
|
32
|
+
a:hover {
|
33
|
+
text-decoration: underline
|
34
|
+
}
|
35
|
+
|
36
|
+
* {
|
37
|
+
border: 0;
|
38
|
+
border-collapse: separate;
|
39
|
+
border-spacing: 0;
|
40
|
+
box-sizing: border-box;
|
41
|
+
margin: 0;
|
42
|
+
max-width: 100%;
|
43
|
+
padding: 0;
|
44
|
+
vertical-align: baseline;
|
45
|
+
font-family: system-ui, "Helvetica Neue", Helvetica, Arial, sans-serif;
|
46
|
+
font-size: 13px;
|
47
|
+
font-stretch: normal;
|
48
|
+
font-style: normal;
|
49
|
+
font-weight: 400;
|
50
|
+
line-height: 29.7px
|
51
|
+
}
|
52
|
+
|
53
|
+
html, body {
|
54
|
+
width: 100%
|
55
|
+
}
|
56
|
+
|
57
|
+
html {
|
58
|
+
height: 100%
|
59
|
+
}
|
60
|
+
|
61
|
+
body {
|
62
|
+
background: #fff;
|
63
|
+
color: #1a1919;
|
64
|
+
padding: 36px
|
65
|
+
}
|
66
|
+
|
67
|
+
.commit {
|
68
|
+
min-width: 100%;
|
69
|
+
border-radius: 3.5px;
|
70
|
+
overflow: hidden;
|
71
|
+
display: inline-block;
|
72
|
+
line-height: 15px;
|
73
|
+
font-family: Menlo, Monaco, Consolas, "Courier New", monospace;
|
74
|
+
border: 1px solid #BCC6CC;
|
75
|
+
}
|
76
|
+
|
77
|
+
.commit * {
|
78
|
+
padding-left: 4px;
|
79
|
+
font-size: 8px;
|
80
|
+
line-height: 15px;
|
81
|
+
}
|
82
|
+
</style>
|
83
|
+
<title>SVN log</title>
|
84
|
+
</head>
|
85
|
+
<body>
|
86
|
+
<p>Hi,</p>
|
87
|
+
<p>The following file(s) changed since <code><%= since_rev %></code> rev in <a href="<%= svn_url %>"><%= svn_url %></a>:</p>
|
88
|
+
<% stdout.split("------------------------------------------------------------------------").reject(&:blank?).reverse.each do |commit| %>
|
89
|
+
<div class="commit">
|
90
|
+
<% commit.split("\n").reject(&:blank?).each_with_index do |line, index| %>
|
91
|
+
<% if index.zero? %>
|
92
|
+
<% details = line.split("|").map(&:strip).reject(&:blank?) %>
|
93
|
+
<p style="background: gainsboro;">
|
94
|
+
<a href="<%= commit_url %><%= details[0][1 .. -1] %>"><%= details[0] %></a>
|
95
|
+
by<a href="<%= user %><%= details[1] %>"><%= details[1] %></a>
|
96
|
+
at<span style="color: #275a90;"><%= details[2] %></span>
|
97
|
+
</p>
|
98
|
+
<% else %>
|
99
|
+
<% if line.start_with?("+++") || line.start_with?("---") %>
|
100
|
+
<p style="background: gainsboro;"><%= line.gsub(/[<>]/, '<' => '<', '>' => '>') %></p>
|
101
|
+
<% elsif line.start_with?("+") %>
|
102
|
+
<p style="<%= "background: darkseagreen;" %>"><%= line.gsub(/[<>]/, '<' => '<', '>' => '>') %></p>
|
103
|
+
<% elsif line.start_with?("-") %>
|
104
|
+
<p style="<%= "background: lightsalmon;" %>"><%= line.gsub(/[<>]/, '<' => '<', '>' => '>') %></p>
|
105
|
+
<% else %>
|
106
|
+
<p style="background: gainsboro;"><%= line.gsub(/[<>]/,'<' => '<', '>' => '>') %></p>
|
107
|
+
<% end %>
|
108
|
+
<% end %>
|
109
|
+
<% end %>
|
110
|
+
</div>
|
111
|
+
<br/><br/><br/>
|
112
|
+
<% end %>
|
113
|
+
<p>Posted by
|
114
|
+
<a href="https://github.com/dgroup/lazylead">lazylead v<%= version %></a>.
|
115
|
+
</p>
|
116
|
+
</body>
|
117
|
+
</html>
|
@@ -0,0 +1,147 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html lang="en">
|
3
|
+
<head>
|
4
|
+
<style>
|
5
|
+
/* CSS styles taken from https://github.com/yegor256/tacit */
|
6
|
+
th {
|
7
|
+
font-weight: 600;
|
8
|
+
text-align: left;
|
9
|
+
}
|
10
|
+
|
11
|
+
td {
|
12
|
+
vertical-align: top;
|
13
|
+
}
|
14
|
+
|
15
|
+
table tr {
|
16
|
+
border-bottom-width: 2.16px
|
17
|
+
}
|
18
|
+
|
19
|
+
table tr th {
|
20
|
+
border-bottom-width: 2.16px
|
21
|
+
}
|
22
|
+
|
23
|
+
table tr td, table tr th {
|
24
|
+
overflow: hidden; /*padding: 5.4px 3.6px*/
|
25
|
+
padding-left: 2px;
|
26
|
+
padding-right: 2px;
|
27
|
+
}
|
28
|
+
|
29
|
+
td:nth-child(3) {
|
30
|
+
min-width: 120px;
|
31
|
+
max-width: 200px;
|
32
|
+
}
|
33
|
+
|
34
|
+
td:nth-child(4) {
|
35
|
+
min-width: 300px;
|
36
|
+
max-width: 500px;
|
37
|
+
}
|
38
|
+
|
39
|
+
pre, code, kbd, samp, var, output {
|
40
|
+
font-family: Menlo, Monaco, Consolas, "Courier New", monospace;
|
41
|
+
font-size: 14.4px
|
42
|
+
}
|
43
|
+
|
44
|
+
pre code {
|
45
|
+
background: none;
|
46
|
+
border: 0;
|
47
|
+
line-height: 29.7px;
|
48
|
+
padding: 0
|
49
|
+
}
|
50
|
+
|
51
|
+
code, kbd {
|
52
|
+
background: #daf1e0;
|
53
|
+
border-radius: 3.6px;
|
54
|
+
color: #2a6f3b;
|
55
|
+
display: inline-block;
|
56
|
+
line-height: 18px;
|
57
|
+
padding: 3.6px 6.3px 2.7px
|
58
|
+
}
|
59
|
+
|
60
|
+
a {
|
61
|
+
color: #275a90;
|
62
|
+
text-decoration: none
|
63
|
+
}
|
64
|
+
|
65
|
+
a:hover {
|
66
|
+
text-decoration: underline
|
67
|
+
}
|
68
|
+
|
69
|
+
* {
|
70
|
+
border: 0;
|
71
|
+
border-collapse: separate;
|
72
|
+
border-spacing: 0;
|
73
|
+
box-sizing: border-box;
|
74
|
+
margin: 0;
|
75
|
+
max-width: 100%;
|
76
|
+
padding: 0;
|
77
|
+
vertical-align: baseline;
|
78
|
+
font-family: system-ui, "Helvetica Neue", Helvetica, Arial, sans-serif;
|
79
|
+
font-size: 13px;
|
80
|
+
font-stretch: normal;
|
81
|
+
font-style: normal;
|
82
|
+
font-weight: 400;
|
83
|
+
line-height: 29.7px
|
84
|
+
}
|
85
|
+
|
86
|
+
html, body {
|
87
|
+
width: 100%
|
88
|
+
}
|
89
|
+
|
90
|
+
html {
|
91
|
+
height: 100%
|
92
|
+
}
|
93
|
+
|
94
|
+
body {
|
95
|
+
background: #fff;
|
96
|
+
color: #1a1919;
|
97
|
+
padding: 36px
|
98
|
+
}
|
99
|
+
|
100
|
+
.msg {
|
101
|
+
background: #eff6e8;
|
102
|
+
border-radius: 3.6px;
|
103
|
+
color: #2a6f3b;
|
104
|
+
display: inline-block;
|
105
|
+
line-height: 18px;
|
106
|
+
padding: 3.6px 6.3px 2.7px
|
107
|
+
}
|
108
|
+
</style>
|
109
|
+
<title>SVN touch</title>
|
110
|
+
</head>
|
111
|
+
<body>
|
112
|
+
<p>Hi,</p>
|
113
|
+
<p>The critical file(s) <code><%= files %></code> have been changed recently:</p>
|
114
|
+
<table summary="table with svn commits where critical files have been changed">
|
115
|
+
<tr>
|
116
|
+
<th id="rev">Revision</th>
|
117
|
+
<th id="author">Author</th>
|
118
|
+
<th id="when">When</th>
|
119
|
+
<th id="files">File(s)</th>
|
120
|
+
<th id="commit_msg">Commit</th>
|
121
|
+
</tr>
|
122
|
+
<% entries.each do |e| %>
|
123
|
+
<tr>
|
124
|
+
<td><a href="<%= commit_url %><%= e.revision %>"><%= e.revision %></a></td>
|
125
|
+
<td><a href="<%= user %><%= e.author %>"><%= e.author %></a></td>
|
126
|
+
<td><%= Time.strptime(e.date, "%Y-%m-%dT%H:%M").strftime("%Y-%m-%d %H:%M") %></td>
|
127
|
+
<td>
|
128
|
+
<% if e.paths.path.respond_to? :join %>
|
129
|
+
<%= e.paths
|
130
|
+
.path
|
131
|
+
.map { |file| "<a href='#{commit_url}#{e.revision}'>#{file}</a>" }
|
132
|
+
.join("<br/>") %>
|
133
|
+
<% else %>
|
134
|
+
<a href="<%= commit_url %><%= e.revision %>"><%= e.paths.path %></a>
|
135
|
+
<% end %>
|
136
|
+
</td>
|
137
|
+
<td>
|
138
|
+
<div class="msg"><%= e.msg %></div>
|
139
|
+
</td>
|
140
|
+
</tr>
|
141
|
+
<% end %>
|
142
|
+
</table>
|
143
|
+
<p>Posted by
|
144
|
+
<a href="https://github.com/dgroup/lazylead">lazylead v<%= version %></a>.
|
145
|
+
</p>
|
146
|
+
</body>
|
147
|
+
</html>
|
data/license.txt
CHANGED
data/readme.md
CHANGED
@@ -38,6 +38,7 @@ Join our telegram group [lazylead.org](https://t.me/lazyleads) for discussions.
|
|
38
38
|
| [Notify about illegal "Fix Version" modification](lib/lazylead/task/fix_version.rb) | ✅ | ❌ | ❌ |
|
39
39
|
| [Expected comment in ticket is missing](lib/lazylead/task/missing_comment.rb) | ✅ | ⌛ | ⌛ |
|
40
40
|
| [Propagate some fields from parent ticket into sub-tasks](.docs/propagate_down.md) | ✅ | ❌ | ❌ |
|
41
|
+
| [Evaluate the ticket formatting accuracy](.docs/accuracy.md) | ✅ | ⌛ | ⌛ |
|
41
42
|
| Print the current capacity of team into newly created tasks | ⌛ | ⌛ | ⌛ |
|
42
43
|
| Create/retrofit the defect automatically into latest release | ⌛ | ⌛ | ❌ |
|
43
44
|
| [Notify about expired(ing) due dates](.docs/duedate_expired.md) | ✅ | ❌ | ⌛ |
|
@@ -112,13 +113,14 @@ For simplicity, we are using [docker-compose](https://docs.docker.com/compose/):
|
|
112
113
|
ll > docker-compose -f .github/tasks.yml up
|
113
114
|
Creating lazylead ... done
|
114
115
|
Attaching to lazylead
|
115
|
-
lazylead | [2020-
|
116
|
-
lazylead | [2020-
|
117
|
-
lazylead | [2020-
|
118
|
-
lazylead | [2020-
|
119
|
-
lazylead | [2020-
|
120
|
-
lazylead | [2020-
|
121
|
-
lazylead | [2020-
|
116
|
+
lazylead | [2020-08-09T06:17:32] DEBUG [main] Version: 0.5.0
|
117
|
+
lazylead | [2020-08-09T06:17:32] DEBUG [main] Memory footprint at start is 52MB
|
118
|
+
lazylead | [2020-08-09T06:17:32] DEBUG [main] Database: '/lazylead/db/ll.db', sql migration dir: '/lazylead/upgrades/sqlite'
|
119
|
+
lazylead | [2020-08-09T06:17:32] DEBUG [main] Migration applied to /lazylead/db/ll.db from /lazylead/upgrades/sqlite
|
120
|
+
lazylead | [2020-08-09T06:17:32] DEBUG [main] Database connection established
|
121
|
+
lazylead | [2020-08-09T06:17:32] DEBUG [main] SMTP connection established with {host} as {user}.
|
122
|
+
lazylead | [2020-08-09T06:17:32] WARN [main] ll-001: No tasks found.
|
123
|
+
lazylead | [2020-08-09T06:17:32] DEBUG [main] Memory footprint at the end is 67MB
|
122
124
|
lazylead exited with code 0
|
123
125
|
ll >
|
124
126
|
```
|
@@ -133,16 +135,16 @@ For simplicity, we are using [docker-compose](https://docs.docker.com/compose/):
|
|
133
135
|
values (1, 'Dream team with lazylead', '{}');
|
134
136
|
insert into systems(id, properties)
|
135
137
|
values (1,'{"type":"Lazylead::Jira", "username":"${jira_user}", "password":"${jira_password}", "site":"${jira_url}", "context_path":""}');
|
136
|
-
insert into tasks (name,
|
138
|
+
insert into tasks (name, schedule, enabled, id, system, team_id, action, properties)
|
137
139
|
values ('Expired due dates',
|
138
|
-
'0 8 * * 1-5',
|
140
|
+
'cron:0 8 * * 1-5',
|
139
141
|
'true',
|
140
142
|
1, 1, 1,
|
141
143
|
'Lazylead::Task::AssigneeAlert',
|
142
144
|
'{"sql":"filter=555", "cc":"<youremail.com>", "subject":"[LL] Expired due dates", "template":"lib/messages/due_date_expired.erb", "postman":"Lazylead::Exchange"}');
|
143
145
|
|
144
146
|
```
|
145
|
-
Yes, for task scheduling we are using [cron](https://crontab.guru).
|
147
|
+
Yes, for task scheduling we are using [cron](https://crontab.guru) here, but you may use other scheduling types from [rufus-scheduler](https://github.com/jmettraux/rufus-scheduler).
|
146
148
|
|
147
149
|
4. Once you changed `./ll.db`, please restart the container using `docker-compose -f .github/tasks.yml restart`
|
148
150
|
```bash
|
@@ -152,15 +154,14 @@ For simplicity, we are using [docker-compose](https://docs.docker.com/compose/):
|
|
152
154
|
check the logs and stop container if needed
|
153
155
|
```bash
|
154
156
|
ll > docker logs lazylead
|
155
|
-
2020-
|
156
|
-
[2020-
|
157
|
-
[2020-
|
158
|
-
[2020-
|
159
|
-
[2020-
|
160
|
-
[2020-
|
157
|
+
lazylead | [2020-08-09T06:17:32] DEBUG [main] Version: 0.5.0
|
158
|
+
lazylead | [2020-08-09T06:17:32] DEBUG [main] Memory footprint at start is 52MB
|
159
|
+
lazylead | [2020-08-09T06:17:32] DEBUG [main] Database: '/lazylead/db/ll.db', sql migration dir: '/lazylead/upgrades/sqlite'
|
160
|
+
lazylead | [2020-08-09T06:17:32] DEBUG [main] Migration applied to /lazylead/db/ll.db from /lazylead/upgrades/sqlite
|
161
|
+
lazylead | [2020-08-09T06:17:32] DEBUG [main] Database connection established
|
162
|
+
lazylead | [2020-08-09T06:17:32] DEBUG [main] SMTP connection established with {host} as {user}.
|
163
|
+
lazylead | [2020-08-09T06:17:32] DEBUG [main] Task scheduled: id='1', name='Expired due dates', cron='0 8 * * 1-5', system='1', action='Lazylead::Task::AssigneeAlert', team_id='1', description='', enabled='true', properties='{"sql":"filter=555", "cc":"my.email@google.com", "subject":"[LL] Expired due dates", "template":"lib/messages/due_date_expired.erb", "postman":"Lazylead::Exchange"}'
|
161
164
|
...
|
162
|
-
ll > docker stop lazylead
|
163
|
-
lazylead
|
164
165
|
```
|
165
166
|
|
166
167
|
### How to contribute?
|
@@ -173,4 +174,4 @@ bundle exec rake
|
|
173
174
|
Everyone interacting in this project’s codebases, issue trackers, chat rooms is expected to follow the [code of conduct](.github/CODE_OF_CONDUCT.md).
|
174
175
|
|
175
176
|
Contributors:
|
176
|
-
* [dgroup](https://github.com/dgroup) as Yurii Dubinka (yurii.dubinka@gmail.com)
|
177
|
+
* [dgroup](https://github.com/dgroup) as Yurii Dubinka ([yurii.dubinka@gmail.com](mailto:yurii.dubinka@gmail.com))
|
data/test/lazylead/cc_test.rb
CHANGED
@@ -129,7 +129,7 @@ module Lazylead
|
|
129
129
|
end
|
130
130
|
|
131
131
|
test "detect plain cc" do
|
132
|
-
CLI::App.new(Log
|
132
|
+
CLI::App.new(Log.new, NoSchedule.new).run(
|
133
133
|
home: ".",
|
134
134
|
sqlite: "test/resources/#{no_ext(__FILE__)}.#{__method__}.db",
|
135
135
|
vcs4sql: "upgrades/sqlite",
|
@@ -140,7 +140,7 @@ module Lazylead
|
|
140
140
|
end
|
141
141
|
|
142
142
|
test "detect complex cc by predefined component" do
|
143
|
-
CLI::App.new(Log
|
143
|
+
CLI::App.new(Log.new, NoSchedule.new).run(
|
144
144
|
home: ".",
|
145
145
|
sqlite: "test/resources/#{no_ext(__FILE__)}.#{__method__}.db",
|
146
146
|
vcs4sql: "upgrades/sqlite",
|
@@ -31,7 +31,7 @@ module Lazylead
|
|
31
31
|
module CLI
|
32
32
|
class AppTest < Lazylead::SqliteTest
|
33
33
|
test "LL database structure installed successfully" do
|
34
|
-
CLI::App.new(Log
|
34
|
+
CLI::App.new(Log.new, NoSchedule.new).run(
|
35
35
|
home: ".",
|
36
36
|
sqlite: "test/resources/#{no_ext(__FILE__)}.#{__method__}.db",
|
37
37
|
vcs4sql: "upgrades/sqlite"
|
@@ -39,14 +39,14 @@ module Lazylead
|
|
39
39
|
assert_tables "test/resources/#{no_ext(__FILE__)}.#{__method__}.db",
|
40
40
|
systems: %w[id properties],
|
41
41
|
teams: %w[id name properties],
|
42
|
-
tasks: %w[id name
|
42
|
+
tasks: %w[id name schedule system action team_id enabled properties]
|
43
43
|
assert_fk "test/resources/#{no_ext(__FILE__)}.#{__method__}.db",
|
44
44
|
%w[tasks team_id teams id],
|
45
45
|
%w[tasks system systems id]
|
46
46
|
end
|
47
47
|
|
48
48
|
test "activesupport is activated for access to domain entities" do
|
49
|
-
CLI::App.new(Log
|
49
|
+
CLI::App.new(Log.new, NoSchedule.new).run(
|
50
50
|
home: ".",
|
51
51
|
sqlite: "test/resources/#{no_ext(__FILE__)}.#{__method__}.db",
|
52
52
|
vcs4sql: "upgrades/sqlite",
|
@@ -57,16 +57,16 @@ module Lazylead
|
|
57
57
|
"Required team record wasn't found in the database"
|
58
58
|
end
|
59
59
|
|
60
|
-
# @todo #10/DEV Think about using "timecop" >v0.9.1 gem in order to make
|
61
|
-
# E2E application skeleton https://stackoverflow.com/questions/59955571.
|
62
|
-
# The depedency for gemspec should be after *thin* in .gemspec
|
63
|
-
# ..
|
64
|
-
# s.add_runtime_dependency "thin", "1.7.2"
|
65
|
-
# s.add_runtime_dependency "timecop", "0.9.1"
|
66
|
-
# ..
|
67
|
-
# More https://github.com/travisjeffery/timecop
|
68
60
|
test "scheduled task was triggered successfully" do
|
69
|
-
|
61
|
+
CLI::App.new(Log.new, Schedule.new(cling: false)).run(
|
62
|
+
home: ".",
|
63
|
+
sqlite: "test/resources/#{no_ext(__FILE__)}.#{__method__}.db",
|
64
|
+
vcs4sql: "upgrades/sqlite",
|
65
|
+
testdata: true
|
66
|
+
)
|
67
|
+
sleep 0.4
|
68
|
+
assert (Time.now - 5.seconds) < Time.parse(File.open("test/resources/echo.txt").first),
|
69
|
+
"Scheduled task wasn't executed few seconds ago"
|
70
70
|
end
|
71
71
|
end
|
72
72
|
end
|
@@ -36,7 +36,7 @@ module Lazylead
|
|
36
36
|
"exchange_user",
|
37
37
|
"exchange_password",
|
38
38
|
"exchange_to"
|
39
|
-
Exchange.new(Log
|
39
|
+
Exchange.new(Log.new, NoSalt.new).send(
|
40
40
|
to: ENV["exchange_to"],
|
41
41
|
tickets: NoAuthJira.new("https://jira.spring.io")
|
42
42
|
.issues("key = DATAJDBC-480"),
|
@@ -52,7 +52,7 @@ module Lazylead
|
|
52
52
|
"enc_exchange_psw",
|
53
53
|
"enc_exchange_to"
|
54
54
|
Exchange.new(
|
55
|
-
Log
|
55
|
+
Log.new,
|
56
56
|
Salt.new("exchange_salt"),
|
57
57
|
"exchange_url" => ENV["exchange_url"],
|
58
58
|
"exchange_user" => ENV["enc_exchange_usr"],
|
@@ -72,7 +72,7 @@ module Lazylead
|
|
72
72
|
"exchange_password",
|
73
73
|
"exchange_to"
|
74
74
|
Exchange.new(
|
75
|
-
Log
|
75
|
+
Log.new,
|
76
76
|
Salt.new("exchange_salt"),
|
77
77
|
"exchange_url" => ENV["exchange_url"],
|
78
78
|
"exchange_user" => ENV["enc_exchange_usr"],
|
data/test/lazylead/model_test.rb
CHANGED
@@ -31,7 +31,7 @@ require_relative "../../lib/lazylead/schedule"
|
|
31
31
|
module Lazylead
|
32
32
|
class OrmTest < Lazylead::SqliteTest
|
33
33
|
test "convert column to json" do
|
34
|
-
CLI::App.new(Log
|
34
|
+
CLI::App.new(Log.new, NoSchedule.new).run(
|
35
35
|
home: ".",
|
36
36
|
sqlite: "test/resources/#{no_ext(__FILE__)}.#{__method__}.db",
|
37
37
|
vcs4sql: "upgrades/sqlite",
|
@@ -42,7 +42,7 @@ module Lazylead
|
|
42
42
|
|
43
43
|
test "env properties injected" do
|
44
44
|
ENV["usr"] = "Mike"
|
45
|
-
CLI::App.new(Log
|
45
|
+
CLI::App.new(Log.new, NoSchedule.new).run(
|
46
46
|
home: ".",
|
47
47
|
sqlite: "test/resources/#{no_ext(__FILE__)}.#{__method__}.db",
|
48
48
|
vcs4sql: "upgrades/sqlite",
|
@@ -53,7 +53,7 @@ module Lazylead
|
|
53
53
|
end
|
54
54
|
|
55
55
|
test "postman initiated through orm" do
|
56
|
-
CLI::App.new(Log
|
56
|
+
CLI::App.new(Log.new, NoSchedule.new).run(
|
57
57
|
home: ".",
|
58
58
|
sqlite: "test/resources/#{no_ext(__FILE__)}.#{__method__}.db",
|
59
59
|
vcs4sql: "upgrades/sqlite",
|
@@ -64,7 +64,7 @@ module Lazylead
|
|
64
64
|
|
65
65
|
test "task properties are using ENV variables" do
|
66
66
|
ENV["key171"] = "value"
|
67
|
-
CLI::App.new(Log
|
67
|
+
CLI::App.new(Log.new, NoSchedule.new).run(
|
68
68
|
home: ".",
|
69
69
|
sqlite: "test/resources/#{no_ext(__FILE__)}.#{__method__}.db",
|
70
70
|
vcs4sql: "upgrades/sqlite",
|