Как генерировать тесты с разными именами в TestNG? - PullRequest
5 голосов
/ 30 апреля 2010

Я использую TestNG для запуска тестов на основе Selenium в Java. У меня есть куча повторных тестов. Как правило, они делают все то же самое, кроме имени теста и одного параметра.

Я хочу автоматизировать его генерацию. Я думал об использовании фабрики. Есть ли способ генерировать тесты с другим именем? Каков наилучший подход к этому?

На данный момент у меня есть что-то вроде ниже, и я хочу создать 10 тестов, как LinkOfInterestIsActiveAfterClick

@Test(dependsOnGroups="loggedin")
public class SmokeTest extends BrowserStartingStoping{

public void LinkOfInterestIsActiveAfterClick(){
        String link = "link_of_interest";
        browser.click("*",link);
        Assert.assertTrue(browser.isLinkActive(link));
    }

}
  • Мой комплект XML автоматически генерируется из кода Java.
  • Имена тестов имеют решающее значение для регистрации, какая ссылка активна, а какая нет.

Ответы [ 2 ]

8 голосов
/ 30 апреля 2010

Пусть ваш тестовый класс реализует org.testng.ITest и переопределит getTestName(), чтобы вернуть желаемое имя.

2 голосов
/ 07 мая 2010

Итак, я связал Factory с DataProvider и использовал атрибуты контекстов.

@DataProvider(name = "DP1")
public Object[][] createData() {
  Object[][] retObjArr={
  {"Link1","link_to_page"},
  {"Link2","link_to_page"},
  return retObjArr;
}

@Test (dataProvider = "DP1")
public void isActive(String name, String link){
  this.context.setAttribute("name", name);
  browser.click(link);
  Assert.assertTrue(browser.isLinkActive(link));
}

А в Слушателе

public class MyListener extends TestListenerAdapter{
  @Override
  public void onTestSuccess(ITestResult tr){
    log("+",tr);
  }
  //and similar

  private void log(String string, ITestResult tr){
    List<ITestContext> k = this.getTestContexts();
    String testName = tr.getTestClass().getName();      
    for (ITestContext i: k)
    {
      if (i.getAttribute("name") != null)
        logger.info(testName+"."+i.getAttribute("name"));
    }
  }

}
...