verifyClass

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

Проверьте класс заданного значения

Описание

пример

verifyClass(testCase,actual,class) проверяет что класс actual заданный класс.

Этот метод проверяет точное соответствие класса. Чтобы проверить включение в иерархию классов, используйте verifyInstanceOf.

пример

verifyClass(testCase,actual,class,diagnostic) также сопоставляет диагностическую информацию в diagnostic с проверкой.

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

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

Объект теста в виде экземпляра matlab.unittest.qualifications.Verifiable класс. Поскольку matlab.unittest.TestCase класс разделяет на подклассы matlab.unittest.qualifications.Verifiable и наследовал его методы, testCase обычно matlab.unittest.TestCase экземпляр.

Значение, чтобы протестировать в виде значения любого типа данных.

Ожидаемый класс в виде строкового скаляра, вектора символов или meta.class экземпляр.

Пример: "MyClass"

Пример: ?MyClass

Диагностическая информация, чтобы отобразиться, когда передачи проверки или сбои в виде массива строк, символьного массива, указателя на функцию или массива matlab.unittest.diagnostics.Diagnostic объекты.

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

Пример: "My Custom Diagnostic"

Пример: @dir

Примеры

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

Создайте контрольный пример для интерактивного тестирования.

testCase = matlab.unittest.TestCase.forInteractiveUse;

Проверьте что класс числового значения 5 double.

verifyClass(testCase,5,"double")
Verification passed.

Повторите тест с помощью meta.class экземпляр вместо строки.

verifyClass(testCase,5,?double)
Verification passed.

Протестируйте, если нуль является логическим значением. Тестовые сбои.

verifyClass(testCase,0,"logical","Value must be logical.")
Verification failed.
    ----------------
    Test Diagnostic:
    ----------------
    Value must be logical.
    ---------------------
    Framework Diagnostic:
    ---------------------
    verifyClass failed.
    --> The value's class is incorrect.
        
        Actual Class:
            double
        Expected Class:
            logical
    
    Actual Value:
         0
    ------------------
    Stack Information:
    ------------------
    In C:\work\TestNumericValuesExample.m (TestNumericValuesExample) at 20

Создайте контрольный пример для интерактивного тестирования.

testCase = matlab.unittest.TestCase.forInteractiveUse;

Проверьте тот @sin указатель на функцию.

verifyClass(testCase,@sin,?function_handle)
Verification passed.

Повторите тест с помощью имени функции "sin". Тестовые сбои.

verifyClass(testCase,"sin",?function_handle)
Verification failed.
    ---------------------
    Framework Diagnostic:
    ---------------------
    verifyClass failed.
    --> The value's class is incorrect.
        
        Actual Class:
            string
        Expected Class:
            function_handle
    
    Actual Value:
        "sin"
    ------------------
    Stack Information:
    ------------------
    In C:\work\TestAFunctionHandleExample.m (TestAFunctionHandleExample) at 17

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

В файле в вашей текущей папке создайте ExampleHandle класс Handle.

classdef ExampleHandle < handle
    properties
        Number = 1;
    end
end

Создайте экземпляр заданного класса.

actual = ExampleHandle;

Создайте тест для интерактивного тестирования, и затем проверьте что класс actual ExampleHandle.

testCase = matlab.unittest.TestCase.forInteractiveUse;
verifyClass(testCase,actual,?ExampleHandle)
Verification passed.

Повторите тест с помощью handle класс. Тест перестал работать потому что handle не точный класс фактического значения.

verifyClass(testCase,actual,?handle)
Verification failed.
    ---------------------
    Framework Diagnostic:
    ---------------------
    verifyClass failed.
    --> The value's class is incorrect.
        
        Actual Class:
            ExampleHandle
        Expected Class:
            handle
    
    Actual Value:
      ExampleHandle with properties:
    
        Number: 1
    ------------------
    Stack Information:
    ------------------
    In C:\work\TestInstanceOfADerivedClassExample.m (TestInstanceOfADerivedClassExample) at 26

Используйте verifyClass протестировать класс выхода функции.

В файле в вашей текущей папке создайте add5 функция. Функция принимает числовой вход и постепенно увеличивает его пять.

function y = add5(x)
% add5 - Increment input by 5
if ~isa(x,"numeric")
    error("add5:InputMustBeNumeric","Input must be numeric.")
end
y = x + 5;
end

Вызовите функцию с допустимым входом.

actual = add5(1);

Создайте тест для интерактивного тестирования, и затем проверьте что класс actual double.

testCase = matlab.unittest.TestCase.forInteractiveUse;
verifyClass(testCase,actual,?double)
Verification passed.

Советы

  • verifyClass удобный метод. Например, verifyClass(testCase,actual,class) функционально эквивалентно следующему коду.

    import matlab.unittest.constraints.IsOfClass
    testCase.verifyThat(actual,IsOfClass(class))
    
  • Используйте проверку типа "verification" для создания и записи сбоев без выдачи исключения. Поскольку проверки не выдают исключения, все тесты выполняются до своего завершения, даже когда имеют место сбои в проверке. Как правило, проверки типа "verification" являются основой для модульного теста, поскольку они обычно не требуют раннего выхода из тестирования. Используйте другие типы проверки для выявления нарушений предварительных обязательных условий или неправильной настройки теста:

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

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

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

Введенный в R2013a