我无法获得当前日期

时间:2015-06-04 08:18:41

标签: java eclipse time webdriver

我正在为一些网站创建一个自动测试,我正在使用WebDriver,TestNG和用Java编写的代码。执行步骤时,控制台的每个输出都应显示时间。一周前一切都很好,每一步都有不同的时间设定。但是,现在时间仍然保持不变。

09:50:48: ***********start***********
09:50:48: ***********PART 1***********
09:50:48: 1.1 home: OK xxxx
09:50:48: ***********PART 2***********
09:50:48: 2.1 home: OK xxxx
09:50:48: 2.2 home: OK xxxx
09:50:48: 2.3 home: OK URL xxxx
09:50:48: 2.4 home: OK xxxx
09:50:48: ***********PART 3***********
....

我使用过这段代码:

Date dNow = new Date( );
SimpleDateFormat ft = new SimpleDateFormat ("yyyy-MM-dd hh:mm:ss");

System.out.println(ft.format(dNow) + ":" + " xxxx");

有人能告诉我,我怎样才能再次获得每一步的当前时间?

测试代码:

package exDrazby;

import java.text.SimpleDateFormat;
import java.util.concurrent.TimeUnit;
import static org.junit.Assert.*;
import org.openqa.selenium.*;
import org.openqa.selenium.firefox.FirefoxDriver;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test;
import java.util.*;
import java.util.NoSuchElementException;


