verifyTrue

Класс: matlab.unittest.qualifications.Verifiable
Пакет: matlab.unittest.qualifications

Проверьте, что значение верно

Синтаксис

verifyTrue(verifiable,actual)
verifyTrue(___,diagnostic)

Описание

verifyTrue(verifiable,actual) проверяет тот actual скаляр, логический со значением истины.

verifyTrue(___,diagnostic) также сопоставляет диагностическую информацию в diagnostic с проверкой. В зависимости от настройки исполнителя тестов среда тестирования может отобразить диагностику когда передачи проверки или сбои. По умолчанию среда отображает диагностику только, когда проверка перестала работать. Можно заменить поведение по умолчанию путем настройки исполнителя тестов. Например, используйте DiagnosticsOutputPlugin экземпляр, чтобы отобразить и провальную и передающую диагностику события.

Входные параметры

verifiable

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

actual

Значение для проверки.

diagnostic

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

  • массив строк

  • массив символов

  • указатель на функцию

  • matlab.unittest.diagnostics.Diagnostic объект

Значения диагностики могут быть нескалярными. Для получения дополнительной информации см. Matlab.unittest.diagnostics.Diagnostic.

Примеры

развернуть все

Создайте TestCase объект для интерактивного тестирования.

testCase = matlab.unittest.TestCase.forInteractiveUse;

Тест true.

verifyTrue(testCase, true);
Interactive verification passed.

Тест false.

verifyTrue(testCase, false);
Interactive verification failed.

---------------------
Framework Diagnostic:
---------------------
verifyTrue failed.
--> The value must evaluate to "true".

Actual Value:
         0

Не удалось выполнить тест.

Номер 1 double значение, не логическое значение.

Двойное значение 1 не true.

testCase = matlab.unittest.TestCase.forInteractiveUse;
verifyTrue(testCase, 1);
Interactive verification failed.

---------------------
Framework Diagnostic:
---------------------
verifyTrue failed.
--> The value must be logical. It is of type "double".

Actual Value:
         1

Не удалось выполнить тест.

Чтобы быть верным, значение должно быть скаляром.

testCase = matlab.unittest.TestCase.forInteractiveUse;
verifyTrue(testCase, [true true true]);
Interactive verification failed.

---------------------
Framework Diagnostic:
---------------------
verifyTrue failed.
--> The value must be scalar. It has a size of [1  3].

Actual Value:
         1     1     1

Не удалось выполнить тест.

Советы

  • Этот метод передает, если и только если фактическое значение является скаляром, логическим со значением истины. Поэтому сущности, такие как истинные ценные массивы и ненулевой удваиваются, производят отказы проверки, когда используется в этом методе, несмотря на эти сущности, показывающие "подобное истине" поведение, такие как инициирование подписания кода в "если" операторы.

  • Этот метод функционально эквивалентен:

    import matlab.unittest.constraints.IsTrue;
    verifiable.verifyThat(actual, IsTrue());
    

    Там существует больше функциональности при использовании IsTrue ограничение непосредственно через verifyThat.

    Использование этого метода для выигрышей в производительности может произойти за счет меньшей диагностической информации и не может обеспечить, тот же уровень строгости придерживался другими ограничениями, такими как IsEqualTo. Аналогичный подход, который обычно менее производителен, но может предоставить немного лучшую диагностическую информацию, является использованием verifyReturnsTrue, который, по крайней мере, показывает отображение функции, выполненной, чтобы сгенерировать провальный результат.

  • Используйте проверку типа "verification" для создания и записи сбоев без выдачи исключения. Поскольку проверки не выдают исключения, все тесты выполняются до своего завершения, даже когда имеют место сбои в проверке. Как правило, проверки типа "verification" являются основой для модульного теста, поскольку они обычно не требуют раннего выхода из тестирования. Используйте другие типы проверки для выявления нарушений предварительных обязательных условий или неправильной настройки теста. В качестве варианта,

    • Используйте проверку типа "assumption", чтобы убедиться, что тестовая среда соответствует предварительным обязательным условиям, которые не приводят к ошибке тестирования. Нарушение условий приводит к фильтрации тестов, а среда тестирования помечает тесты как незавершенныеДля получения дополнительной информации см. matlab.unittest.qualifications. Assumable.

    • Используйте проверку типа "assertion", когда состояние отказа делает недействительным оставшуюся часть текущего теста, но не препятствует правильному выполнению последующих видов тестирования. Сбой в точке утверждения показывает, что текущий метод тестирования является неудачным и неполным. Для получения дополнительной информации см. matlab.unittest.qualifications. Assertable.

    • Используйте проверку типа "fatal assertion", чтобы прервать сеанс тестирования после сбоя. Эти типы проверки применяются, когда характер отказа настолько принципиален, что нет смысла продолжать тестирование. Эти виды проверки также применяются, когда отключение без изменений не восстанавливает состояние MATLAB® правильно, и лучше прекратить тестирование и начать новый сеанс. Для получения дополнительной информации см. matlab.unittest.qualifications. FatalAssertable.

Введенный в R2013a