1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26 package it.tidalwave.util.test;
27
28 import jakarta.annotation.Nonnull;
29 import jakarta.annotation.Nullable;
30 import java.util.Arrays;
31 import org.slf4j.LoggerFactory;
32 import org.testng.ITestContext;
33 import org.testng.ITestResult;
34 import org.testng.TestListenerAdapter;
35
36
37
38
39
40
41 public class TestLogger extends TestListenerAdapter
42 {
43 private static final String S = "***********************************************";
44 private static final String SEPARATOR = S + S + S + S;
45
46 @Override
47 public void onStart (@Nonnull final ITestContext testContext)
48 {
49 super.onStart(testContext);
50 final var testClass = testContext.getCurrentXmlTest().getClasses().get(0).getName();
51 final var log = LoggerFactory.getLogger(testClass);
52 log.info("STARTING TESTS OF {}", testClass);
53 }
54
55 @Override
56 public void onFinish (@Nonnull final ITestContext testContext)
57 {
58 super.onFinish(testContext);
59 final var testClass = testContext.getCurrentXmlTest().getClasses().get(0).getName();
60 final var log = LoggerFactory.getLogger(testClass);
61 log.info("FINISHED TESTS OF {}", testClass);
62 }
63
64
65
66
67
68
69
70
71
72 @Override
73 public void onConfigurationSkip (@Nonnull final ITestResult result)
74 {
75 super.onConfigurationSkip(result);
76 final var log = LoggerFactory.getLogger(result.getTestClass().getRealClass());
77 final var throwable = result.getThrowable();
78 log.warn("CONFIGURATION SKIPPED {}", getMessage(throwable));
79
80 if (throwable != null)
81 {
82 log.warn("CONFIGURATION SKIPPED", result.getThrowable());
83 }
84 }
85
86 @Override
87 public void onConfigurationFailure (@Nonnull final ITestResult result)
88 {
89 super.onConfigurationFailure(result);
90 final var log = LoggerFactory.getLogger(result.getTestClass().getRealClass());
91 final var throwable = result.getThrowable();
92 log.error("CONFIGURATION FAILED {}", getMessage(throwable));
93
94 if (throwable != null)
95 {
96 log.error("CONFIGURATION FAILED", result.getThrowable());
97 }
98 }
99
100 @Override
101 public void onTestStart (@Nonnull final ITestResult result)
102 {
103 super.onTestStart(result);
104 final var args = getArgs(result);
105 final var max = Math.max(args.length() + 5, result.getName().length() + 7);
106 final var separator = SEPARATOR.substring(0, Math.min(max, SEPARATOR.length()));
107 final var log = LoggerFactory.getLogger(result.getTestClass().getRealClass());
108
109 log.info(separator);
110 log.info("TEST \"{}\"", result.getName().replace('_', ' '));
111
112 if (!args.isEmpty())
113 {
114 log.info("ARGS {}", args);
115 }
116
117 log.info(separator);
118 }
119
120 @Override
121 public void onTestFailure (@Nonnull final ITestResult result)
122 {
123 super.onTestFailure(result);
124 final var log = LoggerFactory.getLogger(result.getTestClass().getRealClass());
125 final var throwable = result.getThrowable();
126 final var args = getArgs(result);
127
128 log.error("TEST FAILED in {} msec - {}{} - {}",
129 result.getEndMillis() - result.getStartMillis(),
130 result.getName().replace('_', ' '),
131 args.isEmpty() ? "" : " " + args,
132 getMessage(throwable));
133
134 if (throwable != null)
135 {
136 log.error("TEST FAILED", result.getThrowable());
137 }
138
139 log.error("");
140 }
141
142 @Override
143 public void onTestFailedButWithinSuccessPercentage (@Nonnull final ITestResult result)
144 {
145 super.onTestFailedButWithinSuccessPercentage(result);
146 final var log = LoggerFactory.getLogger(result.getTestClass().getRealClass());
147 log.info("TEST FAILED WITHIN SUCCESS PERCENTAGE in {} msec", result.getEndMillis() - result.getStartMillis());
148 log.info("");
149 }
150
151 @Override
152 public void onTestSkipped (@Nonnull final ITestResult result)
153 {
154 super.onTestSkipped(result);
155 final var log = LoggerFactory.getLogger(result.getTestClass().getRealClass());
156 final var throwable = result.getThrowable();
157 log.info("TEST SKIPPED {}", getMessage(throwable));
158
159 if (throwable != null)
160 {
161 log.info("TEST SKIPPED", result.getThrowable());
162 }
163
164 log.info("");
165 }
166
167 @Override
168 public void onTestSuccess (@Nonnull final ITestResult result)
169 {
170 super.onTestSuccess(result);
171 final var log = LoggerFactory.getLogger(result.getTestClass().getRealClass());
172 log.info("TEST PASSED in {} msec", result.getEndMillis() - result.getStartMillis());
173 log.info("");
174 }
175
176 @Nonnull
177 private String getArgs (@Nonnull final ITestResult result)
178 {
179 var args = "";
180
181 final var parameters = result.getParameters();
182
183 if ((parameters != null) && parameters.length > 0)
184 {
185 args = Arrays.toString(parameters);
186 }
187
188 return args;
189 }
190
191 @Nonnull
192 private static String getMessage (@Nullable final Throwable throwable)
193 {
194 return (throwable == null) ? "" : throwable.toString();
195
196 }
197 }