Google is committed to advancing racial equity for Black communities. See how.
Эта страница была переведа с помощью Cloud Translation API.
Switch to English

Использовать Suite Retry

Набор обычно включает несколько тестовых модулей и может достигать довольно большого размера тестового корпуса. Например, Android Compatibility Test Suite (CTS) включает сотни модулей и сотни тысяч тестовых случаев.

Большое количество тестов может не пройти из-за плохой изоляции или перехода устройств в плохое состояние.

Функция повторной попытки пакета предназначена для решения этих случаев: она позволяет вам повторять попытки сбоя только вместо полных наборов, чтобы исключить нестабильность и плохую изоляцию. Если тест постоянно терпит неудачу, повторная попытка также не удастся; и вы получите гораздо более сильный сигнал, что существует реальная проблема.

Реализовать повторную попытку набора

Повторная попытка результатов включает чтение предыдущих результатов и повторный запуск предыдущего вызова.

Основным интерфейсом, запускающим повторную попытку, является ITestSuiteResultLoader , который позволяет загружать предыдущий результат и предыдущую командную строку.

Затем RetryRescheduler использует эту информацию для воссоздания предыдущей команды и заполнения некоторых фильтров, чтобы повторно запустить только предыдущие сбои или невыполненные тесты.

Пример повторной попытки набора: CTS

Конфигурация повтора в CTS:

<configuration description="Runs a retry of a previous CTS session.">
    <object type="previous_loader" class="com.android.compatibility.common.tradefed.result.suite.PreviousResultLoader" />
    <test class="com.android.tradefed.testtype.suite.retry.RetryRescheduler" />

    <logger class="com.android.tradefed.log.FileLogger">
        <option name="log-level-display" value="WARN" />
    </logger>
</configuration>

Это применимо к большинству комплектов, которые его расширяют, например VTS ).

Он будет вызываться через:

cts-tradefed run retry --retry <session>

Сессию можно найти, перечислив предыдущие результаты в консоли CTS:

cts-tf > l r
Session  Pass  Fail  Modules Complete  Result Directory     Test Plan  Device serial(s)  Build ID   Product
0        2092  30    148 of 999        2018.10.29_14.12.57  cts        [serial]          P          Pixel

Точная исходная команда будет перезагружена и повторно запущена с дополнительными фильтрами. Это означает, что если ваша исходная команда включала некоторые параметры, они также будут частью повторной попытки.

Например:

cts-tradefed run cts-dev -m CtsGestureTestCases

CtsGestureTestCases попытка, CtsGestureTestCases выше, всегда будет ограничена CtsGestureTestCases поскольку мы CtsGestureTestCases команду, в которой задействована только она.

Настроить повтор для набора в стиле CTS

Чтобы повторная попытка сработала, предыдущие результаты необходимо экспортировать в формате прототипа. Необходимо добавить следующее:

<result_reporter class="com.android.compatibility.common.tradefed.result.suite.CompatibilityProtoResultReporter" />

Его необходимо добавить в XML-конфигурацию основной команды, и в результате в папке результатов будет создан файл test-record.pb .

Затем CTS retry загружает данные из комбинации test-record.pb и существующего test_result.xml для подготовки повторного вызова.