parent
70414d2279
commit
13d168c8a5
4 changed files with 122 additions and 97 deletions
|
@ -18,7 +18,7 @@ This repository is for E2E UI automation.
|
|||
|
||||
### Prerequisites
|
||||
- Docker & Docker-compose
|
||||
- Java
|
||||
- Java (install aarch64 jdk if you have M1/arm chip)
|
||||
- Maven
|
||||
|
||||
### How to install
|
||||
|
|
|
@ -126,6 +126,12 @@
|
|||
<artifactId>netty-transport-native-unix-common</artifactId>
|
||||
<version>${netty.version}</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>io.netty</groupId>
|
||||
<artifactId>netty-resolver-dns-native-macos</artifactId>
|
||||
<version>${netty.version}</version>
|
||||
<classifier>osx-aarch_64</classifier>
|
||||
</dependency>
|
||||
|
||||
<dependency>
|
||||
<groupId>org.testcontainers</groupId>
|
||||
|
|
|
@ -14,10 +14,8 @@ public class TestConfiguration {
|
|||
Boolean.parseBoolean(System.getProperty("SAVE_PAGE_SOURCE", "false"));
|
||||
public static Boolean REOPEN_BROWSER_ON_FAIL =
|
||||
Boolean.parseBoolean(System.getProperty("REOPEN_BROWSER_ON_FAIL", "true"));
|
||||
public static String BROWSER = System.getProperty("BROWSER", "chrome");
|
||||
public static String BROWSER = System.getProperty("BROWSER", "chromium");
|
||||
public static String BROWSER_SIZE = System.getProperty("BROWSER_SIZE", "1920x1080");
|
||||
public static Boolean ENABLE_VNC = Boolean.parseBoolean(System.getProperty("ENABLE_VNC", "true"));
|
||||
public static String IMAGE_NAME = System.getProperty("SELENIUM_DOCKER_IMAGE", "selenium/standalone-chrome");
|
||||
public static String IMAGE_TAG = System.getProperty("SELENIUM_IMAGE_TAG", "103.0");
|
||||
|
||||
}
|
||||
|
|
|
@ -12,10 +12,18 @@ import com.provectus.kafka.ui.utils.qaseIO.TestCaseGenerator;
|
|||
import io.github.cdimascio.dotenv.Dotenv;
|
||||
import io.qameta.allure.Allure;
|
||||
import io.qameta.allure.selenide.AllureSelenide;
|
||||
import java.io.ByteArrayInputStream;
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.util.Arrays;
|
||||
import lombok.SneakyThrows;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.apache.commons.io.FileUtils;
|
||||
import org.junit.jupiter.api.*;
|
||||
import org.junit.jupiter.api.AfterAll;
|
||||
import org.junit.jupiter.api.AfterEach;
|
||||
import org.junit.jupiter.api.BeforeAll;
|
||||
import org.junit.jupiter.api.BeforeEach;
|
||||
import org.junit.jupiter.api.DisplayNameGeneration;
|
||||
import org.openqa.selenium.Dimension;
|
||||
import org.openqa.selenium.OutputType;
|
||||
import org.openqa.selenium.TakesScreenshot;
|
||||
|
@ -26,22 +34,17 @@ import org.testcontainers.containers.BrowserWebDriverContainer;
|
|||
import org.testcontainers.containers.wait.strategy.Wait;
|
||||
import org.testcontainers.utility.DockerImageName;
|
||||
|
||||
import java.io.ByteArrayInputStream;
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.util.Arrays;
|
||||
|
||||
@Slf4j
|
||||
@DisplayNameGeneration(CamelCaseToSpacedDisplayNameGenerator.class)
|
||||
public class BaseTest {
|
||||
|
||||
public static final String SELENIUM_IMAGE_NAME = "selenium/standalone-chrome";
|
||||
public static final String SELENIARM_STANDALONE_CHROMIUM = "seleniarm/standalone-chromium";
|
||||
protected Pages pages = Pages.INSTANCE;
|
||||
protected Helpers helpers = Helpers.INSTANCE;
|
||||
|
||||
private Screenshooter screenshooter = new Screenshooter();
|
||||
|
||||
private static final String IMAGE_NAME = TestConfiguration.IMAGE_NAME;
|
||||
private static final String IMAGE_TAG = TestConfiguration.IMAGE_TAG;
|
||||
protected static BrowserWebDriverContainer<?> webDriverContainer = null;
|
||||
|
||||
public void compareScreenshots(String name) {
|
||||
|
@ -61,15 +64,27 @@ public class BaseTest {
|
|||
|
||||
@BeforeAll
|
||||
public static void start() {
|
||||
DockerImageName image = DockerImageName.parse(IMAGE_NAME).withTag(IMAGE_TAG);
|
||||
|
||||
DockerImageName image = isARM64()
|
||||
? DockerImageName.parse(SELENIARM_STANDALONE_CHROMIUM).asCompatibleSubstituteFor(SELENIUM_IMAGE_NAME)
|
||||
: DockerImageName.parse(SELENIUM_IMAGE_NAME);
|
||||
log.info("Using [{}] as image name for chrome", image.getUnversionedPart());
|
||||
|
||||
webDriverContainer = new BrowserWebDriverContainer<>(image)
|
||||
.withCapabilities(new ChromeOptions().addArguments("--disable-dev-shm-usage"))
|
||||
.withEnv("JAVA_OPTS", "-Dwebdriver.chrome.whitelistedIps=")
|
||||
.withCapabilities(new ChromeOptions()
|
||||
.addArguments("--disable-dev-shm-usage")
|
||||
.addArguments("--verbose")
|
||||
)
|
||||
.waitingFor(Wait.forHttp("/"))
|
||||
//.withLogConsumer(new Slf4jLogConsumer(log).withPrefix("[CHROME]: ")) // uncomment for debugging
|
||||
.waitingFor(Wait.forLogMessage(".*Started Selenium Standalone.*", 1));
|
||||
try {
|
||||
Testcontainers.exposeHostPorts(8080);
|
||||
webDriverContainer.start();
|
||||
webDriverContainer.isRunning();
|
||||
webDriverContainer.isHostAccessible();
|
||||
} catch (Throwable e) {
|
||||
log.error("Couldn't start a container", e);
|
||||
}
|
||||
}
|
||||
|
||||
@AfterAll
|
||||
|
@ -96,7 +111,8 @@ public class BaseTest {
|
|||
setup();
|
||||
Runtime.getRuntime().addShutdownHook(new Thread(() -> {
|
||||
if (TestCaseGenerator.FAILED) {
|
||||
log.error("Tests FAILED because some problem with @CaseId annotation. Verify that all tests annotated with @CaseId and Id is correct!");
|
||||
log.error(
|
||||
"Tests FAILED because some problem with @CaseId annotation. Verify that all tests annotated with @CaseId and Id is correct!");
|
||||
Runtime.getRuntime().halt(100500);
|
||||
}
|
||||
}));
|
||||
|
@ -105,7 +121,8 @@ public class BaseTest {
|
|||
@AfterEach
|
||||
public void afterMethod() {
|
||||
Allure.addAttachment("Screenshot",
|
||||
new ByteArrayInputStream(((TakesScreenshot) webDriverContainer.getWebDriver()).getScreenshotAs(OutputType.BYTES)));
|
||||
new ByteArrayInputStream(
|
||||
((TakesScreenshot) webDriverContainer.getWebDriver()).getScreenshotAs(OutputType.BYTES)));
|
||||
}
|
||||
|
||||
@SneakyThrows
|
||||
|
@ -134,4 +151,8 @@ public class BaseTest {
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
private static boolean isARM64() {
|
||||
return System.getProperty("os.arch").equals("aarch64");
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue