New WebDriver instance per test method?

前端 未结 2 424
青春惊慌失措
青春惊慌失措 2021-01-01 13:24

What\'s the best practice fort creating webdriver instances in Selenium-webdriver? Once per test method, per test class or per test run?

They seem to be rather (very

相关标签:
2条回答
  • 2021-01-01 13:28

    I've found that reusing browser instances between test methods has been a huge time saver when using real browsers, e.g. Firefox. When running tests with HtmlUnitDriver, there is very little benefit.

    Regarding the danger of indeterministic tests, it's a trade-off between totally deterministic tests and your time. Integration tests often involve trade-offs like these. If you want totally deterministic integration tests you should also be worrying about clearing the database/server state in between test runs.

    One thing that you definitely should do if you are going to reuse browser instances is to clear/store the cookies between runs.

    driver.manage().deleteAllCookies();
    

    I do that in a tearDown() method. Also if your application stores any data on the client side you'd need to clear that (maybe via JavascriptExecutor). To your application which is under test, it should look like a completely unrelated request after doing this, which really minimizes the risk of indeterministic behaviour.

    0 讨论(0)
  • 2021-01-01 13:32

    If your goal of automated integration testing is to have reproducible tests, then I would recommend a new webdriver instance for every test execution.

    Each test should stand alone, independent from any other test or side-effects.

    Personally the only thing I find more frustrating than a hard to reproduce bug, is a non-deterministic test that you don't trust.

    (This becomes even more crucial for managing the test data itself, particularly when you look at tests which can modify persistent application state, like CRUD operations.)

    Yes, additional test execution time is costly, but it is better then spending the time debugging your tests.

    Some possible solutions to help offset this penalty is to roll your testing directly into your build process, going beyond Continuous Build to Continuous Integration approach.

    Also try to limit the scope of your integration tests. If you have a lot of heavy integration tests, eating up execution time, try to refactor. Instead, increase the coverage of your more lightweight unit tests of the underlying service calls (where your business logic is).

    0 讨论(0)
提交回复
热议问题