如何在页面对象中使用范围报告日志?

问题描述 投票:0回答:1

当在页面对象中使用test.log()方法时,我得到了空指针异常。

我的区段报告测试是在TestBase类的“ @BeforeMethod”中定义的。因此,我需要访问test.log();。进入页面对象LoginPage.java。在测试用例级别,即LoginPageTest.java

上可以正常工作
    @BeforeMethod
    public void beforeMethod(Method method) {
    String testMethodName = method.getName();
    test = extent.createTest(testMethodName);
    String testReslt = method.getName();
    test.info(MarkupHelper.createLabel(testReslt, ExtentColor.BLUE));
    log.info("**************" + method.getName() + "Started***************");
}

public static void logExtentReport(String str) {
    test.log(Status.INFO, str);
}

下面是LoginPage.java(这是一个页面对象类)

public class LoginPage {

    private WebDriver driver;
    private final Logger log = LoggerHelper.getLogger(LoginPage.class);
    VerificationHelper verificationHelper;

    WaitHelper waitHelper;

    @FindBy(css = "#email")
    WebElement loginEmail;

    @FindBy(css = "#password")
    WebElement loginPassword;

    @FindBy(css = "#loginbutton")
    WebElement loginBtn;

    @FindBy(css = "#loginerrormsg")
    WebElement authenticationFailureMessage;

    @FindBy(css = "#soflow-color")
    WebElement userProfileDrpDwn;

    @FindBy(xpath = "//option[@value='string:logout']")
    WebElement logout;

    @FindBy(tagName = "a")
    List<WebElement> allLinks;

    String urls[] = null;

    public LoginPage(WebDriver driver) {
        this.driver = driver;
        PageFactory.initElements(driver, this);
        waitHelper = new WaitHelper(driver);
        waitHelper.waitForElement(loginBtn, 
    ObjectReader.reader.getExplicitWait());
    }

    public void enterEmailAddress(String emailAddress) {
        log.info("entering email address...." + emailAddress);
        this.loginEmail.clear();
        this.loginEmail.sendKeys(emailAddress);
    }

    public void enterPassword(String password) {
        log.info("entering password...." + password);
        this.loginPassword.clear();
        this.loginPassword.sendKeys(password);
    }

    public ProspectorPage clickOnSubmitButton(String isValidCredentials) {
        log.info("clicking on submit button...");
        loginBtn.click();
        if (isValidCredentials.equalsIgnoreCase("yes")) {
            return new ProspectorPage(driver);
        }
        return null;
    }

    public boolean verifySuccessLoginMsg() {
        return new VerificationHelper(driver).isDisplayed(userProfileDrpDwn);
    }

    public boolean verifyAuthenticationFailureMsg() {
        return new 
    VerificationHelper(driver).isDisplayed(authenticationFailureMessage);
    }

    public void loginToApplication(String emailAddress, String password, 
        String isValidCredentials) {
        enterEmailAddress(emailAddress);
        loginBtn.click();
        enterPassword(password);
        new TestBase().captureScreen("Login Page_1", driver);
        clickOnSubmitButton(isValidCredentials);
    }

    public void logout() {
        userProfileDrpDwn.click();
        new TestBase().captureScreen("Logout", driver);
        waitHelper.waitForElement(logout, 
        ObjectReader.reader.getExplicitWait());
        logout.click();
        log.info("clicked on logout link");
        TestBase.logExtentReport("clicked on logout link");
        waitHelper.waitForElement(loginBtn, 
        ObjectReader.reader.getExplicitWait());
    }
}
}

您可以在LoginPage类中看到,我已经使用了TestBase.logExtentReport()方法,该方法显示了NullPointerException,并且我无法在PageObject类中初始化TestBase引用。因此,如何在此处使用logExtentReport方法?

Helper类也获得了NPE,即使将记录器的范围从最终更改为静态也是如此。下面是代码:

import com.uiFramework.engie.prospector.helper.logger.LoggerHelper;
import com.uiFramework.engie.prospector.testbase.TestBase;

public class VerificationHelper {

private WebDriver driver;
private static Logger log = 
LoggerHelper.getLogger(VerificationHelper.class);

public VerificationHelper(WebDriver driver){
    this.driver = driver;
}

public boolean isDisplayed(WebElement element){
    try{
        element.isDisplayed();
        log.info("element is Displayed.."+element.getText());
        TestBase.logExtentReport("element is 
     Displayed.."+element.getText());
        return true;
    }
    catch(Exception e){
        log.error("element is not Displayed..", e.getCause());
        TestBase.logExtentReport("element is not 
    Displayed.."+e.getMessage());
        return false;
    }
}

public boolean isNotDisplayed(WebElement element){
    try{
        element.isDisplayed();
        log.info("element is present.."+element.getText());
        TestBase.logExtentReport("element is 
    present.."+element.getText());
        return false;
    }
    catch(Exception e){
        log.error("element is not present..");
        return true;
    }
}

public String readValueFromElement(WebElement element){
    if(null == element){
        log.info("WebElement is null..");
        return null;
    }
    boolean status = isDisplayed(element);
    if(status){
        log.info("element text is .."+element.getText());
        return element.getText();
    }
    else{
        return null;
    }
}
public String getText(WebElement element){
    if(null == element){
        log.info("WebElement is null..");
        return null;
    }
    boolean status = isDisplayed(element);
    if(status){
        log.info("element text is .."+element.getText());
        return element.getText();
    }
    else{
        return null;
    }
}

}

selenium automation pageobjects extentreports selenium-extent-report
1个回答
1
投票

只需更改

private final Logger log = LoggerHelper.getLogger(LoginPage.class);

to

private static final Logger log = LoggerHelper.getLogger(LoginPage.class);
© www.soinside.com 2019 - 2024. All rights reserved.