PHP 개발 동안 Bindec () 함수는 종종 이진 문자열을 소수점 숫자로 변환하는 데 사용됩니다. 코드의 정확성을 보장하기 위해 일반적으로 기능 동작을 확인하기 위해 단위 테스트를 작성합니다. 이 기사에서는 단위 테스트에서 이진 입력을 시뮬레이션하고 Bindec () 함수의 출력 결과를 확인하는 방법을 소개합니다.
Bindec () 는 이진 문자열을 해당 10 진수 정수로 변환하는 PHP 내장 기능입니다.
<?php
echo bindec("1101"); // 산출 13
실제 프로젝트에서 이진 데이터는 파일, 네트워크 데이터 스트림 또는 사용자 입력과 같은 여러 채널에서 나올 수 있습니다. Bindec ()가 다른 입력 시나리오에서 안정적으로 작동하도록하려면 단위 테스트는 경계 조건 및 예외 입력을 포괄해야합니다.
다음 예제는 PhPunit으로 다중 이진 입력을 시뮬레이션하는 방법을 보여주고 Bindec () 출력이 예상대로 확인되는지 확인합니다.
<?php
use PHPUnit\Framework\TestCase;
class BindecTest extends TestCase
{
/**
* 다양한 테스트 사례를 제공합니다,정상 및 비정상 입력을 포함합니다
*/
public function binaryProvider()
{
return [
['0', 0],
['1', 1],
['1010', 10],
['11111111', 255],
['100000000', 256],
['invalid', 0], // 이진이 아닌 문자열 bindec 반품0
['', 0], // 空字符串반품0
];
}
/**
* @dataProvider binaryProvider
*/
public function testBindecConversion($binary, $expected)
{
$result = bindec($binary);
$this->assertSame($expected, $result, "Binary input: $binary");
}
}
BinaryProvider () 메소드는 여러 세트의 테스트 데이터 세트를 정의하여 일반 이진 번호, 빈 문자열 및 불법 문자열을 다룹니다.
@dataprovider 주석을 통해 테스트 데이터를 테스트 방법으로 전달하고 Bindec () 의 반환 값을 하나씩 확인하십시오.
불법 바이너리 문자열의 경우 Bindec ()가 내장 된 동작 인 0을 반환합니다.
프로젝트 디렉토리 구조 및 PhPunit 구성이 준비되었다고 가정하면 명령을 실행하십시오.
php vendor/bin/phpunit tests/BindecTest.php
모든 어설 션이 전달되면 Bindec ()가 여러 입력 하에서 정상적으로 수행 함을 의미합니다.
이 기사에서는 PHP 단위 테스트에서 이진 입력을 시뮬레이션하고 여러 문자열을 데이터 제공 업체를 통해 Bindec () 함수로 전달하는 방법에 대해 설명하며 출력 결과를 확인합니다. 이 방법은 Bindec () 에 적합 할뿐만 아니라 유사한 내장 또는 사용자 정의 기능에 대한 테두리 및 예외 입력 테스트에도 적합합니다.