Чем опасна static WebDriver? | OTUS

Чем опасна 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.

Не пропустите новые полезные статьи!

Спасибо за подписку!

Мы отправили вам письмо для подтверждения вашего email.
С уважением, OTUS!

Автор
0 комментариев
Для комментирования необходимо авторизоваться