verifyInstanceOf

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

Проверьте, что значение является объектом заданного типа

Синтаксис

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

Описание

verifyInstanceOf(verifiable,actual,className) проверяет, что actual является значением MATLAB®, класс которого является классом, заданным className.

verifyInstanceOf(verifiable,actual,metaClass) проверяет, что actual является значением MATLAB, класс которого является классом, заданным экземпляром meta.class metaClass.

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

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

verifiable

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

actual

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

className

Имя класса, заданного как вектор символа.

метакласс

Экземпляр meta.class класс.

diagnostic

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

  • stringArray

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

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

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

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

Примеры

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

Эти интерактивные тесты проверяют класс номера, 5.

Создайте объект TestCase и Значение для проверки.

testCase = matlab.unittest.TestCase.forInteractiveUse;
actvalue = 5;

Проверьте, что actvalue является экземпляром класса double.

verifyInstanceOf(testCase, actvalue, 'double');
Interactive verification passed.

Проверьте, является ли actvalue экземпляром char.

verifyInstanceOf(testCase, 5, 'char');
Interactive verification failed.

---------------------
Framework Diagnostic:
---------------------
verifyInstanceOf failed.
--> The value must be an instance of the expected type.
    
    Actual Class:
        double
    Expected Type:
        char

Actual Value:
         5

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

Эти тесты проверяют указатели на функцию, заданные как meta.class экземпляр, ?function_handle.

Создайте указатель на функцию.

fh = @sin;
testCase = matlab.unittest.TestCase.forInteractiveUse;
verifyInstanceOf(testCase, fh, ?function_handle);
Interactive verification passed.

Протестируйте имя функции.

fh = 'sin';
verifyInstanceOf(testCase, fh, ?function_handle);
Interactive verification failed.

---------------------
Framework Diagnostic:
---------------------
verifyInstanceOf failed.
--> The value must be an instance of the expected type.
    
    Actual Class:
        char
    Expected Type:
        function_handle

Actual Value:
    sin

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

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

Создайте класс, BaseExample.

classdef BaseExample
end

Создайте производный класс, DerivedExample.

classdef DerivedExample < BaseExample
end

Проверьте, что DerivedExample является экземпляром BaseExample.

testCase = matlab.unittest.TestCase.forInteractiveUse;
testCase.verifyInstanceOf(DerivedExample(), ?BaseExample);
Interactive verification passed.

Проверьте, что BaseExample не является экземпляром DerivedExample.

testCase.verifyInstanceOf(BaseExample(), ?DerivedExample);
Interactive verification failed.

---------------------
Framework Diagnostic:
---------------------
verifyInstanceOf failed.
--> The value must be an instance of the expected type.
    
    Actual Class:
        BaseExample
    Expected Type:
        DerivedExample

Actual Value:
      BaseExample with no properties.

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

Советы

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

    import matlab.unittest.constraints.IsInstanceOf;
    verifiable.verifyThat(actual, IsInstanceOf(className));
    verifiable.verifyThat(actual, IsInstanceOf(metaClass));
    

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

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

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

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

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

Введенный в R2013a

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