Add more type info

pull/149/head
Pavel Djundik 5 years ago
parent b87c9faab9
commit 914ec4b79a

@ -25,24 +25,25 @@
*/ */
abstract class BaseSocket abstract class BaseSocket
{ {
/** @var resource */
public $Socket; public $Socket;
public $Engine; public int $Engine;
public $Address; public string $Address;
public $Port; public int $Port;
public $Timeout; public int $Timeout;
public function __destruct( ) public function __destruct( )
{ {
$this->Close( ); $this->Close( );
} }
abstract public function Close( ); abstract public function Close( ) : void;
abstract public function Open( $Address, $Port, $Timeout, $Engine ); abstract public function Open( string $Address, int $Port, int $Timeout, int $Engine ) : void;
abstract public function Write( $Header, $String = '' ); abstract public function Write( int $Header, string $String = '' ) : bool;
abstract public function Read( $Length = 1400 ); abstract public function Read( int $Length = 1400 ) : Buffer;
protected function ReadInternal( $Buffer, $Length, $SherlockFunction ) protected function ReadInternal( Buffer $Buffer, int $Length, callable $SherlockFunction ) : Buffer
{ {
if( $Buffer->Remaining( ) === 0 ) if( $Buffer->Remaining( ) === 0 )
{ {

@ -25,31 +25,23 @@
{ {
/** /**
* Buffer * Buffer
*
* @var string
*/ */
private $Buffer; private string $Buffer = '';
/** /**
* Buffer length * Buffer length
*
* @var int
*/ */
private $Length; private int $Length = 0;
/** /**
* Current position in buffer * Current position in buffer
*
* @var int
*/ */
private $Position; private int $Position = 0;
/** /**
* Sets buffer * Sets buffer
*
* @param string $Buffer Buffer
*/ */
public function Set( $Buffer ) public function Set( string $Buffer ) : void
{ {
$this->Buffer = $Buffer; $this->Buffer = $Buffer;
$this->Length = StrLen( $Buffer ); $this->Length = StrLen( $Buffer );
@ -61,7 +53,7 @@
* *
* @return int Remaining bytes in buffer * @return int Remaining bytes in buffer
*/ */
public function Remaining( ) public function Remaining( ) : int
{ {
return $this->Length - $this->Position; return $this->Length - $this->Position;
} }
@ -70,10 +62,8 @@
* Gets data from buffer * Gets data from buffer
* *
* @param int $Length Bytes to read * @param int $Length Bytes to read
*
* @return string
*/ */
public function Get( $Length = -1 ) public function Get( int $Length = -1 ) : string
{ {
if( $Length === 0 ) if( $Length === 0 )
{ {
@ -100,20 +90,16 @@
/** /**
* Get byte from buffer * Get byte from buffer
*
* @return int
*/ */
public function GetByte( ) public function GetByte( ) : int
{ {
return Ord( $this->Get( 1 ) ); return Ord( $this->Get( 1 ) );
} }
/** /**
* Get short from buffer * Get short from buffer
*
* @return int
*/ */
public function GetShort( ) public function GetShort( ) : int
{ {
if( $this->Remaining( ) < 2 ) if( $this->Remaining( ) < 2 )
{ {
@ -122,15 +108,13 @@
$Data = UnPack( 'v', $this->Get( 2 ) ); $Data = UnPack( 'v', $this->Get( 2 ) );
return $Data[ 1 ]; return (int)$Data[ 1 ];
} }
/** /**
* Get long from buffer * Get long from buffer
*
* @return int
*/ */
public function GetLong( ) public function GetLong( ) : int
{ {
if( $this->Remaining( ) < 4 ) if( $this->Remaining( ) < 4 )
{ {
@ -139,15 +123,13 @@
$Data = UnPack( 'l', $this->Get( 4 ) ); $Data = UnPack( 'l', $this->Get( 4 ) );
return $Data[ 1 ]; return (int)$Data[ 1 ];
} }
/** /**
* Get float from buffer * Get float from buffer
*
* @return float
*/ */
public function GetFloat( ) public function GetFloat( ) : float
{ {
if( $this->Remaining( ) < 4 ) if( $this->Remaining( ) < 4 )
{ {
@ -156,15 +138,13 @@
$Data = UnPack( 'f', $this->Get( 4 ) ); $Data = UnPack( 'f', $this->Get( 4 ) );
return $Data[ 1 ]; return (float)$Data[ 1 ];
} }
/** /**
* Get unsigned long from buffer * Get unsigned long from buffer
*
* @return int
*/ */
public function GetUnsignedLong( ) public function GetUnsignedLong( ) : int
{ {
if( $this->Remaining( ) < 4 ) if( $this->Remaining( ) < 4 )
{ {
@ -173,15 +153,13 @@
$Data = UnPack( 'V', $this->Get( 4 ) ); $Data = UnPack( 'V', $this->Get( 4 ) );
return $Data[ 1 ]; return (int)$Data[ 1 ];
} }
/** /**
* Read one string from buffer ending with null byte * Read one string from buffer ending with null byte
*
* @return string
*/ */
public function GetString( ) public function GetString( ) : string
{ {
$ZeroBytePosition = StrPos( $this->Buffer, "\0", $this->Position ); $ZeroBytePosition = StrPos( $this->Buffer, "\0", $this->Position );

@ -28,30 +28,30 @@
/** /**
* Points to socket class * Points to socket class
* *
* @var Socket * @var BaseSocket
*/ */
private $Socket; private $Socket;
private $RconPassword; private string $RconPassword = '';
private $RconChallenge; private string $RconChallenge = '';
public function __construct( $Socket ) public function __construct( BaseSocket $Socket )
{ {
$this->Socket = $Socket; $this->Socket = $Socket;
} }
public function Close( ) public function Close( ) : void
{ {
$this->RconChallenge = 0; $this->RconChallenge = '';
$this->RconPassword = 0; $this->RconPassword = '';
} }
public function Open( ) public function Open( ) : void
{ {
// //
} }
public function Write( $Header, $String = '' ) public function Write( int $Header, string $String = '' ) : bool
{ {
$Command = Pack( 'cccca*', 0xFF, 0xFF, 0xFF, 0xFF, $String ); $Command = Pack( 'cccca*', 0xFF, 0xFF, 0xFF, 0xFF, $String );
$Length = StrLen( $Command ); $Length = StrLen( $Command );
@ -64,7 +64,7 @@
* @throws AuthenticationException * @throws AuthenticationException
* @return Buffer * @return Buffer
*/ */
public function Read( $Length = 1400 ) public function Read( int $Length = 1400 ) : Buffer
{ {
// GoldSource RCON has same structure as Query // GoldSource RCON has same structure as Query
$Buffer = $this->Socket->Read( ); $Buffer = $this->Socket->Read( );
@ -115,7 +115,7 @@
return $Buffer; return $Buffer;
} }
public function Command( $Command ) public function Command( string $Command ) : string
{ {
if( !$this->RconChallenge ) if( !$this->RconChallenge )
{ {
@ -128,7 +128,7 @@
return $Buffer->Get( ); return $Buffer->Get( );
} }
public function Authorize( $Password ) public function Authorize( string $Password ) : void
{ {
$this->RconPassword = $Password; $this->RconPassword = $Password;

@ -25,9 +25,9 @@
*/ */
class Socket extends BaseSocket class Socket extends BaseSocket
{ {
public function Close( ) public function Close( ) : void
{ {
if( $this->Socket ) if( $this->Socket !== null )
{ {
FClose( $this->Socket ); FClose( $this->Socket );
@ -35,7 +35,7 @@
} }
} }
public function Open( $Address, $Port, $Timeout, $Engine ) public function Open( string $Address, int $Port, int $Timeout, int $Engine ) : void
{ {
$this->Timeout = $Timeout; $this->Timeout = $Timeout;
$this->Engine = $Engine; $this->Engine = $Engine;
@ -53,7 +53,7 @@
Stream_Set_Blocking( $this->Socket, true ); Stream_Set_Blocking( $this->Socket, true );
} }
public function Write( $Header, $String = '' ) public function Write( int $Header, string $String = '' ) : bool
{ {
$Command = Pack( 'ccccca*', 0xFF, 0xFF, 0xFF, 0xFF, $Header, $String ); $Command = Pack( 'ccccca*', 0xFF, 0xFF, 0xFF, 0xFF, $Header, $String );
$Length = StrLen( $Command ); $Length = StrLen( $Command );
@ -68,7 +68,7 @@
* *
* @return Buffer Buffer * @return Buffer Buffer
*/ */
public function Read( $Length = 1400 ) public function Read( int $Length = 1400 ) : Buffer
{ {
$Buffer = new Buffer( ); $Buffer = new Buffer( );
$Buffer->Set( FRead( $this->Socket, $Length ) ); $Buffer->Set( FRead( $this->Socket, $Length ) );
@ -78,7 +78,7 @@
return $Buffer; return $Buffer;
} }
public function Sherlock( $Buffer, $Length ) public function Sherlock( Buffer $Buffer, int $Length ) : bool
{ {
$Data = FRead( $this->Socket, $Length ); $Data = FRead( $this->Socket, $Length );

@ -76,31 +76,23 @@
/** /**
* Points to socket class * Points to socket class
*
* @var BaseSocket
*/ */
private $Socket; private BaseSocket $Socket;
/** /**
* True if connection is open, false if not * True if connection is open, false if not
*
* @var bool
*/ */
private $Connected; private bool $Connected = false;
/** /**
* Contains challenge * Contains challenge
*
* @var string
*/ */
private $Challenge; private string $Challenge = '';
/** /**
* Use old method for getting challenge number * Use old method for getting challenge number
*
* @var bool
*/ */
private $UseOldGetChallengeMethod; private bool $UseOldGetChallengeMethod = false;
public function __construct( BaseSocket $Socket = null ) public function __construct( BaseSocket $Socket = null )
{ {
@ -123,16 +115,16 @@
* @throws InvalidArgumentException * @throws InvalidArgumentException
* @throws SocketException * @throws SocketException
*/ */
public function Connect( $Address, $Port, $Timeout = 3, $Engine = self::SOURCE ) public function Connect( string $Address, int $Port, int $Timeout = 3, int $Engine = self::SOURCE ) : void
{ {
$this->Disconnect( ); $this->Disconnect( );
if( !is_int( $Timeout ) || $Timeout < 0 ) if( $Timeout < 0 )
{ {
throw new InvalidArgumentException( 'Timeout must be an integer.', InvalidArgumentException::TIMEOUT_NOT_INTEGER ); throw new InvalidArgumentException( 'Timeout must be a positive integer.', InvalidArgumentException::TIMEOUT_NOT_INTEGER );
} }
$this->Socket->Open( $Address, (int)$Port, $Timeout, (int)$Engine ); $this->Socket->Open( $Address, $Port, $Timeout, $Engine );
$this->Connected = true; $this->Connected = true;
} }
@ -144,7 +136,7 @@
* *
* @returns bool Previous value * @returns bool Previous value
*/ */
public function SetUseOldGetChallengeMethod( $Value ) public function SetUseOldGetChallengeMethod( bool $Value ) : bool
{ {
$Previous = $this->UseOldGetChallengeMethod; $Previous = $this->UseOldGetChallengeMethod;
@ -156,7 +148,7 @@
/** /**
* Closes all open connections * Closes all open connections
*/ */
public function Disconnect( ) public function Disconnect( ) : void
{ {
$this->Connected = false; $this->Connected = false;
$this->Challenge = ''; $this->Challenge = '';
@ -180,7 +172,7 @@
* *
* @return bool True on success, false on failure * @return bool True on success, false on failure
*/ */
public function Ping( ) public function Ping( ) : bool
{ {
if( !$this->Connected ) if( !$this->Connected )
{ {
@ -201,7 +193,7 @@
* *
* @return array Returns an array with information on success * @return array Returns an array with information on success
*/ */
public function GetInfo( ) public function GetInfo( ) : array
{ {
if( !$this->Connected ) if( !$this->Connected )
{ {
@ -246,16 +238,12 @@
$Mod[ 'Size' ] = $Buffer->GetLong( ); $Mod[ 'Size' ] = $Buffer->GetLong( );
$Mod[ 'ServerSide' ] = $Buffer->GetByte( ) === 1; $Mod[ 'ServerSide' ] = $Buffer->GetByte( ) === 1;
$Mod[ 'CustomDLL' ] = $Buffer->GetByte( ) === 1; $Mod[ 'CustomDLL' ] = $Buffer->GetByte( ) === 1;
$Server[ 'Mod' ] = $Mod;
} }
$Server[ 'Secure' ] = $Buffer->GetByte( ) === 1; $Server[ 'Secure' ] = $Buffer->GetByte( ) === 1;
$Server[ 'Bots' ] = $Buffer->GetByte( ); $Server[ 'Bots' ] = $Buffer->GetByte( );
if( isset( $Mod ) )
{
$Server[ 'Mod' ] = $Mod;
}
return $Server; return $Server;
} }
@ -368,7 +356,7 @@
* *
* @return array Returns an array with players on success * @return array Returns an array with players on success
*/ */
public function GetPlayers( ) public function GetPlayers( ) : array
{ {
if( !$this->Connected ) if( !$this->Connected )
{ {
@ -414,7 +402,7 @@
* *
* @return array Returns an array with rules on success * @return array Returns an array with rules on success
*/ */
public function GetRules( ) public function GetRules( ) : array
{ {
if( !$this->Connected ) if( !$this->Connected )
{ {
@ -453,12 +441,9 @@
/** /**
* Get challenge (used for players/rules packets) * Get challenge (used for players/rules packets)
* *
* @param $Header
* @param $ExpectedResult
*
* @throws InvalidPacketException * @throws InvalidPacketException
*/ */
private function GetChallenge( $Header, $ExpectedResult ) private function GetChallenge( int $Header, int $ExpectedResult ) : void
{ {
if( $this->Challenge ) if( $this->Challenge )
{ {
@ -509,7 +494,7 @@
* @throws InvalidPacketException * @throws InvalidPacketException
* @throws SocketException * @throws SocketException
*/ */
public function SetRconPassword( $Password ) public function SetRconPassword( string $Password ) : void
{ {
if( !$this->Connected ) if( !$this->Connected )
{ {
@ -551,7 +536,7 @@
* *
* @return string Answer from server in string * @return string Answer from server in string
*/ */
public function Rcon( $Command ) public function Rcon( string $Command ) : string
{ {
if( !$this->Connected ) if( !$this->Connected )
{ {

@ -29,20 +29,19 @@
{ {
/** /**
* Points to socket class * Points to socket class
*
* @var Socket
*/ */
private $Socket; private BaseSocket $Socket;
/** @var resource */
private $RconSocket; private $RconSocket;
private $RconRequestId; private int $RconRequestId = 0;
public function __construct( $Socket ) public function __construct( BaseSocket $Socket )
{ {
$this->Socket = $Socket; $this->Socket = $Socket;
} }
public function Close( ) public function Close( ) : void
{ {
if( $this->RconSocket ) if( $this->RconSocket )
{ {
@ -54,7 +53,7 @@
$this->RconRequestId = 0; $this->RconRequestId = 0;
} }
public function Open( ) public function Open( ) : void
{ {
if( !$this->RconSocket ) if( !$this->RconSocket )
{ {
@ -70,7 +69,7 @@
} }
} }
public function Write( $Header, $String = '' ) public function Write( int $Header, string $String = '' ) : bool
{ {
// Pack the packet together // Pack the packet together
$Command = Pack( 'VV', ++$this->RconRequestId, $Header ) . $String . "\x00\x00"; $Command = Pack( 'VV', ++$this->RconRequestId, $Header ) . $String . "\x00\x00";
@ -82,7 +81,7 @@
return $Length === FWrite( $this->RconSocket, $Command, $Length ); return $Length === FWrite( $this->RconSocket, $Command, $Length );
} }
public function Read( ) public function Read( ) : Buffer
{ {
$Buffer = new Buffer( ); $Buffer = new Buffer( );
$Buffer->Set( FRead( $this->RconSocket, 4 ) ); $Buffer->Set( FRead( $this->RconSocket, 4 ) );
@ -122,7 +121,7 @@
return $Buffer; return $Buffer;
} }
public function Command( $Command ) public function Command( string $Command ) : string
{ {
$this->Write( SourceQuery::SERVERDATA_EXECCOMMAND, $Command ); $this->Write( SourceQuery::SERVERDATA_EXECCOMMAND, $Command );
$Buffer = $this->Read( ); $Buffer = $this->Read( );
@ -174,7 +173,7 @@
return rtrim( $Data, "\0" ); return rtrim( $Data, "\0" );
} }
public function Authorize( $Password ) public function Authorize( string $Password ) : void
{ {
$this->Write( SourceQuery::SERVERDATA_AUTH, $Password ); $this->Write( SourceQuery::SERVERDATA_AUTH, $Password );
$Buffer = $this->Read( ); $Buffer = $this->Read( );

@ -1,13 +1,12 @@
<?php <?php
use PHPUnit\Framework\TestCase; use PHPUnit\Framework\TestCase;
use xPaw\SourceQuery\BaseSocket; use xPaw\SourceQuery\BaseSocket;
use xPaw\SourceQuery\Exception\InvalidPacketException;
use xPaw\SourceQuery\SourceQuery; use xPaw\SourceQuery\SourceQuery;
use xPaw\SourceQuery\Buffer; use xPaw\SourceQuery\Buffer;
class TestableSocket extends BaseSocket class TestableSocket extends BaseSocket
{ {
private $PacketQueue; private \SplQueue $PacketQueue;
public function __construct( ) public function __construct( )
{ {
@ -16,17 +15,17 @@
} }
public function Queue( $Data ) public function Queue( string $Data ) : void
{ {
$this->PacketQueue->push( $Data ); $this->PacketQueue->push( $Data );
} }
public function Close( ) public function Close( ) : void
{ {
// //
} }
public function Open( $Address, $Port, $Timeout, $Engine ) public function Open( string $Address, int $Port, int $Timeout, int $Engine ) : void
{ {
$this->Timeout = $Timeout; $this->Timeout = $Timeout;
$this->Engine = $Engine; $this->Engine = $Engine;
@ -34,29 +33,29 @@
$this->Address = $Address; $this->Address = $Address;
} }
public function Write( $Header, $String = '' ) public function Write( int $Header, string $String = '' ) : bool
{ {
// return true;
} }
public function Read( $Length = 1400 ) public function Read( int $Length = 1400 ) : Buffer
{ {
$Buffer = new Buffer( ); $Buffer = new Buffer( );
$Buffer->Set( $this->PacketQueue->shift() ); $Buffer->Set( (string)$this->PacketQueue->shift() );
$this->ReadInternal( $Buffer, $Length, [ $this, 'Sherlock' ] ); $this->ReadInternal( $Buffer, $Length, [ $this, 'Sherlock' ] );
return $Buffer; return $Buffer;
} }
public function Sherlock( $Buffer, $Length ) public function Sherlock( Buffer $Buffer, int $Length ) : bool
{ {
if( $this->PacketQueue->isEmpty() ) if( $this->PacketQueue->isEmpty() )
{ {
return false; return false;
} }
$Buffer->Set( $this->PacketQueue->shift() ); $Buffer->Set( (string)$this->PacketQueue->shift() );
return $Buffer->GetLong( ) === -2; return $Buffer->GetLong( ) === -2;
} }
@ -64,17 +63,17 @@
class SourceQueryTests extends TestCase class SourceQueryTests extends TestCase
{ {
private $Socket; private TestableSocket $Socket;
private $SourceQuery; private SourceQuery $SourceQuery;
public function setUp() public function setUp() : void
{ {
$this->Socket = new TestableSocket(); $this->Socket = new TestableSocket();
$this->SourceQuery = new SourceQuery( $this->Socket ); $this->SourceQuery = new SourceQuery( $this->Socket );
$this->SourceQuery->Connect( '', 2 ); $this->SourceQuery->Connect( '', 2 );
} }
public function tearDown() public function tearDown() : void
{ {
$this->SourceQuery->Disconnect(); $this->SourceQuery->Disconnect();
@ -84,7 +83,7 @@
/** /**
* @expectedException xPaw\SourceQuery\Exception\InvalidArgumentException * @expectedException xPaw\SourceQuery\Exception\InvalidArgumentException
*/ */
public function testInvalidTimeout() public function testInvalidTimeout() : void
{ {
$SourceQuery = new SourceQuery( ); $SourceQuery = new SourceQuery( );
$SourceQuery->Connect( '', 2, -1 ); $SourceQuery->Connect( '', 2, -1 );
@ -93,7 +92,7 @@
/** /**
* @expectedException xPaw\SourceQuery\Exception\SocketException * @expectedException xPaw\SourceQuery\Exception\SocketException
*/ */
public function testNotConnectedGetInfo() public function testNotConnectedGetInfo() : void
{ {
$this->SourceQuery->Disconnect(); $this->SourceQuery->Disconnect();
$this->SourceQuery->GetInfo(); $this->SourceQuery->GetInfo();
@ -102,7 +101,7 @@
/** /**
* @expectedException xPaw\SourceQuery\Exception\SocketException * @expectedException xPaw\SourceQuery\Exception\SocketException
*/ */
public function testNotConnectedPing() public function testNotConnectedPing() : void
{ {
$this->SourceQuery->Disconnect(); $this->SourceQuery->Disconnect();
$this->SourceQuery->Ping(); $this->SourceQuery->Ping();
@ -111,7 +110,7 @@
/** /**
* @expectedException xPaw\SourceQuery\Exception\SocketException * @expectedException xPaw\SourceQuery\Exception\SocketException
*/ */
public function testNotConnectedGetPlayers() public function testNotConnectedGetPlayers() : void
{ {
$this->SourceQuery->Disconnect(); $this->SourceQuery->Disconnect();
$this->SourceQuery->GetPlayers(); $this->SourceQuery->GetPlayers();
@ -120,7 +119,7 @@
/** /**
* @expectedException xPaw\SourceQuery\Exception\SocketException * @expectedException xPaw\SourceQuery\Exception\SocketException
*/ */
public function testNotConnectedGetRules() public function testNotConnectedGetRules() : void
{ {
$this->SourceQuery->Disconnect(); $this->SourceQuery->Disconnect();
$this->SourceQuery->GetRules(); $this->SourceQuery->GetRules();
@ -129,7 +128,7 @@
/** /**
* @expectedException xPaw\SourceQuery\Exception\SocketException * @expectedException xPaw\SourceQuery\Exception\SocketException
*/ */
public function testNotConnectedSetRconPassword() public function testNotConnectedSetRconPassword() : void
{ {
$this->SourceQuery->Disconnect(); $this->SourceQuery->Disconnect();
$this->SourceQuery->SetRconPassword('a'); $this->SourceQuery->SetRconPassword('a');
@ -138,7 +137,7 @@
/** /**
* @expectedException xPaw\SourceQuery\Exception\SocketException * @expectedException xPaw\SourceQuery\Exception\SocketException
*/ */
public function testNotConnectedRcon() public function testNotConnectedRcon() : void
{ {
$this->SourceQuery->Disconnect(); $this->SourceQuery->Disconnect();
$this->SourceQuery->Rcon('a'); $this->SourceQuery->Rcon('a');
@ -147,7 +146,7 @@
/** /**
* @expectedException xPaw\SourceQuery\Exception\SocketException * @expectedException xPaw\SourceQuery\Exception\SocketException
*/ */
public function testRconWithoutPassword() public function testRconWithoutPassword() : void
{ {
$this->SourceQuery->Rcon('a'); $this->SourceQuery->Rcon('a');
} }
@ -155,7 +154,7 @@
/** /**
* @dataProvider InfoProvider * @dataProvider InfoProvider
*/ */
public function testGetInfo( $RawInput, $ExpectedOutput ) public function testGetInfo( string $RawInput, array $ExpectedOutput ) : void
{ {
if( isset( $ExpectedOutput[ 'IsMod' ] ) ) if( isset( $ExpectedOutput[ 'IsMod' ] ) )
{ {
@ -169,7 +168,7 @@
$this->assertEquals( $ExpectedOutput, $RealOutput ); $this->assertEquals( $ExpectedOutput, $RealOutput );
} }
public function InfoProvider() public function InfoProvider() : array
{ {
$DataProvider = []; $DataProvider = [];
@ -191,7 +190,7 @@
* @expectedException xPaw\SourceQuery\Exception\InvalidPacketException * @expectedException xPaw\SourceQuery\Exception\InvalidPacketException
* @dataProvider BadPacketProvider * @dataProvider BadPacketProvider
*/ */
public function testBadGetInfo( $Data ) public function testBadGetInfo( string $Data ) : void
{ {
$this->Socket->Queue( $Data ); $this->Socket->Queue( $Data );
@ -202,7 +201,7 @@
* @expectedException xPaw\SourceQuery\Exception\InvalidPacketException * @expectedException xPaw\SourceQuery\Exception\InvalidPacketException
* @dataProvider BadPacketProvider * @dataProvider BadPacketProvider
*/ */
public function testBadGetChallengeViaPlayers( $Data ) public function testBadGetChallengeViaPlayers( string $Data ) : void
{ {
$this->Socket->Queue( $Data ); $this->Socket->Queue( $Data );
@ -213,7 +212,7 @@
* @expectedException xPaw\SourceQuery\Exception\InvalidPacketException * @expectedException xPaw\SourceQuery\Exception\InvalidPacketException
* @dataProvider BadPacketProvider * @dataProvider BadPacketProvider
*/ */
public function testBadGetPlayersAfterCorrectChallenge( $Data ) public function testBadGetPlayersAfterCorrectChallenge( string $Data ) : void
{ {
$this->Socket->Queue( "\xFF\xFF\xFF\xFF\x41\x11\x11\x11\x11" ); $this->Socket->Queue( "\xFF\xFF\xFF\xFF\x41\x11\x11\x11\x11" );
$this->Socket->Queue( $Data ); $this->Socket->Queue( $Data );
@ -225,7 +224,7 @@
* @expectedException xPaw\SourceQuery\Exception\InvalidPacketException * @expectedException xPaw\SourceQuery\Exception\InvalidPacketException
* @dataProvider BadPacketProvider * @dataProvider BadPacketProvider
*/ */
public function testBadGetRulesAfterCorrectChallenge( $Data ) public function testBadGetRulesAfterCorrectChallenge( string $Data ) : void
{ {
$this->Socket->Queue( "\xFF\xFF\xFF\xFF\x41\x11\x11\x11\x11" ); $this->Socket->Queue( "\xFF\xFF\xFF\xFF\x41\x11\x11\x11\x11" );
$this->Socket->Queue( $Data ); $this->Socket->Queue( $Data );
@ -233,7 +232,7 @@
$this->SourceQuery->GetRules(); $this->SourceQuery->GetRules();
} }
public function BadPacketProvider( ) public function BadPacketProvider( ) : array
{ {
return return
[ [
@ -247,7 +246,7 @@
]; ];
} }
public function testGetChallengeTwice( ) public function testGetChallengeTwice( ) : void
{ {
$this->Socket->Queue( "\xFF\xFF\xFF\xFF\x41\x11\x11\x11\x11" ); $this->Socket->Queue( "\xFF\xFF\xFF\xFF\x41\x11\x11\x11\x11" );
$this->Socket->Queue( "\xFF\xFF\xFF\xFF\x45\x01\x00ayy\x00lmao\x00" ); $this->Socket->Queue( "\xFF\xFF\xFF\xFF\x45\x01\x00ayy\x00lmao\x00" );
@ -260,7 +259,7 @@
/** /**
* @dataProvider RulesProvider * @dataProvider RulesProvider
*/ */
public function testGetRules( $RawInput, $ExpectedOutput ) public function testGetRules( array $RawInput, array $ExpectedOutput ) : void
{ {
$this->Socket->Queue( hex2bin( "ffffffff4104fce20e" ) ); // Challenge $this->Socket->Queue( hex2bin( "ffffffff4104fce20e" ) ); // Challenge
@ -274,7 +273,7 @@
$this->assertEquals( $ExpectedOutput, $RealOutput ); $this->assertEquals( $ExpectedOutput, $RealOutput );
} }
public function RulesProvider() public function RulesProvider() : array
{ {
$DataProvider = []; $DataProvider = [];
@ -295,7 +294,7 @@
/** /**
* @dataProvider PlayersProvider * @dataProvider PlayersProvider
*/ */
public function testGetPlayers( $RawInput, $ExpectedOutput ) public function testGetPlayers( array $RawInput, array $ExpectedOutput ) : void
{ {
$this->Socket->Queue( hex2bin( "ffffffff4104fce20e" ) ); // Challenge $this->Socket->Queue( hex2bin( "ffffffff4104fce20e" ) ); // Challenge
@ -309,7 +308,7 @@
$this->assertEquals( $ExpectedOutput, $RealOutput ); $this->assertEquals( $ExpectedOutput, $RealOutput );
} }
public function PlayersProvider() public function PlayersProvider() : array
{ {
$DataProvider = []; $DataProvider = [];
@ -327,7 +326,7 @@
return $DataProvider; return $DataProvider;
} }
public function testPing() public function testPing() : void
{ {
$this->Socket->Queue( "\xFF\xFF\xFF\xFF\x6A\x00"); $this->Socket->Queue( "\xFF\xFF\xFF\xFF\x6A\x00");
$this->assertTrue( $this->SourceQuery->Ping() ); $this->assertTrue( $this->SourceQuery->Ping() );

Loading…
Cancel
Save