Чем опасна static WebDriver?
Очень часто начинающие тестировщики сталкиваются с проблемой создания экземпляра класса, содержащего WebDriver. И, на первый взгляд, самым логичным решением будет создать static-переменную, проинициализировать ее, а потом использовать в тестах.
И, действительно, при запуске на локальной машине тесты выполняются. Однако в будущем это может сыграть злую шутку.
Что такое модификатор static?
Модификатор static означает, что эта переменная будет принадлежать классу, а не экземпляру класса. Что же это означает на практике? Сколько бы не создавался класс, переменная будет одна.
Для понимания, рассмотрим следующий код:
public class StaticClass { static String staticVar = "this is static"; public void printStaticVar(){ System.out.println(staticVar); } }
Данный класс имеет одну статичную переменную и один метод, который ее выводит. Давайте теперь создадим два экземпляра класса и вызовем метод.
public class t2 { public static void main(String[] args) { StaticClass sc1 = new StaticClass(); sc1.printStaticVar(); StaticClass sc2 = new StaticClass(); sc2.printStaticVar(); } }
В обоих случаях нам выведется корректный результат (тот, который мы ожидаем).
This is static var This is static var
Однако что будет, если мы изменим static-переменную?
public static void main(String[] args) { StaticClass sc1 = new StaticClass(); staticVar = "This is new static var"; sc1.printStaticVar(); StaticClass sc2 = new StaticClass(); sc2.printStaticVar(); }
Что в данном случае выведется на экран? Чаще всего, начинающий автоматизатор ожидает, что будет выведено примерно следующее:
This is new static var This is static var
Однако, в реальности будет выведено:
This is new static var This is new static var
Почему так случилось? Потому, что переменная принадлежит классу, а не экземпляру. А что же случится, если мы будем использовать static WebDriver?
При запуске в многопоточности (а необходимость в ней возникает почти сразу), переменная будет перезаписываться (т. к. каждый запуск тестов будет перезаписывать эту переменную), что приведет к некорректной работе тестов.
Чтобы избежать этой проблемы, используйте локальные переменные без модификатора static.