verifyNotSameHandle

Класс: matlab.unittest.qualifications. Проверяемый
Пакет: matlab.unittest.qualifications

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

Синтаксис

verifyNotSameHandle(verifiable,actual,notExpectedHandle)
verifyNotSameHandle(___,diagnostic)

Описание

verifyNotSameHandle(verifiable,actual,notExpectedHandle) проверяет, что actual является другим размером и/или не содержит тех же образцов, что и notExpectedHandle массив указателей.

verifyNotSameHandle(___,diagnostic) также связывает диагностическую информацию в diagnostic с проверкой. В зависимости от конфигурации исполнителя тестов строение тестирования может отображать диагностику, когда проверка проходит или не проходит. По умолчанию среда отображает диагностику только в случае сбоя проверки. Поведение по умолчанию можно переопределить путем настройки исполнителя тестов. Для примера используйте DiagnosticsOutputPlugin образец для отображения как сбойной, так и проходящей диагностики событий.

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

verifiable

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

actual

Значение для тестирования.

notExpectedHandle

Массив указателей для сравнения.

diagnostic

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

  • Строковые массивы

  • Символьный массив

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

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

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

Примеры

расширить все

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

testCase = matlab.unittest.TestCase.forInteractiveUse;

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

classdef ExampleHandle < handle
end

Создайте две переменные handle.

h1 = ExampleHandle;
h2 = ExampleHandle;

Указатели указывают на различные объекты.

verifyNotSameHandle(testCase, h1, h2);
Interactive verification passed.

Показать соответствующие комбинации указателей.

verifyNotSameHandle(testCase, [h1 h2 h1], [h1 h2 h1]);
Interactive verification failed.

---------------------
Framework Diagnostic:
---------------------
verifyNotSameHandle failed.
--> The two handles must not refer to the same handle, or should have 
different sizes.

Actual Value:
      1x3 ExampleHandle array with no properties.
Handle Object:
      1x3 ExampleHandle array with no properties.

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

Порядок аргументов указателя имеет значение.

verifyNotSameHandle(testCase, [h1 h2], [h2 h1]);
Interactive verification passed.

Тестируйте указатель сам с собой.

verifyNotSameHandle(testCase, h1, h1);
Interactive verification failed.

---------------------
Framework Diagnostic:
---------------------
verifyNotSameHandle failed.
--> The two handles must not refer to the same handle, or should have 
different sizes.

Actual Value:
      ExampleHandle with no properties.
Handle Object:
      ExampleHandle with no properties.

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

Переменные не совпадают по размеру.

verifyNotSameHandle(testCase, h2, [h2 h2]);
Interactive verification passed.

Переменные имеют одинаковый размер.

verifyNotSameHandle(testCase, [h1 h1], [h1 h1]);
Interactive verification failed.

---------------------
Framework Diagnostic:
---------------------
verifyNotSameHandle failed.
--> The two handles must not refer to the same handle, or should have 
different sizes.

Actual Value:
      1x2 ExampleHandle array with no properties.
Handle Object:
      1x2 ExampleHandle array with no properties.

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

Совет

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

    import matlab.unittest.constraints.IsSameHandleAs;
    verifiable.verifyThat(actual, ~IsSameHandleAs(notExpectedHandle));

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

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

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

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

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

Введенный в R2013a