verifyReturnsTrue

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

Проверьте, что функция возвращает true

Описание

пример

verifyReturnsTrue(testCase,actual) проверяет тот actual указатель на функцию, который возвращает логический скалярный 1 TRUE).

пример

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

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

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

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

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

Пример: @() myFunction(1,2)

Пример: @() ~strcmp('a','b')

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

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

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

Пример: @dir

Примеры

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

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

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

testCase = matlab.unittest.TestCase.forInteractiveUse;

Протестируйте true функция.

verifyReturnsTrue(testCase,@true)
Verification passed.

Протестируйте false функция. Тест перестал работать потому что false не возвращает true.

verifyReturnsTrue(testCase,@false)
Verification failed.
    ---------------------
    Framework Diagnostic:
    ---------------------
    verifyReturnsTrue failed.
    --> The function handle did not evaluate to "true".
    --> Returned value:
              logical
            
               0
    
    Evaluated Function:
      function_handle with value:
    
        @false
    ------------------
    Stack Information:
    ------------------
    In C:\work\TestIfFunctionReturnsTrueExample.m (TestIfFunctionReturnsTrueExample) at 19

Протестируйте если вызов isequal возвращает верный, учитывая два эквивалентных числовых значения.

verifyReturnsTrue(testCase,@() isequal(1,single(1)))
Verification passed.

Проверьте, что это верно, что две различных буквы различные.

verifyReturnsTrue(testCase,@() ~strcmp('a','b'))
Verification passed.

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

verifyReturnsTrue(testCase,@() strcmp('a',{'a','a'}))
Verification failed.
    ---------------------
    Framework Diagnostic:
    ---------------------
    verifyReturnsTrue failed.
    --> The function handle did not return a scalar. The return value had a size of [1  2].
    --> Returned value:
              1×2 logical array
            
               1   1
    
    Evaluated Function:
      function_handle with value:
    
        @()strcmp('a',{'a','a'})
    ------------------
    Stack Information:
    ------------------
    In C:\work\TestIfFunctionReturnsTrueExample.m (TestIfFunctionReturnsTrueExample) at 33

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

verifyReturnsTrue(testCase,@ones, ...
    "Returned value must be a logical scalar.")
Verification failed.
    ----------------
    Test Diagnostic:
    ----------------
    Returned value must be a logical scalar.
    ---------------------
    Framework Diagnostic:
    ---------------------
    verifyReturnsTrue failed.
    --> The function handle did not return a logical value. The return value was of type "double".
    --> Returned value:
                 1
    
    Evaluated Function:
      function_handle with value:
    
        @ones
    ------------------
    Stack Information:
    ------------------
    In C:\work\TestIfFunctionReturnsTrueExample.m (TestIfFunctionReturnsTrueExample) at 37

Советы

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

    import matlab.unittest.constraints.ReturnsTrue
    testCase.verifyThat(actual,ReturnsTrue)
    
  • Альтернатива verifyReturnsTrue verifyTrue метод. verifyTrue запуски быстрее и легче использовать, но verifyReturnsTrue предоставляет немного лучшую диагностическую информацию. В этом примере, обоих тестовых сбоях, но втором тесте отображает указатель на функцию как часть диагностики.

    actual = 1;
    expected = 2;
    testCase = matlab.unittest.TestCase.forInteractiveUse;
    verifyTrue(testCase,isequal(actual,expected))
    verifyReturnsTrue(testCase,@()isequal(actual,expected))
  • Используйте проверку типа "verification" для создания и записи сбоев без выдачи исключения. Поскольку проверки не выдают исключения, все тесты выполняются до своего завершения, даже когда имеют место сбои в проверке. Как правило, проверки типа "verification" являются основой для модульного теста, поскольку они обычно не требуют раннего выхода из тестирования. Используйте другие типы проверки для выявления нарушений предварительных обязательных условий или неправильной настройки теста:

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

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

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

Введенный в R2013a