mirror of
https://github.com/bia-technologies/yaxunit.git
synced 2025-04-11 11:11:51 +02:00
97 lines
5.3 KiB
Markdown
97 lines
5.3 KiB
Markdown
|
---
|
||
|
tags: [Getting started, Test data]
|
||
|
---
|
||
|
|
||
|
# Удаление тестовых данных
|
||
|
|
||
|
При использовании тестовых данных нередко необходимо удалять созданные объекты.
|
||
|
|
||
|
Для этого вы можете использовать
|
||
|
|
||
|
## Автоматические транзакции
|
||
|
|
||
|
Для включения нужно при регистрации теста вызвать метод `ВТранзакции()`
|
||
|
|
||
|
```bsl title=ВТранзакции.bsl
|
||
|
ЮТТесты
|
||
|
.ДобавитьТест("Фикция").ВТранзакции() // Использование транзакции для конкретного теста
|
||
|
|
||
|
ЮТТесты
|
||
|
.ДобавитьТестовыйНабор("Основной).ВТранзакции() // Использование транзакции для набора тестов
|
||
|
.ДобавитьТест("Фикция")
|
||
|
|
||
|
ЮТТесты.ВТранзакции() // Использование транзакции для тестов модуля
|
||
|
.ДобавитьТест("Фикция")
|
||
|
|
||
|
```
|
||
|
|
||
|
И тогда тестовый движок будет оборачивать в транзакцию каждый серверный тест (для клиентских будет игнорироваться)
|
||
|
|
||
|
:::caution Учитывайте
|
||
|
В транзакцию оборачивается тест, а не модуль или набор, поэтому данные созданные вне теста не будут удалены.
|
||
|
Такие данные необходимо удалять самостоятельно при необходимости.
|
||
|
:::
|
||
|
|
||
|
## Механизма удаления тестовых данных
|
||
|
|
||
|
Для включения нужно при регистрации теста вызвать метод `УдалениеТестовыхДанных()`
|
||
|
|
||
|
```bsl title=УдалениеТестовыхДанных.bsl
|
||
|
ЮТТесты
|
||
|
.ДобавитьТест("Фикция").УдалениеТестовыхДанных() // Использование для конкретного теста
|
||
|
|
||
|
ЮТТесты
|
||
|
.ДобавитьТестовыйНабор("Основной).УдалениеТестовыхДанных() // Использование для всех тестов набора
|
||
|
.ДобавитьТест("Фикция")
|
||
|
|
||
|
ЮТТесты.УдалениеТестовыхДанных() // Использование для всех тестов модуля
|
||
|
.ДобавитьТест("Фикция")
|
||
|
|
||
|
ЮТТесты.ВТранзакции().УдалениеТестовыхДанных() // Совместно с транзакцией
|
||
|
.ДобавитьТест("Фикция")
|
||
|
|
||
|
```
|
||
|
|
||
|
Механизм не используется транзакции, а запоминает в контексте все созданные с помощью API объекты и записи регистров сведений.
|
||
|
Позволяет:
|
||
|
|
||
|
* Удалять данные созданные с клиента
|
||
|
* Удалять данные созданные вне теста (в обработчиках событий)
|
||
|
|
||
|
:::tip
|
||
|
Механизм понимает в рамках какого контекста исполнения (тест, набор, модуль) были созданы данные и удаляет их по выходу из него.
|
||
|
:::
|
||
|
|
||
|
Рассмотрим время жизни объектов созданных на разных этапах тестирования, например имеем такой модуль.
|
||
|
|
||
|
```bsl title=УдалениеТестовыхДанныхВремяЖизни.bsl
|
||
|
Процедура ПередВсемиТестами() Экспорт
|
||
|
ДанныеМодуля = ЮТест.Данные().СоздатьЭлемент(); // Не будет удалена
|
||
|
КонецПроцедуры
|
||
|
|
||
|
Процедура ПередТестовымНабором() Экспорт
|
||
|
ДанныеНабора = ЮТест.Данные().СоздатьЭлемент();
|
||
|
КонецПроцедуры
|
||
|
|
||
|
Процедура ПослеВсехТестов() Экспорт
|
||
|
ДанныеТеста = ЮТест.Данные().СоздатьЭлемент();
|
||
|
КонецПроцедуры
|
||
|
|
||
|
Процедура Тест() Экспорт
|
||
|
Ссылка = ЮТест.Данные().СоздатьЭлемент();
|
||
|
КонецПроцедуры
|
||
|
```
|
||
|
|
||
|
Для переменных получим разное время жизни
|
||
|
|
||
|
* `ДанныеМодуля` - Не будет удалена, проблема будет решена в ближайшем будущем.
|
||
|
* `ДанныеНабора` - Живет, пока исполняются тесты набора.
|
||
|
* `ДанныеТеста` и `Ссылка`- Живут, пока исполняется тест.
|
||
|
|
||
|
:::caution Механизм имеет ряд ограничений и не работает для следующих кейсов:
|
||
|
|
||
|
* Данные создан не через API
|
||
|
* Данные созданы в событии "ПередВсемиТестами" (работает для "ПередТестовымНабором")
|
||
|
* Данные созданы в клиентском модуле через вызов своего серверного модуля, даже если он использует API тестового движка
|
||
|
:::
|