java - 如何将 log4j 与 TestNG 集成?

标签 java selenium log4j testng

我正在尝试使用 log4j.properites 运行我的 selenium-testng 程序。我想知道如何将我的 testng 类与 log4j.properties 集成。

  1. 我已经使用 testNG 创建了一个示例 google 登录测试
  2. 我已经在 src/main/resources 下创建了 log4j.properties
  3. 我已经为代码编写了记录器 记录器日志 = Logger.getLogger(loginTest.class.getName());
  4. 我尝试运行测试,但我看不到生成任何日志。 现在我不确定接下来的步骤 - 有人可以指导我吗。

    公共(public)类登录测试{

    WebDriver driver;
    Logger log = Logger.getLogger(loginTest.class.getName());
    
    
    @BeforeMethod
    public void setUp() {
        System.setProperty("webdriver.chrome.driver" , "C:/Users/User/Desktop/Selenium Drivers/chromedriver.exe");
        driver = new ChromeDriver();
        driver.get("https://www.google.com/");
        driver.manage().window().maximize();
        driver.manage().timeouts().pageLoadTimeout(10, TimeUnit.SECONDS);
        driver.manage().timeouts().implicitlyWait(15, TimeUnit.SECONDS);
    }
    
    
    @Test
    public void titleTest() {
        String title = driver.getTitle();
        System.out.println(title);
        Assert.assertEquals(title, "Google");
    }
    
    @Test
    public void gmailLogoTest() {
        boolean b = driver.findElement(By.linkText("Gmail")).isDisplayed();
        Assert.assertTrue(true);
    }
    
    @AfterMethod
    public void tearDown() {
        driver.quit();
    
    
    }
    

    设置级别

    log4j.rootCategory=调试,控制台,文件

    写入控制台的 Appender

    log4j.appender.console=org.apache.log4j.ConsoleAppender
    log4j.appender.console.layout=org.apache.log4j.PatternLayout log4j.appender.console.layout.ConversionPattern=%d{MM-dd-yyyy HH:mm:ss} %F %-5p [%t] %c{2} %L - %m%n

    写入文件的Appender

    log4j.appender.file=org.apache.log4j.RollingFileAppender log4j.appender.file.File=application.log

    定义日志文件的最大大小

    log4j.appender.file.MaxFileSize=10mb log4j.appender.file.MaxBackupIndex=10 log4j.appender.file.layout=org.apache.log4j.PatternLayout
    log4j.appender.file.layout.ConversionPattern=%d{ISO8601} %5p [%t] %c{1}:%L - %m%n log4j.appender.file.Append=true

最佳答案

我相信你的构建路径中有 log4j.jar

您的 src 文件夹中应该有 log4j.properties 文件。请检查配置。

# Root logger option
log4j.rootLogger=DEBUG, file, stdout

# Direct log messages to a log file
log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=D:\\Testlog.log
log4j.appender.file.MaxFileSize=10MB
log4j.appender.file.MaxBackupIndex=10
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

# Direct log messages to stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

这是你的测试:

package testpkg;

import java.io.File;
import java.util.concurrent.TimeUnit;
import org.apache.log4j.Logger;
import org.junit.Assert;
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;
import org.testng.annotations.Test;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.AfterMethod;

public class loginTest {
WebDriver driver;
Logger log = Logger.getLogger(loginTest.class.getName());

  @BeforeMethod
  public void setUp() {
        //System.setProperty("webdriver.chrome.driver" , "C:/Users/User/Desktop/Selenium Drivers/chromedriver.exe");
      System.setProperty("webdriver.chrome.driver", System.getProperty("user.dir") + File.separator + "\\Executables\\Chromedriver.exe");
        driver = new ChromeDriver();
        driver.get("https://www.google.com/");
        driver.manage().window().maximize();
        driver.manage().timeouts().pageLoadTimeout(10, TimeUnit.SECONDS);
        driver.manage().timeouts().implicitlyWait(15, TimeUnit.SECONDS);
        log.debug("opening webiste");
    }

  @Test
  public void titleTest() {
        String title = driver.getTitle();
        System.out.println(title);
        Assert.assertEquals(title, "Google");
        log.debug("Title match");
    }

  @Test
  public void gmailLogoTest() {
        boolean b = driver.findElement(By.linkText("Gmail")).isDisplayed();
        Assert.assertTrue(true);
        log.debug("Linked found");

    }

  @AfterMethod
  public void tearDown() {
        driver.quit();


    }

}

输出:

您可以在控制台以及 log4j.properties 文件中提到的 D:\\TeSTLog.log 中查看详细信息。

希望这对您有所帮助。

关于java - 如何将 log4j 与 TestNG 集成?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55329209/

相关文章:

java - 在 JPA 查询中从 GROUP BY 创建 Map 对象

java - Selenium webdriver 轮询时间

tomcat - 忽略 Grails 日志记录配置

java - 如何设置无限最大文件大小的log4j?

java - equals 方法覆盖父类(super class)中的 equals 并且可能不对称

播放某些 mp3 文件时 JavaFX 抛出 ERROR_MEDIA_INVALID

python - 使用 Selenium Webdriver 和 FireFox 时出错

java - Log4j 2 不再支持 log4j.properties 文件了吗?

java - android opengles 2.0 绘制字符串 2d

java - 在java中读取csv时如何跳过第一行