Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Allure enhancements #1485

Merged
merged 3 commits into from
Feb 9, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
313 changes: 21 additions & 292 deletions .github/workflows/e2eTests.yml

Large diffs are not rendered by default.

12 changes: 12 additions & 0 deletions src/main/java/com/shaft/cli/FileActions.java
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,18 @@
passAction("Source File: \"" + sourceFilePath + "\" | Destination File: \"" + destinationFilePath + "\"");
}

public void renameFile(String filePath, String newFileName) {
try {
var targetFile = new File(filePath);
String targetDirectory = targetFile.getParentFile().getAbsolutePath();
FileUtils.copyFile(targetFile, new File(targetDirectory + File.separator + newFileName));
FileUtils.deleteQuietly(targetFile);
passAction("Target File Path: \"" + filePath + "\", file was renamed to \"" + newFileName + "\".");
} catch (IOException e) {
failAction(e);

Check warning on line 65 in src/main/java/com/shaft/cli/FileActions.java

View check run for this annotation

Codecov / codecov/patch

src/main/java/com/shaft/cli/FileActions.java#L64-L65

Added lines #L64 - L65 were not covered by tests
}
}

/**
* Copies files from sourceDirectory to destinationDirectory using the provided
* terminalSession. References: <a href="https://www.computerhope.com/unix/ucp.htm">computer hope/unix/ucp.htm</a>
Expand Down
1 change: 1 addition & 0 deletions src/main/java/com/shaft/cli/TerminalActions.java
Original file line number Diff line number Diff line change
Expand Up @@ -319,6 +319,7 @@ private List<String> executeLocalCommand(List<String> commands, String longComma
ReportManager.logDiscrete("Executing: \"" + command + "\" locally.");
try {
ProcessBuilder pb = getProcessBuilder(command, finalDirectory, isWindows);
pb.environment().put("JAVA_HOME", System.getProperty("java.home"));
if (!asynchronous) {
pb.redirectErrorStream(true);
Process localProcess = pb.start();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
import io.appium.java_client.android.AndroidDriver;
import io.appium.java_client.ios.IOSDriver;
import io.github.bonigarcia.wdm.WebDriverManager;
import io.github.bonigarcia.wdm.config.WebDriverManagerException;
import io.qameta.allure.Step;
import lombok.*;
import org.apache.logging.log4j.Level;
Expand Down Expand Up @@ -123,7 +124,7 @@
return DriverType.CHROME;
}

@SneakyThrows(java.lang.InterruptedException.class)
@SneakyThrows(InterruptedException.class)

Check warning on line 127 in src/main/java/com/shaft/driver/internal/DriverFactory/DriverFactoryHelper.java

View check run for this annotation

Codecov / codecov/patch

src/main/java/com/shaft/driver/internal/DriverFactory/DriverFactoryHelper.java#L127

Added line #L127 was not covered by tests
private static int attemptRemoteServerPing() {
boolean serverReady = false;
var session = new SHAFT.API(TARGET_HUB_URL);
Expand Down Expand Up @@ -158,7 +159,7 @@
return statusCode;
}

@SneakyThrows({java.net.MalformedURLException.class, InterruptedException.class})
@SneakyThrows({MalformedURLException.class, InterruptedException.class})

Check warning on line 162 in src/main/java/com/shaft/driver/internal/DriverFactory/DriverFactoryHelper.java

View check run for this annotation

Codecov / codecov/patch

src/main/java/com/shaft/driver/internal/DriverFactory/DriverFactoryHelper.java#L162

Added line #L162 was not covered by tests
private static WebDriver attemptRemoteServerConnection(Capabilities capabilities) {
WebDriver driver = null;
boolean isRemoteConnectionEstablished = false;
Expand All @@ -168,12 +169,12 @@
try {
driver = connectToRemoteServer(capabilities, false);
isRemoteConnectionEstablished = true;
} catch (org.openqa.selenium.SessionNotCreatedException | URISyntaxException sessionNotCreatedException1) {
} catch (SessionNotCreatedException | URISyntaxException sessionNotCreatedException1) {
exception = sessionNotCreatedException1.getMessage();
try {
driver = connectToRemoteServer(capabilities, true);
isRemoteConnectionEstablished = true;
} catch (org.openqa.selenium.SessionNotCreatedException |
} catch (SessionNotCreatedException |
URISyntaxException sessionNotCreatedException2) {
// do nothing
ReportManagerHelper.logDiscrete(sessionNotCreatedException1, Level.DEBUG);
Expand Down Expand Up @@ -281,10 +282,12 @@
}

private void createNewLocalDriverInstance(DriverType driverType, int retryAttempts) {
String initialLog = "Attempting to run locally on: \"" + Properties.platform.targetPlatform() + " | " + JavaHelper.convertToSentenceCase(driverType.getValue()) + "\"";
String targetPlatform = Properties.platform.targetPlatform().toLowerCase();
String initialLog = "Attempting to run locally on: \"" + targetPlatform + " | " + JavaHelper.convertToSentenceCase(driverType.getValue()) + "\"";
if (SHAFT.Properties.web.headlessExecution()) {
initialLog = initialLog + ", Headless Execution";
}
initialLog = initialLog.replace(targetPlatform, JavaHelper.convertToSentenceCase(targetPlatform) + getPlatformIcon(targetPlatform));
ReportManager.logDiscrete(initialLog + ".");
try {
ReportManager.logDiscrete(WEB_DRIVER_MANAGER_MESSAGE);
Expand Down Expand Up @@ -345,6 +348,18 @@
}
}

//TODO: Implement
private String getPlatformIcon(String targetPlatform) {
return "";
// return switch (targetPlatform){
// case "linux" -> "<img src=\"\">";
// case "mac", "ios" -> "<img src=\"\">";
// case "android" -> "<img src=\"\">";
// case "windows" -> "<img src=\"\">";
// default -> "";
// };
}

private void createNewDockerizedDriverInstance(DriverType driverType) {
String initialLog = "Attempting to run dockerized on: \"" + Properties.platform.targetPlatform() + " | " + JavaHelper.convertToSentenceCase(driverType.getValue()) + "\"";
if (SHAFT.Properties.web.headlessExecution()) {
Expand Down Expand Up @@ -373,7 +388,7 @@
// driver =ThreadGuard.protect(remoteWebDriver));
driver = remoteWebDriver;
ReportManager.log("Successfully Opened " + JavaHelper.convertToSentenceCase(driverType.getValue()) + ".");
} catch (io.github.bonigarcia.wdm.config.WebDriverManagerException exception) {
} catch (WebDriverManagerException exception) {

Check warning on line 391 in src/main/java/com/shaft/driver/internal/DriverFactory/DriverFactoryHelper.java

View check run for this annotation

Codecov / codecov/patch

src/main/java/com/shaft/driver/internal/DriverFactory/DriverFactoryHelper.java#L391

Added line #L391 was not covered by tests
failAction("Failed to create new Dockerized Browser Session, are you sure Docker is available on your machine?", exception);
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@
import java.util.stream.Stream;

import static com.shaft.listeners.internal.CucumberHelper.shaftSetup;
import static com.shaft.listeners.internal.CucumberHelper.shaftTeardown;
import static com.shaft.listeners.internal.CucumberHelper.shaftTearDown;
import static io.qameta.allure.util.ResultsUtils.*;

/**
Expand Down Expand Up @@ -143,7 +143,7 @@
@SuppressWarnings("unused")
private void handleFeatureFinishedHandler(final TestRunFinished event) {
// custom code
shaftTeardown();
shaftTearDown();

Check warning on line 146 in src/main/java/com/shaft/listeners/CucumberFeatureListener.java

View check run for this annotation

Codecov / codecov/patch

src/main/java/com/shaft/listeners/CucumberFeatureListener.java#L146

Added line #L146 was not covered by tests
// end of custom code
}

Expand Down
14 changes: 6 additions & 8 deletions src/main/java/com/shaft/listeners/JunitListener.java
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
import com.shaft.listeners.internal.UpdateChecker;
import com.shaft.properties.internal.PropertiesHelper;
import com.shaft.tools.internal.security.GoogleTink;
import com.shaft.tools.io.internal.AllureManager;
import com.shaft.tools.io.internal.ExecutionSummaryReport;
import com.shaft.tools.io.internal.ProjectStructureManager;
import com.shaft.tools.io.internal.ReportManagerHelper;
Expand Down Expand Up @@ -39,7 +40,7 @@

@Override
public void testPlanExecutionFinished(TestPlan testPlan) {
engineTeardown();
engineTearDown();

Check warning on line 43 in src/main/java/com/shaft/listeners/JunitListener.java

View check run for this annotation

Codecov / codecov/patch

src/main/java/com/shaft/listeners/JunitListener.java#L43

Added line #L43 was not covered by tests
}

@Override
Expand Down Expand Up @@ -87,28 +88,25 @@
UpdateChecker.check();
ImageProcessingActions.loadOpenCV();

ReportManagerHelper.initializeAllureReportingEnvironment();
AllureManager.initializeAllureReportingEnvironment();

Check warning on line 91 in src/main/java/com/shaft/listeners/JunitListener.java

View check run for this annotation

Codecov / codecov/patch

src/main/java/com/shaft/listeners/JunitListener.java#L91

Added line #L91 was not covered by tests
ReportManagerHelper.cleanExecutionSummaryReportDirectory();

ReportManagerHelper.setDiscreteLogging(SHAFT.Properties.reporting.alwaysLogDiscreetly());
ReportManagerHelper.setDebugMode(SHAFT.Properties.reporting.debugMode());
}

private void engineTeardown() {
private void engineTearDown() {
ReportManagerHelper.setDiscreteLogging(true);
JiraHelper.reportExecutionStatusToJira();
GoogleTink.encrypt();
ReportManagerHelper.generateAllureReportArchive();
ReportManagerHelper.openAllureReportAfterExecution();
AllureManager.generateAllureReportArchive();
AllureManager.openAllureReportAfterExecution();

Check warning on line 103 in src/main/java/com/shaft/listeners/JunitListener.java

View check run for this annotation

Codecov / codecov/patch

src/main/java/com/shaft/listeners/JunitListener.java#L102-L103

Added lines #L102 - L103 were not covered by tests
long executionEndTime = System.currentTimeMillis();
ExecutionSummaryReport.generateExecutionSummaryReport(passedTests.size(), failedTests.size(), skippedTests.size(), executionStartTime, executionEndTime);
ReportManagerHelper.logEngineClosure();
}

private void afterInvocation() {
// IssueReporter.updateTestStatusInCaseOfVerificationFailure(iTestResult);
// IssueReporter.updateIssuesLog(iTestResult);
// TestNGListenerHelper.updateConfigurationMethodLogs(iTestResult);
ReportManagerHelper.setDiscreteLogging(SHAFT.Properties.reporting.alwaysLogDiscreetly());
}

Expand Down
11 changes: 4 additions & 7 deletions src/main/java/com/shaft/listeners/TestNGListener.java
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,7 @@
import com.shaft.properties.internal.PropertiesHelper;
import com.shaft.tools.internal.security.GoogleTink;
import com.shaft.tools.io.ReportManager;
import com.shaft.tools.io.internal.ExecutionSummaryReport;
import com.shaft.tools.io.internal.IssueReporter;
import com.shaft.tools.io.internal.ProjectStructureManager;
import com.shaft.tools.io.internal.ReportManagerHelper;
import com.shaft.tools.io.internal.*;
import io.qameta.allure.Allure;
import lombok.Getter;
import org.testng.*;
Expand Down Expand Up @@ -79,7 +76,7 @@ public static void engineSetup(ProjectStructureManager.RunType runType) {
ReportManagerHelper.logEngineVersion();
Thread.ofVirtual().start(UpdateChecker::check);
Thread.ofVirtual().start(ImageProcessingActions::loadOpenCV);
Thread.ofVirtual().start(ReportManagerHelper::initializeAllureReportingEnvironment);
Thread.ofVirtual().start(AllureManager::initializeAllureReportingEnvironment);
Thread.ofVirtual().start(ReportManagerHelper::cleanExecutionSummaryReportDirectory);
ReportManagerHelper.setDiscreteLogging(SHAFT.Properties.reporting.alwaysLogDiscreetly());
ReportManagerHelper.setDebugMode(SHAFT.Properties.reporting.debugMode());
Expand Down Expand Up @@ -201,12 +198,12 @@ public void afterInvocation(IInvokedMethod iInvokedMethod, ITestResult iTestResu
@Override
public void onExecutionFinish() {
ReportManagerHelper.setDiscreteLogging(true);
Thread allureArchiveGeneration = Thread.ofVirtual().start(ReportManagerHelper::generateAllureReportArchive);
Thread allureArchiveGeneration = Thread.ofVirtual().start(AllureManager::generateAllureReportArchive);
long executionEndTime = System.currentTimeMillis();
Thread summaryReportGeneration = Thread.ofVirtual().start(() -> ExecutionSummaryReport.generateExecutionSummaryReport(passedTests.size(), failedTests.size(), skippedTests.size(), executionStartTime, executionEndTime));
Thread.ofVirtual().start(JiraHelper::reportExecutionStatusToJira);
Thread.ofVirtual().start(GoogleTink::encrypt);
Thread.ofVirtual().start(ReportManagerHelper::openAllureReportAfterExecution);
Thread.ofVirtual().start(AllureManager::openAllureReportAfterExecution);
Thread.ofVirtual().start(ReportManagerHelper::logEngineClosure);
try {
summaryReportGeneration.join();
Expand Down
13 changes: 5 additions & 8 deletions src/main/java/com/shaft/listeners/internal/CucumberHelper.java
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,7 @@
import com.shaft.gui.internal.image.ImageProcessingActions;
import com.shaft.properties.internal.PropertiesHelper;
import com.shaft.tools.internal.security.GoogleTink;
import com.shaft.tools.io.internal.CheckpointCounter;
import com.shaft.tools.io.internal.ProjectStructureManager;
import com.shaft.tools.io.internal.ReportHelper;
import com.shaft.tools.io.internal.ReportManagerHelper;
import com.shaft.tools.io.internal.*;
import org.testng.Reporter;
import org.testng.xml.XmlSuite;

Expand Down Expand Up @@ -48,7 +45,7 @@
UpdateChecker.check();
ImageProcessingActions.loadOpenCV();

ReportManagerHelper.initializeAllureReportingEnvironment();
AllureManager.initializeAllureReportingEnvironment();

Check warning on line 48 in src/main/java/com/shaft/listeners/internal/CucumberHelper.java

View check run for this annotation

Codecov / codecov/patch

src/main/java/com/shaft/listeners/internal/CucumberHelper.java#L48

Added line #L48 was not covered by tests

ReportHelper.attachImportantLinks();
ReportHelper.attachPropertyFiles();
Expand All @@ -68,7 +65,7 @@
);
}

public static void shaftTeardown() {
public static void shaftTearDown() {
if (Reporter.getCurrentTestResult() == null) {
// running in native Cucumber mode
ReportHelper.attachEngineLog();
Expand All @@ -79,8 +76,8 @@
ReportManagerHelper.setDiscreteLogging(true);
JiraHelper.reportExecutionStatusToJira();
GoogleTink.encrypt();
ReportManagerHelper.generateAllureReportArchive();
ReportManagerHelper.openAllureReportAfterExecution();
AllureManager.generateAllureReportArchive();
AllureManager.openAllureReportAfterExecution();

Check warning on line 80 in src/main/java/com/shaft/listeners/internal/CucumberHelper.java

View check run for this annotation

Codecov / codecov/patch

src/main/java/com/shaft/listeners/internal/CucumberHelper.java#L79-L80

Added lines #L79 - L80 were not covered by tests
ReportManagerHelper.logEngineClosure();
}
}
Expand Down
Loading
Loading