Skip to content

Commit 16cd618

Browse files
Merge pull request #261 from eliasnogueira/allure-screenshot
Allure screenshot
2 parents bbc7f86 + 476781b commit 16cd618

File tree

6 files changed

+58
-96
lines changed

6 files changed

+58
-96
lines changed

pom.xml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@
66

77
<groupId>com.eliasnogueira</groupId>
88
<artifactId>selenium-java-lean-test-architecture</artifactId>
9-
<version>3.4.2</version>
9+
<version>3.4.3</version>
1010

1111
<scm>
1212
<connection>scm:[email protected]:eliasnogueira/selenium-java-lean-test-architecture.git</connection>

src/main/java/com/eliasnogueira/report/AllureManager.java

Lines changed: 0 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -24,18 +24,14 @@
2424

2525
package com.eliasnogueira.report;
2626

27-
import com.eliasnogueira.driver.DriverManager;
2827
import com.eliasnogueira.enums.Target;
2928
import com.github.automatedowl.tools.AllureEnvironmentWriter;
3029
import com.google.common.collect.ImmutableMap;
31-
import io.qameta.allure.Attachment;
32-
import org.openqa.selenium.TakesScreenshot;
3330

3431
import java.util.HashMap;
3532
import java.util.Map;
3633

3734
import static com.eliasnogueira.config.ConfigurationManager.configuration;
38-
import static org.openqa.selenium.OutputType.BYTES;
3935

4036
public class AllureManager {
4137

@@ -59,14 +55,4 @@ public static void setAllureEnvironmentInformation() {
5955

6056
AllureEnvironmentWriter.allureEnvironmentWriter(ImmutableMap.copyOf(basicInfo));
6157
}
62-
63-
@Attachment(value = "Failed test screenshot", type = "image/png")
64-
public static byte[] takeScreenshotToAttachOnAllureReport() {
65-
return ((TakesScreenshot) DriverManager.getDriver()).getScreenshotAs(BYTES);
66-
}
67-
68-
@Attachment(value = "Browser information", type = "text/plain")
69-
public static String addBrowserInformationOnAllureReport() {
70-
return DriverManager.getInfo();
71-
}
7258
}
Lines changed: 56 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,56 @@
1+
/*
2+
* MIT License
3+
*
4+
* Copyright (c) 2024 Elias Nogueira
5+
*
6+
* Permission is hereby granted, free of charge, to any person obtaining a copy
7+
* of this software and associated documentation files (the "Software"), to deal
8+
* in the Software without restriction, including without limitation the rights
9+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10+
* copies of the Software, and to permit persons to whom the Software is
11+
* furnished to do so, subject to the following conditions:
12+
*
13+
* The above copyright notice and this permission notice shall be included in all
14+
* copies or substantial portions of the Software.
15+
*
16+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22+
* SOFTWARE.
23+
*/
24+
package com.eliasnogueira.report;
25+
26+
import com.eliasnogueira.driver.DriverManager;
27+
import io.qameta.allure.Attachment;
28+
import io.qameta.allure.listener.TestLifecycleListener;
29+
import io.qameta.allure.model.TestResult;
30+
import org.openqa.selenium.OutputType;
31+
import org.openqa.selenium.TakesScreenshot;
32+
import org.openqa.selenium.WebDriver;
33+
34+
import static io.qameta.allure.model.Status.BROKEN;
35+
import static io.qameta.allure.model.Status.FAILED;
36+
37+
/*
38+
* Approach implemented using the https://github.com/biczomate/allure-testng7.5-attachment-example as reference
39+
*/
40+
public class AllureTestLifecycleListener implements TestLifecycleListener {
41+
42+
public AllureTestLifecycleListener() {
43+
}
44+
45+
@Attachment(value = "Page Screenshot", type = "image/png")
46+
public byte[] saveScreenshot(WebDriver driver) {
47+
return ((TakesScreenshot) driver).getScreenshotAs(OutputType.BYTES);
48+
}
49+
50+
@Override
51+
public void beforeTestStop(TestResult result) {
52+
if (FAILED == result.getStatus() || BROKEN == result.getStatus()) {
53+
saveScreenshot(DriverManager.getDriver());
54+
}
55+
}
56+
}

src/test/java/com/eliasnogueira/BaseWeb.java

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -31,13 +31,11 @@
3131
import org.testng.annotations.AfterMethod;
3232
import org.testng.annotations.BeforeMethod;
3333
import org.testng.annotations.BeforeSuite;
34-
import org.testng.annotations.Listeners;
3534
import org.testng.annotations.Optional;
3635
import org.testng.annotations.Parameters;
3736

3837
import static com.eliasnogueira.config.ConfigurationManager.configuration;
3938

40-
@Listeners({TestListener.class})
4139
public abstract class BaseWeb {
4240

4341
@BeforeSuite

src/test/java/com/eliasnogueira/TestListener.java

Lines changed: 0 additions & 79 deletions
This file was deleted.
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
com.eliasnogueira.report.AllureTestLifecycleListener

0 commit comments

Comments
 (0)