Обход NullPointerException в Mockito при подмене метода

Пройдите тест, узнайте какой профессии подходите

Я предпочитаю
0%
Работать самостоятельно и не зависеть от других
Работать в команде и рассчитывать на помощь коллег
Организовывать и контролировать процесс работы

Быстрый ответ

Для предотвращения NullPointerException в Mockito, гарантируйте корректную инициализацию мок-объектов с использованием mock() или spy(). Конфигурируйте мок следующим образом:

Java
Скопировать код
MyClass myClassMock = mock(MyClass.class);
when(myClassMock.myMethod()).thenReturn(myExpectedValue);

Важно внедрить созданные моки в тестируемый объект и инициализировать все зависимости перед началом настройки. Для этого применяются @RunWith(MockitoJUnitRunner.class) или initMocks(this).

Выбирайте точные матчеры аргументов, такие как anyInt(), anyLong() и пр., чтобы избежать ошибок при сопоставлении параметров.

Кинга Идем в IT: пошаговый план для смены профессии

Точное сопоставление аргументов

Использование специфических матчеров аргументов

Специфические матчеры обеспечивают точную настройку поведения заглушек, что предотвращает NullPointerExceptions:

Java
Скопировать код
// Правильное использование специфических матчеров аргументов
when(myClassMock.someMethod(anyInt())).thenReturn(myExpectedValue); // Метод теперь безошибочно принимает любое целое число.
Подробнее об этом расскажет наш спикер на видео
skypro youtube speaker

Аннотации упрощают настройку Mockito

Аннотации @InjectMocks, @RunWith(MockitoJUnitRunner.class) и @Before облегчают автоматическую инициализацию моков перед тестированием и минимизируют риск обращения к непроинициализированному объекту.

Осознанно используйте deep stubs

Хотя RETURNS_DEEP_STUBS упрощает моделирование цепочечных вызовов, его использование может усложнить понимание и поддержку теста, делая логику неясной.

Особенности настройки заглушек в Mockito

Мастерство конфигурирования заглушек для цепочек методов

В некоторых случаях RETURNS_DEEP_STUBS упрощает настройку моков для цепочек вызовов:

Java
Скопировать код
// Настройка цепочек вызовов с Mockito для результатов deep stubs
when(myClassMock.someMethod().anotherMethod()).thenReturn(myExpectedValue); // Одна заглушка моделирует всю последовательность вызовов.

Гарантия правильной инициализации моков

Правильно инициализируйте моки для предотвращения NullPointerException:

Java
Скопировать код
@Before
public void prepareMocks() {
  MockitoAnnotations.initMocks(this);
}

Уделите внимание типам параметров!

Необходимо учитывать типы данных параметров методов при настройке моков. Неправильный выбор матчера, например, any() вместо anyString(), может вызвать исключения.

Проверка работы заглушек

Проверка результатов и валидация предположений

Проверка предположений с помощью assert и verify помогает убедиться в корректности работы моков:

Java
Скопировать код
// Валидация взаимодействия с моком
verify(myClassMock).myMethod(anyInt()); // Подтверждаем, что метод был вызван с корректными параметрами.

Избегайте использования сеттеров на заглушках

Моки не должны иметь состояния, поэтому использование сеттеров не имеет смысла.

Правильно используйте аннотации тестирования

Некорректное использование аннотаций @Test может ввести в заблуждение. Обратите внимание, чтобы не перепутать аннотации разных тестовых фреймворков, таких как TestNG и JUnit.

Тщательно организуйте импорты

Тщательный выбор правильных импортов может предотвратить множество проблем с тестами, так же как аккуратная проверка оборудования перед полётом.

Визуализация

Визуализация настройки моков помогает предотвратить NullPointerException:

Markdown
Скопировать код
Цепь вызовов методов: 🚂 -> 🚃 -> 🚃 -> 🚎 (null)

// Подмена метода – это как добавление вагона с грузом:
Настройка: 🚂 -> 🚃 -> 🚃 -> 🚋('🎁')

// Настройка в Mockito:
when(mockedObject.someMethod()).thenReturn('🎁'); // Вагон теперь перевозит '🎁', а не 'null'.

Правильная настройка – это страховка от поезда NullPointerException, сходящего с рельсов:

Markdown
Скопировать код
До настройки:                 🚂 -> 🚃 -> 🚃 -> 🚎 (💥)
После корректной настройки: 🚂 -> 🚃 -> 🚃 -> 🚋('🎁') // Таков наш метод борьбы с катастрофами, связанными с `NullPointerException`!

🛤️🔧 // Конец неожиданным крушениям!

Полезные материалы

  1. Mockito – mockito-core 5.10.0 javadoc — официальная документация Mockito.
  2. Mockito Tutorial | Baeldung — детальное руководство по работы с Mockito.
  3. Common Causes for NullPointerException in Mockito – Stack Overflow — обсуждения, связанные с NullPointerException в Mockito.
  4. Mockito (Mockito 5.10.0 API) — подробности настройки последовательных вызовов в Mockito.
  5. Unit tests with Mockito – Tutorial — обучающее руководство по настройке моков с использованием Mockito.
  6. JUnit 5 User Guide — официальная документация по использованию Mockito вместе с JUnit.
  7. FAQ · mockito/mockito Wiki · GitHub — ответы на часто задаваемые вопросы о Mockito.
Проверь как ты усвоил материалы статьи
Пройди тест и узнай насколько ты лучше других читателей
Какой метод используется для создания моков в Mockito?
1 / 5
Свежие материалы