verifyLength

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

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

Синтаксис

verifyLength(verifiable,actual,expectedLength)
verifyLength(___,diagnostic)

Описание

verifyLength(verifiable,actual,expectedLength) проверяет тот actual массив MATLAB®, длиной которого является expectedLength.

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

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

verifiable

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

actual

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

expectedLength

Длина массива задана как самая большая размерность того массива.

diagnostic

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

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

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

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

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

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

Примеры

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

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

testCase = matlab.unittest.TestCase.forInteractiveUse;

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

verifyLength(testCase, ones(2, 5, 3), 5, 'User diagnostic');
Interactive verification passed.

Длина массива не является ожидаемым значением, 3.

verifyLength(testCase, [2 3], 3);
Interactive verification failed.

---------------------
Framework Diagnostic:
---------------------
verifyLength failed.
--> The array has an incorrect length.
    
    Actual Length:
             2
    Expected Length:
             3

Actual Array:
         2     3

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

Длиной 2x3 массив является 3.

verifyLength(testCase, [1 2 3; 4 5 6], 3);
Interactive verification passed.

Проверьте длину 2x3, массив не является числом элементов, 6.

verifyLength(testCase, [1 2 3; 4 5 6], 6);
Interactive verification failed.

---------------------
Framework Diagnostic:
---------------------
verifyLength failed.
--> The array has an incorrect length.
    
    Actual Length:
             3
    Expected Length:
             6

Actual Array:
         1     2     3
         4     5     6

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

verifyLength(testCase, eye(2), 4);
Interactive verification failed.

---------------------
Framework Diagnostic:
---------------------
verifyLength failed.
--> The array has an incorrect length.
    
    Actual Length:
             2
    Expected Length:
             4

Actual Array:
         1     0
         0     1
testCase = matlab.unittest.TestCase.forInteractiveUse;
verifyLength(testCase, {'someText', 'someotherText'}, 2);
Interactive verification passed.

Советы

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

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

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

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

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

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

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

Введенный в R2013a