assumeError

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

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

Синтаксис

assumeError(assumable,actual,identifier)
assumeError(assumable,actual,metaClass)
assumeError(___,diagnostic)
[output1,...,outputN] = assumeError(___)

Описание

assumeError(assumable,actual,identifier) принимает, что actual является указателем на функцию, который выдает исключение с ошибочным идентификатором, который равен identifier.

assumeError(assumable,actual,metaClass) принимает, что actual является указателем на функцию, который выдает исключение, тип которого задан экземпляром meta.class, заданным в metaClass. Этот метод не требует, чтобы экземпляр был точным соответствием класса, а скорее это должно быть в заданной иерархии классов, и та иерархия должна включать класс MException.

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

[output1,...,outputN] = assumeError(___) возвращает несколько выходных аргументов от вызова указателя на функцию actual. Используйте этот синтаксис, чтобы управлять количеством выходных аргументов, которые требуют от указателя на функцию. Если ошибки указателя на функцию, все выходные параметры имеют тип missing. В противном случае, output1,...,outputN выходные значения от actual. Можно использовать этот синтаксис с любым из входных параметров предыдущих синтаксисов.

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

assumable

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

actual

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

identifier

Ошибочный идентификатор, заданный как вектор символов.

metaClass

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

diagnostic

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

  • stringArray

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

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

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

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

Примеры

Смотрите примеры для verifyError и замените вызовы verifyError с assumeError.

Советы

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

    import matlab.unittest.constraints.Throws;
    assumable.assumeThat(actual, Throws(identifier));
    assumable.assumeThat(actual, Throws(metaClass));
    

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

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

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

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

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

Смотрите также

| | |

Введенный в R2013a