public class Help {
    private WebDriver driver;
    private String baseUrl;
    private StringBuffer verificationErrors = new StringBuffer();
     Date dNow = new Date( );
     SimpleDateFormat ft = new SimpleDateFormat ("yyyy-MM-dd hh:mm:ss");

@BeforeMethod
public void setUp() throws Exception {
    driver = new FirefoxDriver();
    //driver.manage().window().maximize();
    baseUrl = "http://www.labmultis.info";
    driver.manage().timeouts().implicitlyWait(30, TimeUnit.SECONDS);

}
@Test
public void testHelpStep1WD() throws Exception {
    System.out.println(" **************************************");
    System.out.println(" * Test projektu: exdrazby.cz –admin verze 3.3s");
    System.out.println(" * Test: HELP verze 1.0");
    System.out.println(" **************************************");
    System.out.println(" ");
    System.out.println(ft.format(dNow) + ":" + " ***********ZAČÁTEK TESTU HELP***********");
    System.out.println(ft.format(dNow) + ":" + " ***********PART 1***********");
    driver.get(baseUrl + "/jpecka.portal-exdrazby/index.php?a=mujucet&aa=resetheslo");
    driver.findElement(By.linkText("Nápověda")).click();
    try {
        assertEquals("Úvod > Nápověda", driver.findElement(By.cssSelector("p.breadcrumb")).getText());
        System.out.println(ft.format(dNow) + ":" + " 1.1 help: OK stránka nápověda dostupná");
    } catch (Error e) {
        verificationErrors.append(e.toString());
        System.out.println(ft.format(dNow) + ":" + " 1.1 help: stránku nápověda se nepodařilo zobrazit!!!");
    }
    assertTrue(isElementPresent(By.cssSelector("div.box.box-inner")));
    System.out.println(ft.format(dNow) + ":" + " ***********PART 2***********");
    try {
        assertEquals("Obsah", driver.findElement(By.cssSelector("h3")).getText());
        System.out.println(ft.format(dNow) + ":" + " 2.1 help: OK box s nápovědou vlevo je zobrazen");
    } catch (Error e) {
        verificationErrors.append(e.toString());
        System.out.println(ft.format(dNow) + ":" + " 2.1 help: box s nápovědou vlevo je chybí!!!");
    }
    assertTrue(isElementPresent(By.linkText("Registrace na portálu")));
    assertTrue(isElementPresent(By.linkText("Jak splnit podmínky účasti v dražbě")));
    assertTrue(isElementPresent(By.linkText("Jak dražit")));
    assertTrue(isElementPresent(By.linkText("Jak hledat dražby")));
    try {
        assertTrue(isElementPresent(By.linkText("Pojmy")));
        System.out.println(ft.format(dNow) + ":" + " 2.2 help: OK box s nápovědou vlevo obsahuje funkční linky: registrace na portálu, jak splnit podmínky účasti v dražbě, jak dražit, jak hledat dražby a pojmy");
    } catch (Error e) {
        verificationErrors.append(e.toString());
        System.out.println(ft.format(dNow) + ":" + " 2.2 help: box s nápovědou vlevo obsahuje chybu, některý z následujích linků není funkční: registrace na portálu, jak splnit podmínky účasti v dražbě, jak dražit, jak hledat dražby a pojmy!!!");
    }
    System.out.println(ft.format(dNow) + ":" + " ***********PART 3***********");
    assertTrue(isElementPresent(By.linkText("Jak se registrovat")));
    assertTrue(isElementPresent(By.linkText("Co je základní registrace")));
    assertTrue(isElementPresent(By.linkText("Registrace dražitele")));
    assertTrue(isElementPresent(By.linkText("Co je registrace ostatních účastníků dražby")));
    driver.findElement(By.xpath("//a[contains(text(),'Co v případě, že se nemůžete  registrovat nebo přihlásit?')]")).click();

    try {
        assertTrue(driver.findElement(By.xpath("/html/body/div[1]/div/section/div/div[2]/ol/h2")).getText().matches("^Co v případě, že se nemůžete registrovat nebo přihlásit[\\s\\S]$"));
        System.out.println(ft.format(dNow) + ":" + " 3.1 help: OK Nápověda > 1. registrace na portálu obsahuje funkční následující linky: jak se registrovat, co je základní registrace, co je registrace dražitele, Co je registrace ostatních účastníků dražby, Co v případě, že se nemůžete registrovat nebo přihlásit.");
    } catch (Error e) {
        verificationErrors.append(e.toString());
        System.out.println(ft.format(dNow) + ":" + " 3.1 help: Nápověda > 1. registrace na portálu obsahuje chybu, některý z následujích linků není funkční: jak se registrovat, co je základní registrace, co je registrace dražitele, Co je registrace ostatních účastníků dražby, Co v případě, že se nemůžete registrovat nebo přihlásit.!!!");
    }
    driver.findElement(By.linkText("Pojmy")).click();
    try {
        assertEquals("Pojmy", driver.findElement(By.xpath("//li[5]/div")).getText());
    } catch (Error e) {
        verificationErrors.append(e.toString());
    }
    assertTrue(isElementPresent(By.linkText("Jak prokázat totožnost")));
    assertTrue(isElementPresent(By.linkText("Ověření totožnosti u exekutora")));
    assertTrue(isElementPresent(By.linkText("Doložení ověřené totožnosti doklady zaslanými poštou")));
    assertTrue(isElementPresent(By.linkText("Doložení ověřené totožnosti kvalifikovaným certifikátem")));
    assertTrue(isElementPresent(By.linkText("Doložení ověřené totožnosti datovou schránkou")));
    assertTrue(isElementPresent(By.linkText("Doložení ověřené totožnosti doklady konvertovanými na poště")));
    assertTrue(isElementPresent(By.linkText("Jak složit dražební jistotu")));
    assertTrue(isElementPresent(By.linkText("Práce s konvertovaným dokladem v části Můj účet")));
    driver.findElement(By.xpath("(//a[contains(text(),'Jak splnit podmínky účasti v dražbě')])[2]")).click();
    try {
        assertEquals("Jak splnit podmínky účasti v dražbě", driver.findElement(By.cssSelector("h2")).getText());
        System.out.println(ft.format(dNow) + ":" + " 3.2 help: OK Nápověda > 2. Jak splnit podmínky účasti v dražbě obsahuje funkční následující linky:Jak splnit podmínky účasti v dražbě, Jak prokázat totožnost, ověření totožnosti u exekutora, Doložení ověřené totožnosti doklady zaslanými poštou, Doložení ověřené totožnosti kvalifikovaným certifikátem, Doložení ověřené totožnosti datovou schránkou, Doložení ověřené totožnosti doklady konvertovanými na poště, Jak složit dražební jistotu, Práce s konvertovaným dokladem v části Můj účet");
    } catch (Error e) {
        verificationErrors.append(e.toString());
        System.out.println(ft.format(dNow) + ":" + " 3.2 help: Nápověda > 2. Jak splnit podmínky účasti v dražbě obsahuje chybu, někter z následujících linků není funkční:Jak splnit podmínky účasti v dražbě, Jak prokázat totožnost, ověření totožnosti u exekutora, Doložení ověřené totožnosti doklady zaslanými poštou, Doložení ověřené totožnosti kvalifikovaným certifikátem, Doložení ověřené totožnosti datovou schránkou, Doložení ověřené totožnosti doklady konvertovanými na poště, Jak složit dražební jistotu, Práce s konvertovaným dokladem v části Můj účet!!!");
    }
    try {
        assertTrue(isElementPresent(By.cssSelector("img")));
    } catch (Error e) {
        verificationErrors.append(e.toString());
    }
    driver.findElement(By.cssSelector("a[title=\"Nápovéda\"]")).click();
    assertTrue(isElementPresent(By.linkText("Kdy začne dražba")));
    assertTrue(isElementPresent(By.linkText("Jak přihazovat")));
    assertTrue(isElementPresent(By.linkText("Kdy dražba končí")));
    driver.findElement(By.linkText("Jak podat námitky")).click();
    try {
        assertEquals("Jak podat námitky", driver.findElement(By.cssSelector("h2")).getText());
        System.out.println(ft.format(dNow) + ":" + " 3.3 help: OK Nápověda > 3. Jak dražit obsahuje funkční následující linky: Kdy začne dražba, jak přihazovat, kdy dražba končí, jak podat námitky");
    } catch (Error e) {
        verificationErrors.append(e.toString());
        System.out.println(ft.format(dNow) + ":" + " 3.3 help: Nápověda > 3. Jak dražit obsahuje chybu, některý z následujících linků je nefunkční: Kdy začne dražba, jak přihazovat, kdy dražba končí, jak podat námitky!!!");
    }
    driver.findElement(By.cssSelector("a[title=\"Nápovéda\"]")).click();
    assertTrue(isElementPresent(By.linkText("Jak hledat dražbu")));
    driver.findElement(By.linkText("Jak nastavit emailové upozornění")).click();
    try {
        assertEquals("Jak nastavit emailové upozornění", driver.findElement(By.cssSelector("h2")).getText());
        System.out.println(ft.format(dNow) + ":" + " 3.4 help: OK Nápověda > 4. Jak hledat dražby obsahuje funkční následující linky: Jak hledat dražbu, jak nastavit emailové upozornění");
    } catch (Error e) {
        verificationErrors.append(e.toString());
        System.out.println(ft.format(dNow) + ":" + " 3.4 help: Nápověda > 4. Jak hledat dražby obsahuje chybu,  některý z následujících linků není funkční: Jak hledat dražbu, jak nastavit emailové upozornění!!!");
    }
    driver.findElement(By.cssSelector("a[title=\"Nápovéda\"]")).click();
    assertTrue(isElementPresent(By.linkText("Předkupní právo")));
    assertTrue(isElementPresent(By.linkText("Příhoz")));
    assertTrue(isElementPresent(By.linkText("Podání")));
    assertTrue(isElementPresent(By.linkText("První příhoz")));
    assertTrue(isElementPresent(By.linkText("Povinný")));
    assertTrue(isElementPresent(By.linkText("Oprávněný")));
    assertTrue(isElementPresent(By.linkText("Dražba")));
    assertTrue(isElementPresent(By.linkText("Vydražitel")));
    assertTrue(isElementPresent(By.linkText("Dražební vyhláška")));
    assertTrue(isElementPresent(By.linkText("Dražební jistota")));
    driver.findElement(By.linkText("Nejnižší podání")).click();
    try {
        assertEquals("Nejnižší podání", driver.findElement(By.cssSelector("h2")).getText());
        System.out.println(ft.format(dNow) + ":" + " 3.5 help: OK Nápověda > 5. Pojmy obsahuje funkční následující linky: Předkupní právo, příhoz, podání, první příhoz, povinný, opravněný, dražba, vydražitel, dražební vyhláška, dražební jistota, nejnižší podání");
    } catch (Error e) {
        verificationErrors.append(e.toString());
        System.out.println(ft.format(dNow) + ":" + " 3.5 help: Nápověda > 5. Pojmy obsahuje chybu, některý z následujích linků je chybný: Předkupní právo, příhoz, podání, první příhoz, povinný, opravněný, dražba, vydražitel, dražební vyhláška, dražební jistota, nejnižší podání!!!");
    }
}


@AfterMethod
public void tearDown() throws Exception {
    driver.close();
    try
    {
        Thread.sleep(5000);
        driver.quit();
    }
    catch(Exception e)
    {
    }
}
private boolean isElementPresent(By by) {
    try {
        driver.findElement(by);
        return true;
    } catch (NoSuchElementException e) {
        return false;
    }
}

}

5 个答案:

答案 0 :(得分:2)

您没有创建新的Date对象。 而不是

System.out.println(ft.format(dNow) +...)

您必须创建一个新的Date对象

尝试将所有dNow对象更改为

System.out.println(ft.format(new Date()) +...)

答案 1 :(得分:1)

在运行每个测试之前,您没有创建新的Date对象。

添加

dNow = new Date( ); 

到setUp方法。

将您的测试分成不同的测试方法。

您还可以创建一个新方法来执行输出

private void log(final String message) {
    System.out.println(MessageFormat.format("{0} - {1}", ft.format(new Date(), message);
}

并使用它代替

System.out.println(ft.format(dNow) + ":" + " ***********ZAČÁTEK TESTU HELP***********");
像这样

log(" ***********ZAČÁTEK TESTU HELP***********");

答案 2 :(得分:1)

尝试删除 dNow 声明语句,并将所有 dNow 替换为 new Date()

答案 3 :(得分:0)

而不是日期dNow = new Date();你应该使用:

java.time.LocalDateTime.now()

它将返回当前的日期时间。

答案 4 :(得分:0)

您可以使用

Calendar.getInstance().getTime()