verifySameHandle

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

Проверьте, что два массива указателя являются тем же самым

Описание

пример

verifySameHandle(testCase,actual,expected) проверяет тот actual совпадает с ожидаемым массивом указателя. Два массива указателя являются тем же самым, если у них есть тот же размер, и их соответствующие элементы относятся к тому же объекту указателя.

пример

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

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

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

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

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

Ожидаемое значение в виде массива указателя.

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

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

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

Пример: @dir

Примеры

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

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

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

classdef ExampleHandle < handle
    properties
        Number = 1;
    end
end

Создайте два ExampleHandle объекты присвоены переменным h1 и h2. Затем присвойте значение h2 к другой переменной h3. Переменные h1 и h2 укажите на различные объекты, но переменные h2 и h3 укажите на тот же объект.

h1 = ExampleHandle;
h2 = ExampleHandle;
h3 = h2;

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

testCase = matlab.unittest.TestCase.forInteractiveUse;

Протестируйте если h1 и h2 укажите на тот же объект. Тестовые сбои.

verifySameHandle(testCase,h1,h2,"Values must point to the same object.")
Verification failed.
    ----------------
    Test Diagnostic:
    ----------------
    Values must point to the same object.
    ---------------------
    Framework Diagnostic:
    ---------------------
    verifySameHandle failed.
    --> Values do not refer to the same handle.
    
    Actual Value:
      ExampleHandle with properties:
    
        Number: 1
    Expected Handle Object:
      ExampleHandle with properties:
    
        Number: 1
    ------------------
    Stack Information:
    ------------------
    In C:\work\TestHandlesForEqualityExample.m (TestHandlesForEqualityExample) at 29

Проверьте тот h2 и h3 укажите на тот же объект.

verifySameHandle(testCase,h2,h3)
Verification passed.

Проверьте тот [h2 h3] и [h3 h2] то же самое. Тест передает, потому что соответствующие векторные элементы указывают на тот же объект.

verifySameHandle(testCase,[h2 h3],[h3 h2])
Verification passed.

Протестируйте если [h1 h2] и [h2 h1] то же самое. Тест перестал работать, потому что соответствующие векторные элементы указывают на различные объекты.

verifySameHandle(testCase,[h1 h2],[h2 h1])
Verification failed.
    ---------------------
    Framework Diagnostic:
    ---------------------
    verifySameHandle failed.
    --> Some elements in the handle array refer to the wrong handle.
    
    Actual Value:
      1×2 ExampleHandle array with properties:
    
        Number
    Expected Handle Object:
      1×2 ExampleHandle array with properties:
    
        Number
    ------------------
    Stack Information:
    ------------------
    In C:\work\TestHandlesForEqualityExample.m (TestHandlesForEqualityExample) at 43

Протестируйте, если два массива указателя различных форм являются тем же самым. Тестовые сбои.

verifySameHandle(testCase,[h1 h1 h2 h3],[h1 h1; h2 h3])
Verification failed.
    ---------------------
    Framework Diagnostic:
    ---------------------
    verifySameHandle failed.
    --> Sizes do not match.
        	Actual Value Size           : [1  4]
        	Expected Handle Object Size : [2  2]
    
    Actual Value:
      1×4 ExampleHandle array with properties:
    
        Number
    Expected Handle Object:
      2×2 ExampleHandle array with properties:
    
        Number
    ------------------
    Stack Information:
    ------------------
    In C:\work\TestHandlesForEqualityExample.m (TestHandlesForEqualityExample) at 48

Советы

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

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

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

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

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

Введенный в R2013a