verifyReturnsTrue

Класс: matlab.unittest.qualifications. Поддающийся проверке
Пакет: matlab.unittest.qualifications

Проверьте, что функция возвращает true, когда оценено

Синтаксис

verifyReturnsTrue (поддающийся проверке, фактический)
verifyReturnsTrue (___, диагностика)

Описание

verifyReturnsTrue(verifiable,actual) проверяет, что actual является указателем на функцию, который возвращает скаляр, логический, чье значение верно.

verifyReturnsTrue(___,diagnostic) также отображает диагностическую информацию в diagnostic после отказа.

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

verifiable

"Образец matlab.unittest.TestCase, который используется для прохождения или непрохождения проверки типа ""verification"" в сочетании с тестовой средой.".

actual

Указатель на функцию, чтобы протестировать.

diagnostic

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

  • stringArray

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

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

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

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

Примеры

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

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

testCase = matlab.unittest.TestCase.forInteractiveUse;
verifyReturnsTrue(testCase, @true);
Interactive verification passed.

Проверьте, что это верно, что два числа равны.

verifyReturnsTrue(testCase, @() isequal(1,1));
Interactive verification passed.

Проверьте, что это верно, что две буквы не являются тем же самым.

verifyReturnsTrue(testCase, @() ~strcmp('a','b'));
Interactive verification passed.

Заставьте верификацию перестать работать путем попытки проверить, что “ложь” оценивает к “истинному”.

verifyReturnsTrue(testCase, @false);
Interactive verification failed.

---------------------
Framework Diagnostic:
---------------------
verifyReturnsTrue failed.
--> The function handle should have evaluated to "true".
--> Returned value:
             0

Actual Function Handle:
        @false

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

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

verifyReturnsTrue(testCase, @() strcmp('a',{'a','a'}));
Interactive verification failed.

---------------------
Framework Diagnostic:
---------------------
verifyReturnsTrue failed.
--> The function handle should have returned a scalar. The return value had a size of [1  2].
--> Returned value:
             1     1

Actual Function Handle:
        @()strcmp('a',{'a','a'})

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

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

verifyReturnsTrue(testCase, @() exist('exist'));
Interactive verification failed.

---------------------
Framework Diagnostic:
---------------------
verifyReturnsTrue failed.
--> The function handle should have returned a logical value. It was of type "double".
--> Returned value:
             5

Actual Function Handle:
        @()exist('exist')

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

Советы

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

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

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

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

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

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

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

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

Введенный в R2013a

Была ли эта тема полезной?