lazylead 0.5.1 → 0.7.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.rubocop.yml +49 -1
- data/.simplecov +1 -1
- data/Guardfile +1 -1
- data/Rakefile +4 -3
- data/bin/lazylead +9 -5
- data/lazylead.gemspec +20 -15
- data/lib/lazylead/cc.rb +21 -20
- data/lib/lazylead/cli/app.rb +13 -5
- data/lib/lazylead/confluence.rb +8 -1
- data/lib/lazylead/email.rb +0 -20
- data/lib/lazylead/exchange.rb +16 -28
- data/lib/lazylead/log.rb +2 -1
- data/lib/lazylead/model.rb +31 -16
- data/lib/lazylead/opts.rb +65 -2
- data/lib/lazylead/postman.rb +18 -16
- data/lib/lazylead/salt.rb +1 -0
- data/lib/lazylead/smtp.rb +3 -1
- data/lib/lazylead/system/jira.rb +31 -6
- data/lib/lazylead/task/accuracy/accuracy.rb +8 -10
- data/lib/lazylead/task/accuracy/attachment.rb +0 -4
- data/lib/lazylead/task/accuracy/logs.rb +8 -4
- data/lib/lazylead/task/accuracy/onlyll.rb +148 -0
- data/lib/lazylead/task/accuracy/records.rb +1 -1
- data/lib/lazylead/task/accuracy/servers.rb +16 -7
- data/lib/lazylead/task/accuracy/stacktrace.rb +50 -10
- data/lib/lazylead/task/accuracy/testcase.rb +23 -6
- data/lib/lazylead/task/assignment.rb +96 -0
- data/lib/lazylead/task/fix_version.rb +6 -0
- data/lib/lazylead/task/propagate_down.rb +1 -1
- data/lib/lazylead/task/svn/diff.rb +77 -0
- data/lib/lazylead/task/svn/grep.rb +139 -0
- data/lib/lazylead/task/svn/touch.rb +99 -0
- data/lib/lazylead/version.rb +1 -1
- data/lib/messages/illegal_assignee_change.erb +123 -0
- data/lib/messages/illegal_fixversion_change.erb +8 -0
- data/lib/messages/only_ll.erb +107 -0
- data/lib/messages/svn_diff.erb +110 -0
- data/lib/messages/{svn_log.erb → svn_diff_attachment.erb} +19 -9
- data/lib/messages/svn_grep.erb +114 -0
- data/test/lazylead/cc_test.rb +1 -0
- data/test/lazylead/model_test.rb +20 -0
- data/test/lazylead/opts_test.rb +47 -0
- data/test/lazylead/postman_test.rb +8 -5
- data/test/lazylead/smoke_test.rb +13 -0
- data/test/lazylead/system/jira_test.rb +6 -7
- data/test/lazylead/task/accuracy/logs_test.rb +62 -2
- data/test/lazylead/task/accuracy/onlyll_test.rb +138 -0
- data/test/lazylead/task/accuracy/servers_test.rb +2 -2
- data/test/lazylead/task/accuracy/stacktrace_test.rb +227 -0
- data/test/lazylead/task/accuracy/testcase_test.rb +49 -0
- data/test/lazylead/task/assignment_test.rb +53 -0
- data/test/lazylead/task/fix_version_test.rb +1 -0
- data/test/lazylead/task/propagate_down_test.rb +4 -3
- data/test/lazylead/task/savepoint_test.rb +7 -4
- data/test/lazylead/task/svn/diff_test.rb +97 -0
- data/test/lazylead/task/svn/grep_test.rb +103 -0
- data/test/lazylead/task/{touch_test.rb → svn/touch_test.rb} +7 -34
- data/test/test.rb +7 -6
- data/upgrades/sqlite/999.testdata.sql +3 -1
- metadata +120 -34
- data/lib/lazylead/task/touch.rb +0 -119
@@ -42,7 +42,7 @@ module Lazylead
|
|
42
42
|
end
|
43
43
|
|
44
44
|
test "url to failed entity found in description" do
|
45
|
-
assert Servers.new(envs: [%r{(http|https)
|
45
|
+
assert Servers.new(envs: [%r{(http|https)://\w+:\d+/.{10,}}]).passed(
|
46
46
|
Task.new(
|
47
47
|
"1. Open the dedicated app
|
48
48
|
2. Click on https://server:6900/object?id=2000
|
@@ -53,7 +53,7 @@ module Lazylead
|
|
53
53
|
end
|
54
54
|
|
55
55
|
test "url to failed entity not present in description" do
|
56
|
-
refute Servers.new(envs: [%r{(http|https)
|
56
|
+
refute Servers.new(envs: [%r{(http|https)://\w+:\d+/.{10,}}]).passed(
|
57
57
|
Task.new(
|
58
58
|
"1. Open the dedicated app
|
59
59
|
2. Click on https://server:6900/
|
@@ -57,6 +57,36 @@ module Lazylead
|
|
57
57
|
)
|
58
58
|
end
|
59
59
|
|
60
|
+
test "java stacktrace is found in uppercase" do
|
61
|
+
assert Stacktrace.new.passed(
|
62
|
+
OpenStruct.new(
|
63
|
+
description: "
|
64
|
+
XXXXXX env: http://xxxx.xxx.com:00000/
|
65
|
+
WL log [^clust1.log]
|
66
|
+
http://xxx.xxx.com/display/xxx/SQLException+No+more+data+to+read+from+socket
|
67
|
+
|
68
|
+
During call we found in clust1.log the following error
|
69
|
+
{NoFoRmAt}
|
70
|
+
at xxx.xxx.xxx.xxx.wrapper.XxxXxxXxxxXxx.xxxxXxxxXxxx(XxxXxxXxxxXxx.java:233)
|
71
|
+
at xxx.xxx.xxx.xxx.wrapper.XxxXxxXxxxXxx.xxxxXxxxXxxx(XxxXxxXxxxXxx.java:343)
|
72
|
+
... 318 more
|
73
|
+
Caused by: javax.transaction.TransactionRolledbackException: EJB Exception: ; nested exception is:
|
74
|
+
javax.ejb.TransactionRolledbackLocalException: EJB Exception:
|
75
|
+
at weblogic.utils.StackTraceDisabled.unknownMethod()
|
76
|
+
Caused by: javax.ejb.TransactionRolledbackLocalException: EJB Exception:
|
77
|
+
... 1 more
|
78
|
+
Caused by: javax.ejb.EJBException: java.sql.SQLRecoverableException: No more data to read from socket
|
79
|
+
... 1 more
|
80
|
+
Caused by: java.sql.SQLRecoverableException: No more data to read from socket
|
81
|
+
... 1 more
|
82
|
+
{NoFoRmAt}
|
83
|
+
|
84
|
+
The investigation is required.
|
85
|
+
More details here: XXXXX-xxxxxx"
|
86
|
+
)
|
87
|
+
)
|
88
|
+
end
|
89
|
+
|
60
90
|
test "stacktrace is found" do
|
61
91
|
assert Stacktrace.new.passed(
|
62
92
|
OpenStruct.new(
|
@@ -95,6 +125,14 @@ module Lazylead
|
|
95
125
|
)
|
96
126
|
end
|
97
127
|
|
128
|
+
test "exception is found" do
|
129
|
+
assert Stacktrace.new.passed(
|
130
|
+
OpenStruct.new(
|
131
|
+
description: "{noformat}sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target; nested exception is javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target{noformat}"
|
132
|
+
)
|
133
|
+
)
|
134
|
+
end
|
135
|
+
|
98
136
|
test "ORA error is found" do
|
99
137
|
assert Stacktrace.new.passed(
|
100
138
|
OpenStruct.new(
|
@@ -109,5 +147,194 @@ module Lazylead
|
|
109
147
|
)
|
110
148
|
)
|
111
149
|
end
|
150
|
+
|
151
|
+
test "ORA error is found in uppercase" do
|
152
|
+
assert Stacktrace.new.passed(
|
153
|
+
OpenStruct.new(
|
154
|
+
description: "
|
155
|
+
{NOFORMAT}
|
156
|
+
@XXXX/xxx/xxx/xxxx_xxx_xxxxx_xxx_xx.sql
|
157
|
+
ORA-02291: 1 integrity constraint (XXX_XXX_XXX.XX_xxx) violated - xx xxx not found for xx_xx=xx xxxxx_xx=XXXXXXX xxxxx=XXXXXXXX xxx_xx=xxx xx_xxx=xxxx.xxx.xxx.xxxxx.xxx.xxx.xxxxx
|
158
|
+
XXXX-xxx-xxxx: xxxxx xxxxx Xxxxx xxxx Xxxx
|
159
|
+
{NOFORMAT}
|
160
|
+
|
161
|
+
XXXX - XXX_XXX.X.XXXX.XXXX.XXXX.XxxxxxXX.X_xxxXXXXXX"
|
162
|
+
)
|
163
|
+
)
|
164
|
+
end
|
165
|
+
|
166
|
+
test "java error is found in code section" do
|
167
|
+
assert Stacktrace.new.passed(
|
168
|
+
OpenStruct.new(
|
169
|
+
description: "
|
170
|
+
asdfasdfasdf
|
171
|
+
{code:java}texta-line1
|
172
|
+
;texta-line2{code}
|
173
|
+
asdjf;asdjfa;sdjf
|
174
|
+
as;djf;asdjf
|
175
|
+
{code}javax.servlet.ServletException: Something went wrong
|
176
|
+
at com.example.myproject.OpenSessionInViewFilter.doFilter(OpenSessionInViewFilter.java:60)
|
177
|
+
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
|
178
|
+
at com.example.myproject.ExceptionHandlerFilter.doFilter(ExceptionHandlerFilter.java:28)
|
179
|
+
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
|
180
|
+
at com.example.myproject.OutputBufferFilter.doFilter(OutputBufferFilter.java:33)
|
181
|
+
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
|
182
|
+
at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:388)
|
183
|
+
at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
|
184
|
+
at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:182)
|
185
|
+
at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:765)
|
186
|
+
at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:418)
|
187
|
+
at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
|
188
|
+
at org.mortbay.jetty.Server.handle(Server.java:326)
|
189
|
+
at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:542)
|
190
|
+
at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:943)
|
191
|
+
at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:756)
|
192
|
+
at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:218)
|
193
|
+
at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:404)
|
194
|
+
at org.mortbay.jetty.bio.SocketConnector$Connection.run(SocketConnector.java:228)
|
195
|
+
at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:582)
|
196
|
+
Caused by: com.example.myproject.MyProjectServletException
|
197
|
+
at com.example.myproject.MyServlet.doPost(MyServlet.java:169)
|
198
|
+
at javax.servlet.http.HttpServlet.service(HttpServlet.java:727)
|
199
|
+
at javax.servlet.http.HttpServlet.service(HttpServlet.java:820)
|
200
|
+
at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:511)
|
201
|
+
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1166)
|
202
|
+
at com.example.myproject.OpenSessionInViewFilter.doFilter(OpenSessionInViewFilter.java:30)
|
203
|
+
... 27 more
|
204
|
+
Caused by: org.hibernate.exception.ConstraintViolationException: could not insert: [com.example.myproject.MyEntity]
|
205
|
+
at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:96)
|
206
|
+
at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:66)
|
207
|
+
at org.hibernate.id.insert.AbstractSelectingDelegate.performInsert(AbstractSelectingDelegate.java:64)
|
208
|
+
at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:2329)
|
209
|
+
at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:2822)
|
210
|
+
at org.hibernate.action.EntityIdentityInsertAction.execute(EntityIdentityInsertAction.java:71)
|
211
|
+
at org.hibernate.engine.ActionQueue.execute(ActionQueue.java:268)
|
212
|
+
at org.hibernate.event.def.AbstractSaveEventListener.performSaveOrReplicate(AbstractSaveEventListener.java:321)
|
213
|
+
at org.hibernate.event.def.AbstractSaveEventListener.performSave(AbstractSaveEventListener.java:204)
|
214
|
+
at org.hibernate.event.def.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:130)
|
215
|
+
at org.hibernate.event.def.DefaultSaveOrUpdateEventListener.saveWithGeneratedOrRequestedId(DefaultSaveOrUpdateEventListener.java:210)
|
216
|
+
at org.hibernate.event.def.DefaultSaveEventListener.saveWithGeneratedOrRequestedId(DefaultSaveEventListener.java:56)
|
217
|
+
at org.hibernate.event.def.DefaultSaveOrUpdateEventListener.entityIsTransient(DefaultSaveOrUpdateEventListener.java:195)
|
218
|
+
at org.hibernate.event.def.DefaultSaveEventListener.performSaveOrUpdate(DefaultSaveEventListener.java:50)
|
219
|
+
at org.hibernate.event.def.DefaultSaveOrUpdateEventListener.onSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:93)
|
220
|
+
at org.hibernate.impl.SessionImpl.fireSave(SessionImpl.java:705)
|
221
|
+
at org.hibernate.impl.SessionImpl.save(SessionImpl.java:693)
|
222
|
+
at org.hibernate.impl.SessionImpl.save(SessionImpl.java:689)
|
223
|
+
at sun.reflect.GeneratedMethodAccessor5.invoke(Unknown Source)
|
224
|
+
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
|
225
|
+
at java.lang.reflect.Method.invoke(Method.java:597)
|
226
|
+
at org.hibernate.context.ThreadLocalSessionContext$TransactionProtectionWrapper.invoke(ThreadLocalSessionContext.java:344)
|
227
|
+
at $Proxy19.save(Unknown Source)
|
228
|
+
at com.example.myproject.MyEntityService.save(MyEntityService.java:59) <-- relevant call (see notes below)
|
229
|
+
at com.example.myproject.MyServlet.doPost(MyServlet.java:164)
|
230
|
+
... 32 more
|
231
|
+
Caused by: java.sql.SQLException: Violation of unique constraint MY_ENTITY_UK_1: duplicate value(s) for column(s) MY_COLUMN in statement [...]
|
232
|
+
at org.hsqldb.jdbc.Util.throwError(Unknown Source)
|
233
|
+
at org.hsqldb.jdbc.jdbcPreparedStatement.executeUpdate(Unknown Source)
|
234
|
+
at com.mchange.v2.c3p0.impl.NewProxyPreparedStatement.executeUpdate(NewProxyPreparedStatement.java:105)
|
235
|
+
at org.hibernate.id.insert.AbstractSelectingDelegate.performInsert(AbstractSelectingDelegate.java:57)
|
236
|
+
... 54 more{code}
|
237
|
+
asdfasdfasdf{code:sql}select 1 from dual {code}what?
|
238
|
+
"
|
239
|
+
)
|
240
|
+
)
|
241
|
+
end
|
242
|
+
|
243
|
+
test "java error is found in code section in uppercase" do
|
244
|
+
assert Stacktrace.new.passed(
|
245
|
+
OpenStruct.new(
|
246
|
+
description: "
|
247
|
+
{CODE}javax.servlet.ServletException: Something went wrong
|
248
|
+
at com.example.myproject.OpenSessionInViewFilter.doFilter(OpenSessionInViewFilter.java:60)
|
249
|
+
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
|
250
|
+
at com.example.myproject.ExceptionHandlerFilter.doFilter(ExceptionHandlerFilter.java:28)
|
251
|
+
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
|
252
|
+
at com.example.myproject.OutputBufferFilter.doFilter(OutputBufferFilter.java:33)
|
253
|
+
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
|
254
|
+
at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:388)
|
255
|
+
at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
|
256
|
+
at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:182)
|
257
|
+
at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:765)
|
258
|
+
at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:418)
|
259
|
+
at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
|
260
|
+
at org.mortbay.jetty.Server.handle(Server.java:326)
|
261
|
+
at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:542)
|
262
|
+
at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:943)
|
263
|
+
at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:756)
|
264
|
+
at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:218)
|
265
|
+
at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:404)
|
266
|
+
at org.mortbay.jetty.bio.SocketConnector$Connection.run(SocketConnector.java:228)
|
267
|
+
at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:582)
|
268
|
+
Caused by: com.example.myproject.MyProjectServletException
|
269
|
+
at com.example.myproject.MyServlet.doPost(MyServlet.java:169)
|
270
|
+
at javax.servlet.http.HttpServlet.service(HttpServlet.java:727)
|
271
|
+
at javax.servlet.http.HttpServlet.service(HttpServlet.java:820)
|
272
|
+
at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:511)
|
273
|
+
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1166)
|
274
|
+
at com.example.myproject.OpenSessionInViewFilter.doFilter(OpenSessionInViewFilter.java:30)
|
275
|
+
... 27 more
|
276
|
+
Caused by: org.hibernate.exception.ConstraintViolationException: could not insert: [com.example.myproject.MyEntity]
|
277
|
+
at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:96)
|
278
|
+
at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:66)
|
279
|
+
at org.hibernate.id.insert.AbstractSelectingDelegate.performInsert(AbstractSelectingDelegate.java:64)
|
280
|
+
at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:2329)
|
281
|
+
at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:2822)
|
282
|
+
at org.hibernate.action.EntityIdentityInsertAction.execute(EntityIdentityInsertAction.java:71)
|
283
|
+
at org.hibernate.engine.ActionQueue.execute(ActionQueue.java:268)
|
284
|
+
at org.hibernate.event.def.AbstractSaveEventListener.performSaveOrReplicate(AbstractSaveEventListener.java:321)
|
285
|
+
at org.hibernate.event.def.AbstractSaveEventListener.performSave(AbstractSaveEventListener.java:204)
|
286
|
+
at org.hibernate.event.def.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:130)
|
287
|
+
at org.hibernate.event.def.DefaultSaveOrUpdateEventListener.saveWithGeneratedOrRequestedId(DefaultSaveOrUpdateEventListener.java:210)
|
288
|
+
at org.hibernate.event.def.DefaultSaveEventListener.saveWithGeneratedOrRequestedId(DefaultSaveEventListener.java:56)
|
289
|
+
at org.hibernate.event.def.DefaultSaveOrUpdateEventListener.entityIsTransient(DefaultSaveOrUpdateEventListener.java:195)
|
290
|
+
at org.hibernate.event.def.DefaultSaveEventListener.performSaveOrUpdate(DefaultSaveEventListener.java:50)
|
291
|
+
at org.hibernate.event.def.DefaultSaveOrUpdateEventListener.onSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:93)
|
292
|
+
at org.hibernate.impl.SessionImpl.fireSave(SessionImpl.java:705)
|
293
|
+
at org.hibernate.impl.SessionImpl.save(SessionImpl.java:693)
|
294
|
+
at org.hibernate.impl.SessionImpl.save(SessionImpl.java:689)
|
295
|
+
at sun.reflect.GeneratedMethodAccessor5.invoke(Unknown Source)
|
296
|
+
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
|
297
|
+
at java.lang.reflect.Method.invoke(Method.java:597)
|
298
|
+
at org.hibernate.context.ThreadLocalSessionContext$TransactionProtectionWrapper.invoke(ThreadLocalSessionContext.java:344)
|
299
|
+
at $Proxy19.save(Unknown Source)
|
300
|
+
at com.example.myproject.MyEntityService.save(MyEntityService.java:59) <-- relevant call (see notes below)
|
301
|
+
at com.example.myproject.MyServlet.doPost(MyServlet.java:164)
|
302
|
+
... 32 more
|
303
|
+
Caused by: java.sql.SQLException: Violation of unique constraint MY_ENTITY_UK_1: duplicate value(s) for column(s) MY_COLUMN in statement [...]
|
304
|
+
at org.hsqldb.jdbc.Util.throwError(Unknown Source)
|
305
|
+
at org.hsqldb.jdbc.jdbcPreparedStatement.executeUpdate(Unknown Source)
|
306
|
+
at com.mchange.v2.c3p0.impl.NewProxyPreparedStatement.executeUpdate(NewProxyPreparedStatement.java:105)
|
307
|
+
at org.hibernate.id.insert.AbstractSelectingDelegate.performInsert(AbstractSelectingDelegate.java:57)
|
308
|
+
... 54 more{CODE}
|
309
|
+
"
|
310
|
+
)
|
311
|
+
)
|
312
|
+
end
|
313
|
+
|
314
|
+
test "java error is found in colored code section in uppercase" do
|
315
|
+
assert Stacktrace.new.passed(
|
316
|
+
OpenStruct.new(
|
317
|
+
description: "
|
318
|
+
{CODE:red}
|
319
|
+
Caused by: java.sql.SQLException: Violation of unique constraint MY_ENTITY_UK_1: duplicate value(s) for column(s) MY_COLUMN in statement [...]
|
320
|
+
at org.hsqldb.jdbc.Util.throwError(Unknown Source)
|
321
|
+
at org.hsqldb.jdbc.jdbcPreparedStatement.executeUpdate(Unknown Source)
|
322
|
+
at com.mchange.v2.c3p0.impl.NewProxyPreparedStatement.executeUpdate(NewProxyPreparedStatement.java:105)
|
323
|
+
at org.hibernate.id.insert.AbstractSelectingDelegate.performInsert(AbstractSelectingDelegate.java:57)
|
324
|
+
... 54 more{CODE}
|
325
|
+
"
|
326
|
+
)
|
327
|
+
)
|
328
|
+
end
|
329
|
+
|
330
|
+
test "pair detected" do
|
331
|
+
assert_equal [[1, 4]],
|
332
|
+
Stacktrace.new.pairs(%w[aa tag bb cc tag dd], "tag")
|
333
|
+
end
|
334
|
+
|
335
|
+
test "proper pair detected" do
|
336
|
+
assert_equal [[1, 4]],
|
337
|
+
Stacktrace.new.pairs(%w[aa tag bb cc tag dd tag], "tag")
|
338
|
+
end
|
112
339
|
end
|
113
340
|
end
|
@@ -197,6 +197,55 @@ module Lazylead
|
|
197
197
|
[^screenshot-1.png]"
|
198
198
|
end
|
199
199
|
|
200
|
+
test "tc with colored ar er" do
|
201
|
+
assert testcase? "*TC:*
|
202
|
+
# Step 1
|
203
|
+
# Step 2
|
204
|
+
# Step ..
|
205
|
+
# Step N
|
206
|
+
{color:#00673A}ER{color}: XXXX
|
207
|
+
{color:#DE10AA}AR{color}: YYYY"
|
208
|
+
end
|
209
|
+
|
210
|
+
test "tc with colored bold ar er" do
|
211
|
+
assert testcase? "*TC:*
|
212
|
+
# Step 1
|
213
|
+
# Step 2
|
214
|
+
# Step ..
|
215
|
+
# Step N
|
216
|
+
*{color:#00673A}ER{color}* = XXXX
|
217
|
+
*{color:#DE10AA}AR{color}* = YYYY"
|
218
|
+
end
|
219
|
+
|
220
|
+
test "tc with ar er in brackets" do
|
221
|
+
assert testcase? "*TC Steps:*
|
222
|
+
# Step 1
|
223
|
+
# Step ..
|
224
|
+
# Step N
|
225
|
+
*[ER]* = XXXX
|
226
|
+
*[AR]* = YYYY"
|
227
|
+
end
|
228
|
+
|
229
|
+
test "tc with ar er in noformat" do
|
230
|
+
assert testcase? "*TC Steps:*
|
231
|
+
# Step 1
|
232
|
+
# Step ..
|
233
|
+
# Step N
|
234
|
+
{noformat}
|
235
|
+
*[ER]* = XXXX
|
236
|
+
*[AR]* = YYYY
|
237
|
+
{noformat}"
|
238
|
+
end
|
239
|
+
|
240
|
+
test "tc with colored ar er in brackets" do
|
241
|
+
assert testcase? "*TC Steps:*
|
242
|
+
# Step 1
|
243
|
+
# Step ..
|
244
|
+
# Step N
|
245
|
+
*{color:#00673A}[ER]{color}* = XXXX
|
246
|
+
*{color:#DE10AA}[AR]{color}* = YYYY"
|
247
|
+
end
|
248
|
+
|
200
249
|
# ensure that issue description has a test case, AR and ER
|
201
250
|
def testcase?(desc)
|
202
251
|
Testcase.new.passed(OpenStruct.new(description: desc))
|
@@ -0,0 +1,53 @@
|
|
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
|
+
|
27
|
+
require_relative "../../test"
|
28
|
+
require_relative "../../../lib/lazylead/smtp"
|
29
|
+
require_relative "../../../lib/lazylead/opts"
|
30
|
+
require_relative "../../../lib/lazylead/postman"
|
31
|
+
require_relative "../../../lib/lazylead/task/assignment"
|
32
|
+
|
33
|
+
module Lazylead
|
34
|
+
class AssignmentTest < Lazylead::Test
|
35
|
+
test "alert in case assignee changed by not authorized person" do
|
36
|
+
Lazylead::Smtp.new.enable
|
37
|
+
Task::Assignment.new.run(
|
38
|
+
NoAuthJira.new("https://jira.spring.io"),
|
39
|
+
Postman.new,
|
40
|
+
Opts.new(
|
41
|
+
"to" => "lead@company.com",
|
42
|
+
"from" => "ll@company.com",
|
43
|
+
"jql" => "key in ('DATAJDBC-480') and assignee is not empty",
|
44
|
+
"allowed" => "tom,mike,bob",
|
45
|
+
"subject" => "Assignment: How dare you?",
|
46
|
+
"template" => "lib/messages/illegal_assignee_change.erb"
|
47
|
+
)
|
48
|
+
)
|
49
|
+
assert_email "Assignment: How dare you?",
|
50
|
+
%w[DATAJDBC-480 01-Apr-2020 Minor Mark\ Paluch tom,mike,bob EntityInstantiators]
|
51
|
+
end
|
52
|
+
end
|
53
|
+
end
|
@@ -42,6 +42,7 @@ module Lazylead
|
|
42
42
|
"from" => "ll@company.com",
|
43
43
|
"jql" => "key in ('DATAJDBC-480') and fixVersion is not empty",
|
44
44
|
"allowed" => "tom,mike,bob",
|
45
|
+
"fields" => "description,reporter,priority,summary,created,fixVersions",
|
45
46
|
"subject" => "FixVersion: How dare you?",
|
46
47
|
"template" => "lib/messages/illegal_fixversion_change.erb"
|
47
48
|
)
|
@@ -28,6 +28,7 @@ require_relative "../../../lib/lazylead/task/propagate_down"
|
|
28
28
|
|
29
29
|
module Lazylead
|
30
30
|
class PropagateDownTest < Lazylead::Test
|
31
|
+
# rubocop:disable Naming/VariableNumber
|
31
32
|
test "propagate fields from parent ticket to sub-tasks" do
|
32
33
|
parent = OpenStruct.new(
|
33
34
|
id: 1,
|
@@ -38,7 +39,7 @@ module Lazylead
|
|
38
39
|
customfield_102: "Yesterday"
|
39
40
|
}.stringify_keys
|
40
41
|
)
|
41
|
-
|
42
|
+
child = Struct.new(:id, :key, :fields, :comment) do
|
42
43
|
def save(diff)
|
43
44
|
fields.merge! diff[:fields]
|
44
45
|
end
|
@@ -54,8 +55,7 @@ module Lazylead
|
|
54
55
|
def save!(body)
|
55
56
|
self[:comment] = body[:body]
|
56
57
|
end
|
57
|
-
end
|
58
|
-
child = Child.new(
|
58
|
+
end.new(
|
59
59
|
2, "PRJ-2",
|
60
60
|
{
|
61
61
|
subtasks: [],
|
@@ -84,5 +84,6 @@ module Lazylead
|
|
84
84
|
|customfield_102|Yesterday|],
|
85
85
|
child.comment
|
86
86
|
end
|
87
|
+
# rubocop:enable Naming/VariableNumber
|
87
88
|
end
|
88
89
|
end
|
@@ -24,6 +24,7 @@
|
|
24
24
|
|
25
25
|
require_relative "../../test"
|
26
26
|
require_relative "../../../lib/lazylead/smtp"
|
27
|
+
require_relative "../../../lib/lazylead/opts"
|
27
28
|
require_relative "../../../lib/lazylead/postman"
|
28
29
|
require_relative "../../../lib/lazylead/task/savepoint"
|
29
30
|
|
@@ -36,10 +37,12 @@ module Lazylead
|
|
36
37
|
Task::Savepoint.new.run(
|
37
38
|
[],
|
38
39
|
Postman.new,
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
40
|
+
Opts.new(
|
41
|
+
"from" => "fake@email.com",
|
42
|
+
"subject" => "[LL] Configuration backup",
|
43
|
+
"template" => "lib/messages/savepoint.erb",
|
44
|
+
"to" => "big.boss@example.com"
|
45
|
+
)
|
43
46
|
)
|
44
47
|
assert_equal 'text/markdown; filename="readme.md"',
|
45
48
|
Mail::TestMailer.deliveries
|
@@ -0,0 +1,97 @@
|
|
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/svn/diff"
|
31
|
+
|
32
|
+
module Lazylead
|
33
|
+
class DiffTest < Lazylead::Test
|
34
|
+
test "changes since revision" do
|
35
|
+
skip "No svn credentials provided" unless env? "svn_log_user",
|
36
|
+
"svn_log_password"
|
37
|
+
skip "No internet connection to riouxsvn.com" unless ping? "riouxsvn.com"
|
38
|
+
Lazylead::Smtp.new.enable
|
39
|
+
Task::Svn::Diff.new.run(
|
40
|
+
[],
|
41
|
+
Postman.new,
|
42
|
+
Opts.new(
|
43
|
+
"from" => "svnlog@test.com",
|
44
|
+
"svn_url" => "https://svn.riouxsvn.com/touch4ll",
|
45
|
+
"svn_user" => ENV["svn_log_user"],
|
46
|
+
"svn_password" => ENV["svn_log_password"],
|
47
|
+
"commit_url" => "https://view.commit.com?rev=",
|
48
|
+
"user" => "https://user.com?id=",
|
49
|
+
"to" => "lead@fake.com",
|
50
|
+
"since_rev" => "1",
|
51
|
+
"subject" => "[SVN] Changed since rev1",
|
52
|
+
"template" => "lib/messages/svn_diff.erb",
|
53
|
+
"template-attachment" => "lib/messages/svn_diff_attachment.erb"
|
54
|
+
)
|
55
|
+
)
|
56
|
+
assert_email_line "[SVN] Changed since rev1",
|
57
|
+
%w[r2 by dgroup at 2020-08-16]
|
58
|
+
end
|
59
|
+
|
60
|
+
test "changes since revision with attachment" do
|
61
|
+
skip "No svn credentials provided" unless env? "svn_log_user",
|
62
|
+
"svn_log_password"
|
63
|
+
skip "No internet connection to riouxsvn.com" unless ping? "riouxsvn.com"
|
64
|
+
skip "No postman credentials provided" unless env? "LL_SMTP_HOST",
|
65
|
+
"LL_SMTP_PORT",
|
66
|
+
"LL_SMTP_USER",
|
67
|
+
"LL_SMTP_PASS",
|
68
|
+
"LL_SMTP_TO",
|
69
|
+
"LL_SMTP_FROM"
|
70
|
+
Lazylead::Smtp.new(
|
71
|
+
Log.new,
|
72
|
+
NoSalt.new,
|
73
|
+
smtp_host: ENV["LL_SMTP_HOST"],
|
74
|
+
smtp_port: ENV["LL_SMTP_PORT"],
|
75
|
+
smtp_user: ENV["LL_SMTP_USER"],
|
76
|
+
smtp_pass: ENV["LL_SMTP_PASS"]
|
77
|
+
).enable
|
78
|
+
Task::Svn::Diff.new.run(
|
79
|
+
[],
|
80
|
+
Postman.new,
|
81
|
+
Opts.new(
|
82
|
+
"from" => ENV["LL_SMTP_FROM"],
|
83
|
+
"svn_url" => "https://svn.riouxsvn.com/touch4ll",
|
84
|
+
"svn_user" => ENV["svn_log_user"],
|
85
|
+
"svn_password" => ENV["svn_log_password"],
|
86
|
+
"commit_url" => "https://view.commit.com?rev=",
|
87
|
+
"user" => "https://user.com?id=",
|
88
|
+
"to" => ENV["LL_SMTP_TO"],
|
89
|
+
"since_rev" => "1",
|
90
|
+
"subject" => "[SVN] Changed since rev1",
|
91
|
+
"template" => "lib/messages/svn_diff.erb",
|
92
|
+
"template-attachment" => "lib/messages/svn_diff_attachment.erb"
|
93
|
+
)
|
94
|
+
)
|
95
|
+
end
|
96
|
+
end
|
97
|
+
end
|