verifyWarning

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

Проверьте, что функция выдает заданное предупреждение

Синтаксис

verifyWarning (поддающийся проверке, фактический, warningID)
verifyWarning (___, диагностика)
[output1..., outputN] = verifyWarning (___)

Описание

verifyWarning(verifiable,actual,warningID) проверяет, что actual выдает предупреждение с идентификатором warningID.

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

[output1,...,outputN] = verifyWarning(___) также возвращает выходные аргументы output1,...,outputN, которые производятся при вызове actual.

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

verifiable

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

actual

Указатель на функцию, чтобы протестировать.

warningID

Предупреждение ID, заданного как вектор символа.

diagnostic

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

  • stringArray

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

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

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

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

Выходные аргументы

output1,...,outputN

Выходные аргументы, 1 через n (если таковые имеются), от actual, возвратились как любой тип. Тип аргумента задан списком аргументов actual.

Примеры

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

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

testCase = matlab.unittest.TestCase.forInteractiveUse;

Проверьте, что фактический ID предупреждения совпадает с входным ID предупреждения.

verifyWarning(testCase, @() warning('SOME:warning:id','Warning!'), ...
    'SOME:warning:id');
Interactive verification passed.
verifyWarning(testCase, @() warning('SOME:other:id', 'Warning message'),...
    'SOME:warning:id', 'Did not issue specified warning');
Warning: Warning message 
> In @()warning('SOME:other:id','Warning message')
  In FunctionHandleConstraint>FunctionHandleConstraint.invoke at 43
  In WarningQualificationConstraint>WarningQualificationConstraint.invoke at 58
  In IssuesWarnings>IssuesWarnings.invoke at 364
  In IssuesWarnings>IssuesWarnings.issuesExpectedWarnings at 411
  In IssuesWarnings>IssuesWarnings.satisfiedBy at 240
  In QualificationDelegate>QualificationDelegate.qualifyThat at 90
  In QualificationDelegate>QualificationDelegate.qualifyWarning at 196
  In Verifiable>Verifiable.verifyWarning at 701 
Interactive verification failed.

----------------
Test Diagnostic:
----------------
Did not issue specified warning

---------------------
Framework Diagnostic:
---------------------
verifyWarning failed.
--> The function handle did not issue the expected warning.
    
    Actual Warnings:
        --> 'SOME:other:id'
    Expected Warning:
        --> 'SOME:warning:id'

Evaluated Function:
        @()warning('SOME:other:id','Warning message')

Протестируйте функцию true, которая не делает предупреждений о проблемах.

testCase = matlab.unittest.TestCase.forInteractiveUse;
verifyWarning(testCase, @true, 'SOME:warning:id', ...
'@true did not issue any warning');
Interactive verification failed.

----------------
Test Diagnostic:
----------------
@true did not issue any warning

---------------------
Framework Diagnostic:
---------------------
verifyWarning failed.
--> The function handle did not issue any warnings.
    
    Expected Warning:
        --> 'SOME:warning:id'

Evaluated Function:
        @true

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

Создайте функцию helper, которая генерирует предупреждение и возвращает вывод.

function varargout = helper()
    warning('SOME:warning:id','Warning!');
    varargout = {123, 'abc'};
end

Вызовите helper.

testCase = matlab.unittest.TestCase.forInteractiveUse;
[actualOut1, actualOut2] = verifyWarning(testCase, @helper, ...
    'SOME:warning:id');
Interactive verification passed.

Советы

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

    import matlab.unittest.constraints.IssuesWarnings;
    verifiable.verifyThat(actual, IssuesWarnings({warningID}));
    

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

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

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

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

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

Введенный в R2013a

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