이 글에서는 PHP에서 어설션 함수를 사용하는 방법을 소개합니다. 도움이 필요한 친구들이 모두 참고할 수 있기를 바랍니다.
저는 원래 Assertion 관련 함수가 PHPUnit과 같은 단위 테스트 컴포넌트에서 제공되는 줄 알았는데, 매뉴얼을 읽다가 Assert() Assertion 함수가 PHP 자체에 포함된 함수라는 것을 알게 되었습니다. 즉, 코드에서 간단한 테스트를 수행할 때 전체 단위 테스트 구성 요소를 완전히 소개할 필요는 없습니다.
assert(1==1); assert(1==2); // assert.exception = 0 时,Warning: assert(): assert(1 == 2) // assert.exception = 1 时,Fatal error: Uncaught AssertionError: 验证不通过
분명히 두 번째 코드 부분은 주장 검증을 통과할 수 없습니다. 이때 PHP는 경고 또는 예외 오류를 반환합니다. 가능한 오류 형식이 두 가지인 이유는 무엇입니까? php.ini에서 Assert.Exception을 off 또는 0으로 설정하면, 즉 이 매개변수의 기능을 끄면 프로그램은 위 코드의 주석과 마찬가지로 여전히 PHP5 형식으로 경고를 반환합니다.
동시에 try...catch를 통해서는 예외를 포착할 수 없습니다. 이 매개변수는 실제 예외 객체를 발생시킬지 여부를 실제로 제어합니다. 이 매개변수를 기본값, 즉 on 또는 1로 유지하면 예외가 직접 발생하고 프로그램이 종료됩니다.
위 코드에서 볼 수 있듯이 어설션의 첫 번째 매개변수는 표현식이며, bool 유형 객체를 반환하는 표현식이 필요합니다. 문자열이나 숫자를 전달하면 어떻게 될까요?
// 设置 assert.exception = 0 进行多条测试 assert(" "); // Deprecated: assert(): Calling assert() with a string argument is deprecated // Warning: assert(): Assertion " " failed assert("1"); // Deprecated: assert(): Calling assert() with a string argument is deprecated assert(0); // Warning: assert(): assert(0) failed assert(1); assert("1==2"); // Deprecated: assert(): Calling assert() with a string argument is deprecated // Warning: assert(): Assertion "1==2" failed
분명히 첫 번째 매개변수의 표현식은 유형 강제를 거치게 되지만, 문자열 유형에는 더 이상 사용되지 않는 알림이 표시됩니다. 이는 Assert() 함수에 전달된 문자열 유형의 표현식 유형이 더 이상 사용되지 않음을 나타냅니다. 현재 테스트 버전은 7.3입니다. 향후 작업을 종료하는 오류나 예외가 직접 보고될 수 있습니다.
가장 큰 문제는 전달된 문자열 자체도 표현식인 경우 이 표현식의 내용을 기준으로 판단이 이루어지므로 마지막 코드와 마찬가지로 쉽게 모호해질 수 있다는 것입니다. 물론, 오래된 사용법은 아직 권장되지 않습니다.
다음으로 Assert() 함수의 다른 매개변수를 살펴보겠습니다. 두 번째 매개변수는 오류 정보를 정의하는 데 사용되는 문자열 또는 예외를 발생시키는 데 사용되는 예외 클래스입니다.
assert(1==1, "验证不通过"); assert(1==2, "验证不通过"); // Warning: assert(): 验证不通过 failed
문자열을 직접 입력하면 우리가 정의한 오류 메시지의 내용이 경고 메시지에 표시됩니다. 이것은 이해하기 매우 쉽습니다.
// 注意 assert.exception 设置不同的区别 assert(1==1, new Exception("验证不通过")); assert(1==2, new Exception("验证不通过")); // assert.exception = 1 时,Fatal error: Uncaught Exception: 验证不通过 // assert.exception = 0 时,Warning: assert(): Exception: 验证不通过
물론, 어설션이 예외를 발생시키도록 예외 클래스를 제공할 수도 있습니다. 기본적으로 이 예외가 발생하면 프로그램 실행이 중단됩니다. 이는 일반적인 예외 발생 프로세스입니다. try...catch를 사용하여 예외를 잡을 수 있습니다.
try{ assert(1==2, new Exception("验证不通过")); }catch(Exception $e){ echo "验证失败!:", $e->getMessage(), PHP_EOL; } // 验证失败!:验证不通过
어설션의 전반적인 작동에 영향을 미치는 또 다른 매개변수가 있는데, 그것은 php.ini의 zend.assertions 매개변수입니다. 여기에는 세 가지 값이 포함됩니다.
이 매개변수를 직접 구성하고 테스트할 수 있습니다. php.ini의 기본값은 1이며, 이는 Assert() 함수가 정상적으로 실행된다는 의미입니다.
PHP의 어설션 함수는 어설션 기능과 관련된 일부 매개변수를 쉽게 설정하고 얻을 수 있는 Assert_options() 함수도 제공합니다. 설정할 수 있는 어설션 플래그는 다음과 같습니다.
플래그 | INI 설정 | 기본값 | 설명
ASSERT_ACTIVE | assert.active | 1 | Assertion() Assertion |
ASSERT _WARNING | 주장 .warning | 1 | 실패한 각 어설션에 대해 PHP 경고 생성 |
ASSERT_BAIL | assert.bail | 0 | 어설션 실패 시 실행 중단 |
ASSERT_QUIET_EVAL | assert.quiet_eval | 0 | 어설션 표현식이 평가될 때 error_reporting 비활성화 |
ASSERT_CALLBACK | assert.callback | (NULL) | 어설션이 실패할 때 호출되는 콜백 함수 |
这些参数的含义都非常好理解,大家可以自己测试一下。我们就来看一下最后一个 ASSERT_CALLBACK 的作用。其实它的说明也非常清楚,就是断言失败的情况下就进入到这个选项定义的回调函数中。
assert_options(ASSERT_ACTIVE, 1); assert_options(ASSERT_WARNING, 1); assert_options(ASSERT_BAIL, 1); assert_options(ASSERT_CALLBACK, function($params){ echo "====faild====", PHP_EOL; var_dump($params); echo "====faild====", PHP_EOL; }); assert(1!=1); // ====faild==== // string(105) ".../source/一起学习PHP中断言函数的使用.php" // ====faild====
当断言失败的时候,我们就进入了回调函数中,在回调函数直接简单的打印了传给回调函数的参数内容。可以看出,这个回调函数里面传递过来的是无法通过断言的文件信息。
学习掌握一下断言函数的使用及配置,可以为我们将来学习 PHPUnit 单元测试打下基础,当然,本身这个能力的东西就不是很多,大家记住就好啦!
测试代码:
https://github.com/zhangyue0503/dev-blog/blob/master/php/202005/source/%E4%B8%80%E8%B5%B7%E5%AD%A6%E4%B9%A0PHP%E4%B8%AD%E6%96%AD%E8%A8%80%E5%87%BD%E6%95%B0%E7%9A%84%E4%BD%BF%E7%94%A8.php
推荐学习:php视频教程
위 내용은 PHP에서 어설션 함수를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!