Compare commits
7 Commits
Author | SHA1 | Date |
---|---|---|
Daniel Seifert | d0db444157 | |
Daniel Seifert | 096ef7ed05 | |
Daniel Seifert | dc0b680776 | |
Daniel Seifert | 05ff18d537 | |
Daniel Seifert | 05132f82ee | |
Daniel Seifert | f5579d9d5e | |
Daniel Seifert | 4e5147a0ac |
32
CHANGELOG.md
32
CHANGELOG.md
|
@ -2,6 +2,38 @@
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
|
## 1.3.0.0 (2022-07-18)
|
||||||
|
|
||||||
|
- tests use generated example phone numbers
|
||||||
|
- move recipient checks from list to recipient itself
|
||||||
|
- tests added
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 1.2.1.0 (2022-07-15)
|
||||||
|
|
||||||
|
- extend log messages
|
||||||
|
- sanitize special phone number format before request
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 1.2.0.0 (2022-07-14)
|
||||||
|
|
||||||
|
- make sender number optional
|
||||||
|
- assign sender address type only if sender is set
|
||||||
|
- collect exception messages in a class
|
||||||
|
- collect URI parts in a class
|
||||||
|
- extract logger handler from client
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 1.1.0.0 (2022-07-13)
|
||||||
|
|
||||||
|
- make installable in PHP 8
|
||||||
|
- remove unused dependency
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
## 1.0.0.0 (2022-07-13)
|
## 1.0.0.0 (2022-07-13)
|
||||||
|
|
||||||
- initial implementation
|
- initial implementation
|
||||||
|
|
|
@ -21,8 +21,10 @@ use Psr\Log\AbstractLogger;
|
||||||
use Psr\Log\LoggerInterface;
|
use Psr\Log\LoggerInterface;
|
||||||
use ReflectionException;
|
use ReflectionException;
|
||||||
|
|
||||||
class LoggerHandlerTest extends ApiTestCase
|
class ALoggerHandlerTest extends ApiTestCase
|
||||||
{
|
{
|
||||||
|
/** tests must run as first, because of singleton, which must not initialized before */
|
||||||
|
|
||||||
/** @var LoggerHandler */
|
/** @var LoggerHandler */
|
||||||
public $loggerHandler;
|
public $loggerHandler;
|
||||||
|
|
||||||
|
@ -46,9 +48,30 @@ class LoggerHandlerTest extends ApiTestCase
|
||||||
unset($this->loggerHandler);
|
unset($this->loggerHandler);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @return void
|
||||||
|
* @covers \D3\LinkmobilityClient\LoggerHandler::getInstance
|
||||||
|
*/
|
||||||
|
public function testGetInstance()
|
||||||
|
{
|
||||||
|
// not existing instance
|
||||||
|
$this->assertInstanceOf(
|
||||||
|
LoggerHandler::class,
|
||||||
|
LoggerHandler::getInstance()
|
||||||
|
);
|
||||||
|
|
||||||
|
// existing instance
|
||||||
|
$this->assertInstanceOf(
|
||||||
|
LoggerHandler::class,
|
||||||
|
LoggerHandler::getInstance()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\LoggerHandler::__construct
|
||||||
*/
|
*/
|
||||||
public function testConstruct()
|
public function testConstruct()
|
||||||
{
|
{
|
||||||
|
@ -62,6 +85,8 @@ class LoggerHandlerTest extends ApiTestCase
|
||||||
* @test
|
* @test
|
||||||
* @return void
|
* @return void
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\LoggerHandler::setLogger
|
||||||
|
* @covers \D3\LinkmobilityClient\LoggerHandler::getLogger
|
||||||
*/
|
*/
|
||||||
public function testLogger()
|
public function testLogger()
|
||||||
{
|
{
|
|
@ -68,6 +68,7 @@ class ClientTest extends ApiTestCase
|
||||||
* @param $apiClient
|
* @param $apiClient
|
||||||
* @return void
|
* @return void
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\Client::__construct
|
||||||
*/
|
*/
|
||||||
public function testConstruct($apiKey, $apiUrl, $apiClient)
|
public function testConstruct($apiKey, $apiUrl, $apiClient)
|
||||||
{
|
{
|
||||||
|
@ -104,6 +105,7 @@ class ClientTest extends ApiTestCase
|
||||||
* @return void
|
* @return void
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
* @dataProvider requestPassedDataProvider
|
* @dataProvider requestPassedDataProvider
|
||||||
|
* @covers \D3\LinkmobilityClient\Client::request
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public function testRequest($requestIsValid)
|
public function testRequest($requestIsValid)
|
||||||
|
@ -175,6 +177,7 @@ class ClientTest extends ApiTestCase
|
||||||
* @return void
|
* @return void
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
* @dataProvider rawRequestDataProvider
|
* @dataProvider rawRequestDataProvider
|
||||||
|
* @covers \D3\LinkmobilityClient\Client::rawRequest
|
||||||
*/
|
*/
|
||||||
public function testRawRequest($okStatus)
|
public function testRawRequest($okStatus)
|
||||||
{
|
{
|
||||||
|
@ -255,4 +258,21 @@ class ClientTest extends ApiTestCase
|
||||||
'NOK status' => [false],
|
'NOK status' => [false],
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @return void
|
||||||
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\Client::getLoggerHandler
|
||||||
|
*/
|
||||||
|
public function testGetLoggerHandler()
|
||||||
|
{
|
||||||
|
$this->assertInstanceOf(
|
||||||
|
LoggerHandler::class,
|
||||||
|
$this->callMethod(
|
||||||
|
$this->api,
|
||||||
|
'getLoggerHandler'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,17 +16,13 @@ declare(strict_types=1);
|
||||||
namespace D3\LinkmobilityClient\Tests\RecipientsList;
|
namespace D3\LinkmobilityClient\Tests\RecipientsList;
|
||||||
|
|
||||||
use D3\LinkmobilityClient\Client;
|
use D3\LinkmobilityClient\Client;
|
||||||
use D3\LinkmobilityClient\LoggerHandler;
|
|
||||||
use D3\LinkmobilityClient\RecipientsList\RecipientsList;
|
use D3\LinkmobilityClient\RecipientsList\RecipientsList;
|
||||||
use D3\LinkmobilityClient\Tests\ApiTestCase;
|
use D3\LinkmobilityClient\Tests\ApiTestCase;
|
||||||
use D3\LinkmobilityClient\ValueObject\Recipient;
|
use D3\LinkmobilityClient\ValueObject\Recipient;
|
||||||
use libphonenumber\NumberParseException;
|
use libphonenumber\PhoneNumberFormat;
|
||||||
use libphonenumber\PhoneNumber;
|
|
||||||
use libphonenumber\PhoneNumberType;
|
use libphonenumber\PhoneNumberType;
|
||||||
use libphonenumber\PhoneNumberUtil;
|
use libphonenumber\PhoneNumberUtil;
|
||||||
use PHPUnit\Framework\MockObject\MockObject;
|
use PHPUnit\Framework\MockObject\MockObject;
|
||||||
use Psr\Log\AbstractLogger;
|
|
||||||
use Psr\Log\LoggerInterface;
|
|
||||||
use ReflectionException;
|
use ReflectionException;
|
||||||
use stdClass;
|
use stdClass;
|
||||||
|
|
||||||
|
@ -35,7 +31,7 @@ class RecipientsListTest extends ApiTestCase
|
||||||
/** @var RecipientsList */
|
/** @var RecipientsList */
|
||||||
public $recipientsList;
|
public $recipientsList;
|
||||||
|
|
||||||
private $phoneNumberFixture = '01527565839';
|
private $phoneNumberFixture;
|
||||||
private $phoneCountryFixture = 'DE';
|
private $phoneCountryFixture = 'DE';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -51,6 +47,10 @@ class RecipientsListTest extends ApiTestCase
|
||||||
->getMock();
|
->getMock();
|
||||||
|
|
||||||
$this->recipientsList = new RecipientsList($clientMock);
|
$this->recipientsList = new RecipientsList($clientMock);
|
||||||
|
|
||||||
|
$phoneUtil = PhoneNumberUtil::getInstance();
|
||||||
|
$example = $phoneUtil->getExampleNumberForType($this->phoneCountryFixture, PhoneNumberType::MOBILE);
|
||||||
|
$this->phoneNumberFixture = $phoneUtil->format($example, PhoneNumberFormat::NATIONAL);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -66,6 +66,7 @@ class RecipientsListTest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @return void
|
* @return void
|
||||||
|
* @covers \D3\LinkmobilityClient\RecipientsList\RecipientsList::__construct
|
||||||
*/
|
*/
|
||||||
public function testConstruct()
|
public function testConstruct()
|
||||||
{
|
{
|
||||||
|
@ -85,33 +86,10 @@ class RecipientsListTest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
*/
|
* @covers \D3\LinkmobilityClient\RecipientsList\RecipientsList::add
|
||||||
public function testGetPhoneNumberUtil()
|
|
||||||
{
|
|
||||||
$this->assertInstanceOf(
|
|
||||||
PhoneNumberUtil::class,
|
|
||||||
$this->callMethod(
|
|
||||||
$this->recipientsList,
|
|
||||||
'getPhoneNumberUtil'
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @test
|
|
||||||
* @throws ReflectionException
|
|
||||||
*/
|
*/
|
||||||
public function testAddValidNumber()
|
public function testAddValidNumber()
|
||||||
{
|
{
|
||||||
/** @var PhoneNumberUtil|MockObject $phoneNumberUtilMock */
|
|
||||||
$phoneNumberUtilMock = $this->getMockBuilder(PhoneNumberUtil::class)
|
|
||||||
->onlyMethods(['parse', 'isValidNumber', 'getNumberType'])
|
|
||||||
->disableOriginalConstructor()
|
|
||||||
->getMock();
|
|
||||||
$phoneNumberUtilMock->method('parse')->willReturn(new PhoneNumber());
|
|
||||||
$phoneNumberUtilMock->method('isValidNumber')->willReturn(true);
|
|
||||||
$phoneNumberUtilMock->method('getNumberType')->willReturn(PhoneNumberType::MOBILE);
|
|
||||||
|
|
||||||
/** @var Recipient|MockObject $recipientMock */
|
/** @var Recipient|MockObject $recipientMock */
|
||||||
$recipientMock = $this->getMockBuilder(Recipient::class)
|
$recipientMock = $this->getMockBuilder(Recipient::class)
|
||||||
->onlyMethods(['get', 'getCountryCode'])
|
->onlyMethods(['get', 'getCountryCode'])
|
||||||
|
@ -120,15 +98,6 @@ class RecipientsListTest extends ApiTestCase
|
||||||
$recipientMock->method('get')->willReturn($this->phoneNumberFixture);
|
$recipientMock->method('get')->willReturn($this->phoneNumberFixture);
|
||||||
$recipientMock->method('getCountryCode')->willReturn($this->phoneCountryFixture);
|
$recipientMock->method('getCountryCode')->willReturn($this->phoneCountryFixture);
|
||||||
|
|
||||||
/** @var RecipientsList|MockObject $recListMock */
|
|
||||||
$recListMock = $this->getMockBuilder(RecipientsList::class)
|
|
||||||
->onlyMethods(['getPhoneNumberUtil'])
|
|
||||||
->setConstructorArgs([$this->recipientsList->getClient()])
|
|
||||||
->getMock();
|
|
||||||
$recListMock->method('getPhoneNumberUtil')->willReturn($phoneNumberUtilMock);
|
|
||||||
|
|
||||||
$this->recipientsList = $recListMock;
|
|
||||||
|
|
||||||
$this->assertCount(
|
$this->assertCount(
|
||||||
0,
|
0,
|
||||||
$this->callMethod($this->recipientsList, 'getRecipientsList')
|
$this->callMethod($this->recipientsList, 'getRecipientsList')
|
||||||
|
@ -152,95 +121,8 @@ class RecipientsListTest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
* @dataProvider addInvalidNumberDataProvider
|
* @covers \D3\LinkmobilityClient\RecipientsList\RecipientsList::clearRecipents
|
||||||
*/
|
* @covers \D3\LinkmobilityClient\RecipientsList\RecipientsList::getRecipientsList
|
||||||
public function testAddInvalidNumber($unparsable, $invalidNumber, $invalidNumberType)
|
|
||||||
{
|
|
||||||
/** @var PhoneNumberUtil|MockObject $phoneNumberUtilMock */
|
|
||||||
$phoneNumberUtilMock = $this->getMockBuilder(PhoneNumberUtil::class)
|
|
||||||
->onlyMethods(['parse', 'isValidNumber', 'getNumberType'])
|
|
||||||
->disableOriginalConstructor()
|
|
||||||
->getMock();
|
|
||||||
|
|
||||||
if ($unparsable) {
|
|
||||||
$phoneNumberUtilMock->method('parse')->willThrowException(new NumberParseException(0, 'message'));
|
|
||||||
} else {
|
|
||||||
$phoneNumberUtilMock->method('parse')->willReturn(new PhoneNumber());
|
|
||||||
}
|
|
||||||
$phoneNumberUtilMock->method('isValidNumber')->willReturn(!$invalidNumber);
|
|
||||||
$phoneNumberUtilMock->method('getNumberType')->willReturn($invalidNumberType ? PhoneNumberType::FIXED_LINE : PhoneNumberType::MOBILE);
|
|
||||||
|
|
||||||
/** @var Recipient|MockObject $recipientMock */
|
|
||||||
$recipientMock = $this->getMockBuilder(Recipient::class)
|
|
||||||
->onlyMethods(['get', 'getCountryCode'])
|
|
||||||
->setConstructorArgs([$this->phoneNumberFixture, $this->phoneCountryFixture])
|
|
||||||
->getMock();
|
|
||||||
$recipientMock->method('get')->willReturn($this->phoneNumberFixture);
|
|
||||||
$recipientMock->method('getCountryCode')->willReturn($this->phoneCountryFixture);
|
|
||||||
|
|
||||||
/** @var LoggerInterface|MockObject $loggerMock */
|
|
||||||
$loggerMock = $this->getMockBuilder(AbstractLogger::class)
|
|
||||||
->onlyMethods(['info', 'log'])
|
|
||||||
->getMock();
|
|
||||||
$loggerMock->expects($this->atLeastOnce())->method('info')->willReturn(true);
|
|
||||||
|
|
||||||
/** @var LoggerHandler|MockObject $loggerHandlerMock */
|
|
||||||
$loggerHandlerMock = $this->getMockBuilder(LoggerHandler::class)
|
|
||||||
->onlyMethods(['getLogger'])
|
|
||||||
->getMock();
|
|
||||||
$loggerHandlerMock->method('getLogger')->willReturn($loggerMock);
|
|
||||||
|
|
||||||
/** @var Client|MockObject $clientMock */
|
|
||||||
$clientMock = $this->getMockBuilder(Client::class)
|
|
||||||
->disableOriginalConstructor()
|
|
||||||
->onlyMethods(['getLoggerHandler'])
|
|
||||||
->getMock();
|
|
||||||
$clientMock->method('getLoggerHandler')->willReturn($loggerHandlerMock);
|
|
||||||
|
|
||||||
/** @var RecipientsList|MockObject $recListMock */
|
|
||||||
$recListMock = $this->getMockBuilder(RecipientsList::class)
|
|
||||||
->onlyMethods(['getPhoneNumberUtil'])
|
|
||||||
->setConstructorArgs([$clientMock])
|
|
||||||
->getMock();
|
|
||||||
$recListMock->method('getPhoneNumberUtil')->willReturn($phoneNumberUtilMock);
|
|
||||||
|
|
||||||
$this->recipientsList = $recListMock;
|
|
||||||
|
|
||||||
$this->assertCount(
|
|
||||||
0,
|
|
||||||
$this->callMethod($this->recipientsList, 'getRecipientsList')
|
|
||||||
);
|
|
||||||
|
|
||||||
$this->assertSame(
|
|
||||||
$this->recipientsList,
|
|
||||||
$this->callMethod(
|
|
||||||
$this->recipientsList,
|
|
||||||
'add',
|
|
||||||
[$recipientMock]
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
$this->assertCount(
|
|
||||||
0,
|
|
||||||
$this->callMethod($this->recipientsList, 'getRecipientsList')
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return array[]
|
|
||||||
*/
|
|
||||||
public function addInvalidNumberDataProvider(): array
|
|
||||||
{
|
|
||||||
return [
|
|
||||||
'unparsable' => [true, false, false],
|
|
||||||
'invalid number' => [false, true, false],
|
|
||||||
'invalid number type' => [false, false, true],
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @test
|
|
||||||
* @throws ReflectionException
|
|
||||||
*/
|
*/
|
||||||
public function testClearRecipents()
|
public function testClearRecipents()
|
||||||
{
|
{
|
||||||
|
@ -268,6 +150,7 @@ class RecipientsListTest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\RecipientsList\RecipientsList::getRecipients
|
||||||
*/
|
*/
|
||||||
public function testGetRecipients()
|
public function testGetRecipients()
|
||||||
{
|
{
|
||||||
|
@ -296,6 +179,7 @@ class RecipientsListTest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\RecipientsList\RecipientsList::getRecipientsList
|
||||||
*/
|
*/
|
||||||
public function testGetRecipientsList()
|
public function testGetRecipientsList()
|
||||||
{
|
{
|
||||||
|
@ -327,6 +211,10 @@ class RecipientsListTest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\RecipientsList\RecipientsList::current
|
||||||
|
* @covers \D3\LinkmobilityClient\RecipientsList\RecipientsList::next
|
||||||
|
* @covers \D3\LinkmobilityClient\RecipientsList\RecipientsList::key
|
||||||
|
* @covers \D3\LinkmobilityClient\RecipientsList\RecipientsList::rewind
|
||||||
*/
|
*/
|
||||||
public function testCurrentNextKeyRewind()
|
public function testCurrentNextKeyRewind()
|
||||||
{
|
{
|
||||||
|
@ -375,6 +263,7 @@ class RecipientsListTest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\RecipientsList\RecipientsList::valid
|
||||||
*/
|
*/
|
||||||
public function testValid()
|
public function testValid()
|
||||||
{
|
{
|
||||||
|
@ -406,13 +295,15 @@ class RecipientsListTest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\RecipientsList\RecipientsList::setClient
|
||||||
|
* @covers \D3\LinkmobilityClient\RecipientsList\RecipientsList::getClient
|
||||||
*/
|
*/
|
||||||
public function testSetGetClient()
|
public function testSetGetClient()
|
||||||
{
|
{
|
||||||
/** @var Client|MockObject $clientMock */
|
/** @var Client|MockObject $clientMock */
|
||||||
$clientMock = $this->getMockBuilder(Client::class)
|
$clientMock = $this->getMockBuilder(Client::class)
|
||||||
->disableOriginalConstructor()
|
->disableOriginalConstructor()
|
||||||
->getMock();
|
->getMock();
|
||||||
|
|
||||||
$this->assertInstanceOf(
|
$this->assertInstanceOf(
|
||||||
RecipientsList::class,
|
RecipientsList::class,
|
||||||
|
|
|
@ -24,6 +24,9 @@ use D3\LinkmobilityClient\SMS\Response;
|
||||||
use D3\LinkmobilityClient\Tests\ApiTestCase;
|
use D3\LinkmobilityClient\Tests\ApiTestCase;
|
||||||
use D3\LinkmobilityClient\ValueObject\Recipient;
|
use D3\LinkmobilityClient\ValueObject\Recipient;
|
||||||
use D3\LinkmobilityClient\ValueObject\Sender;
|
use D3\LinkmobilityClient\ValueObject\Sender;
|
||||||
|
use libphonenumber\PhoneNumberFormat;
|
||||||
|
use libphonenumber\PhoneNumberType;
|
||||||
|
use libphonenumber\PhoneNumberUtil;
|
||||||
use PHPUnit\Framework\MockObject\MockObject;
|
use PHPUnit\Framework\MockObject\MockObject;
|
||||||
use Psr\Http\Message\ResponseInterface;
|
use Psr\Http\Message\ResponseInterface;
|
||||||
use Psr\Http\Message\StreamInterface;
|
use Psr\Http\Message\StreamInterface;
|
||||||
|
@ -62,6 +65,8 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
* @test
|
* @test
|
||||||
* @return void
|
* @return void
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::__construct
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::__construct
|
||||||
*/
|
*/
|
||||||
public function testConstruct()
|
public function testConstruct()
|
||||||
{
|
{
|
||||||
|
@ -95,6 +100,8 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getUri
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getUri
|
||||||
*/
|
*/
|
||||||
public function testGetUri()
|
public function testGetUri()
|
||||||
{
|
{
|
||||||
|
@ -109,10 +116,17 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::validate
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::validate
|
||||||
|
* @covers \D3\LinkmobilityClient\Request\Request::validate
|
||||||
*/
|
*/
|
||||||
public function validatePassedTest()
|
public function validatePassedTest()
|
||||||
{
|
{
|
||||||
$recipient = new Recipient('015792300219', 'DE');
|
$phoneUtil = PhoneNumberUtil::getInstance();
|
||||||
|
$example = $phoneUtil->getExampleNumberForType('DE', PhoneNumberType::MOBILE);
|
||||||
|
$phoneNumberFixture = $phoneUtil->format($example, PhoneNumberFormat::NATIONAL);
|
||||||
|
|
||||||
|
$recipient = new Recipient($phoneNumberFixture, 'DE');
|
||||||
|
|
||||||
/** @var Request|MockObject $requestMock */
|
/** @var Request|MockObject $requestMock */
|
||||||
$requestMock = $this->getMockBuilder($this->testClassName)
|
$requestMock = $this->getMockBuilder($this->testClassName)
|
||||||
|
@ -136,10 +150,16 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::validate
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::validate
|
||||||
*/
|
*/
|
||||||
public function validateFailedTest()
|
public function validateFailedTest()
|
||||||
{
|
{
|
||||||
$recipient = new Recipient('015792300219', 'DE');
|
$phoneUtil = PhoneNumberUtil::getInstance();
|
||||||
|
$example = $phoneUtil->getExampleNumberForType('DE', PhoneNumberType::MOBILE);
|
||||||
|
$phoneNumberFixture = $phoneUtil->format($example, PhoneNumberFormat::NATIONAL);
|
||||||
|
|
||||||
|
$recipient = new Recipient($phoneNumberFixture, 'DE');
|
||||||
|
|
||||||
/** @var Request|MockObject $requestMock */
|
/** @var Request|MockObject $requestMock */
|
||||||
$requestMock = $this->getMockBuilder($this->testClassName)
|
$requestMock = $this->getMockBuilder($this->testClassName)
|
||||||
|
@ -165,6 +185,9 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getRawBody
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getRawBody
|
||||||
|
* @covers \D3\LinkmobilityClient\Request\Request::getRawBody
|
||||||
*/
|
*/
|
||||||
public function testGetRawBody()
|
public function testGetRawBody()
|
||||||
{
|
{
|
||||||
|
@ -189,6 +212,8 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
* @dataProvider getBodyDataProvider
|
* @dataProvider getBodyDataProvider
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getBody
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getBody
|
||||||
*/
|
*/
|
||||||
public function testGetBody($contentType, $expected)
|
public function testGetBody($contentType, $expected)
|
||||||
{
|
{
|
||||||
|
@ -245,6 +270,8 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getOptions
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getOptions
|
||||||
*/
|
*/
|
||||||
public function testGetOptions()
|
public function testGetOptions()
|
||||||
{
|
{
|
||||||
|
@ -304,6 +331,10 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::setMessage
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::setMessage
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getMessage
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getMessage
|
||||||
*/
|
*/
|
||||||
public function setGetMessageTest()
|
public function setGetMessageTest()
|
||||||
{
|
{
|
||||||
|
@ -317,6 +348,10 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::setMethod
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::setMethod
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getMethod
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getMethod
|
||||||
*/
|
*/
|
||||||
public function setGetMethodTest()
|
public function setGetMethodTest()
|
||||||
{
|
{
|
||||||
|
@ -326,6 +361,8 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getMethods
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getMethods
|
||||||
*/
|
*/
|
||||||
public function getMethodsTest()
|
public function getMethodsTest()
|
||||||
{
|
{
|
||||||
|
@ -341,6 +378,10 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::setContentType
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::setContentType
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getContentType
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getContentType
|
||||||
*/
|
*/
|
||||||
public function setGetContentTypeTest()
|
public function setGetContentTypeTest()
|
||||||
{
|
{
|
||||||
|
@ -350,6 +391,10 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::setClientMessageId
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::setClientMessageId
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getClientMessageId
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getClientMessageId
|
||||||
*/
|
*/
|
||||||
public function setGetClientMessageIdTest()
|
public function setGetClientMessageIdTest()
|
||||||
{
|
{
|
||||||
|
@ -359,6 +404,10 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::setContentCategory
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::setContentCategory
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getContentCategory
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getContentCategory
|
||||||
*/
|
*/
|
||||||
public function setGetContentCategoryTest()
|
public function setGetContentCategoryTest()
|
||||||
{
|
{
|
||||||
|
@ -368,6 +417,8 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getContentCategories
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getContentCategories
|
||||||
*/
|
*/
|
||||||
public function getContentCategoriesTest()
|
public function getContentCategoriesTest()
|
||||||
{
|
{
|
||||||
|
@ -383,6 +434,10 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::setTestMode
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::setTestMode
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getTestMode
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getTestMode
|
||||||
*/
|
*/
|
||||||
public function setGetTestModeTest()
|
public function setGetTestModeTest()
|
||||||
{
|
{
|
||||||
|
@ -392,6 +447,10 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::setMaxSmsPerMessage
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::setMaxSmsPerMessage
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getMaxSmsPerMessage
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getMaxSmsPerMessage
|
||||||
*/
|
*/
|
||||||
public function setGetMaxSmsPerMessageTest()
|
public function setGetMaxSmsPerMessageTest()
|
||||||
{
|
{
|
||||||
|
@ -401,6 +460,10 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::setMessageType
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::setMessageType
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getMessageType
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getMessageType
|
||||||
*/
|
*/
|
||||||
public function setGetMessageTypeTest()
|
public function setGetMessageTypeTest()
|
||||||
{
|
{
|
||||||
|
@ -410,6 +473,10 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::setNotificationCallbackUrl
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::setNotificationCallbackUrl
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getNotificationCallbackUrl
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getNotificationCallbackUrl
|
||||||
*/
|
*/
|
||||||
public function setGetNotificationCallbackUrlTest()
|
public function setGetNotificationCallbackUrlTest()
|
||||||
{
|
{
|
||||||
|
@ -419,6 +486,10 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::setPriority
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::setPriority
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getPriority
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getPriority
|
||||||
*/
|
*/
|
||||||
public function setGetPriorityTest()
|
public function setGetPriorityTest()
|
||||||
{
|
{
|
||||||
|
@ -428,6 +499,8 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getRecipientsList
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getRecipientsList
|
||||||
*/
|
*/
|
||||||
public function getRecipientsListTest()
|
public function getRecipientsListTest()
|
||||||
{
|
{
|
||||||
|
@ -443,6 +516,10 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::sendAsFlashSms
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::sendAsFlashSms
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::doSendAsFlashSms
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::doSendAsFlashSms
|
||||||
*/
|
*/
|
||||||
public function setGetFlashSmsTest()
|
public function setGetFlashSmsTest()
|
||||||
{
|
{
|
||||||
|
@ -452,6 +529,10 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::setSenderAddress
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::setSenderAddress
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getSenderAddress
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getSenderAddress
|
||||||
*/
|
*/
|
||||||
public function setGetSenderAddressTest()
|
public function setGetSenderAddressTest()
|
||||||
{
|
{
|
||||||
|
@ -466,6 +547,10 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
* @dataProvider setGetSenderAddressTypeDataProvider
|
* @dataProvider setGetSenderAddressTypeDataProvider
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::setSenderAddressType
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::setSenderAddressType
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getSenderAddressType
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getSenderAddressType
|
||||||
*/
|
*/
|
||||||
public function testSetGetSenderAddressType($hasSender, $addressType, $expected)
|
public function testSetGetSenderAddressType($hasSender, $addressType, $expected)
|
||||||
{
|
{
|
||||||
|
@ -519,6 +604,8 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getSenderAddressTypes
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getSenderAddressTypes
|
||||||
*/
|
*/
|
||||||
public function getSenderAddressTypesTest()
|
public function getSenderAddressTypesTest()
|
||||||
{
|
{
|
||||||
|
@ -534,6 +621,10 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::setValidityPeriode
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::setValidityPeriode
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getValidityPeriode
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getValidityPeriode
|
||||||
*/
|
*/
|
||||||
public function setGetValidityPeriodeTest()
|
public function setGetValidityPeriodeTest()
|
||||||
{
|
{
|
||||||
|
@ -544,6 +635,8 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
* @dataProvider getResponseInstanceDataProvider
|
* @dataProvider getResponseInstanceDataProvider
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getResponseInstance
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getResponseInstance
|
||||||
*/
|
*/
|
||||||
public function testGetResponseInstance(ResponseInterface $response)
|
public function testGetResponseInstance(ResponseInterface $response)
|
||||||
{
|
{
|
||||||
|
@ -599,6 +692,10 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::setClient
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::setClient
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getClient
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getClient
|
||||||
*/
|
*/
|
||||||
public function setGetClientTest()
|
public function setGetClientTest()
|
||||||
{
|
{
|
||||||
|
@ -609,4 +706,33 @@ abstract class AbstractRequest extends ApiTestCase
|
||||||
|
|
||||||
$this->checkGetterSetter($clientMock, 'setClient', 'getClient');
|
$this->checkGetterSetter($clientMock, 'setClient', 'getClient');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @return void
|
||||||
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\BinaryRequest::getResponseClass
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\TextRequest::getResponseClass
|
||||||
|
*/
|
||||||
|
public function testGetResponseClass()
|
||||||
|
{
|
||||||
|
$className = $this->callMethod(
|
||||||
|
$this->request,
|
||||||
|
'getResponseClass'
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertIsString(
|
||||||
|
$className
|
||||||
|
);
|
||||||
|
|
||||||
|
/** @var \D3\LinkmobilityClient\Response\ResponseInterface|MockObject $responseMock */
|
||||||
|
$responseMock = $this->getMockBuilder($className)
|
||||||
|
->disableOriginalConstructor()
|
||||||
|
->getMock();
|
||||||
|
|
||||||
|
$this->assertInstanceOf(
|
||||||
|
\D3\LinkmobilityClient\Response\ResponseInterface::class,
|
||||||
|
$responseMock
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,6 +29,9 @@ abstract class AbstractResponse extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\Response::__construct
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\Response::getRawResponse
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\Response::getContent
|
||||||
*/
|
*/
|
||||||
public function testConstruct()
|
public function testConstruct()
|
||||||
{
|
{
|
||||||
|
@ -102,6 +105,7 @@ abstract class AbstractResponse extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\Response::getInternalStatus
|
||||||
*/
|
*/
|
||||||
public function testGetInternalStatus()
|
public function testGetInternalStatus()
|
||||||
{
|
{
|
||||||
|
@ -111,6 +115,7 @@ abstract class AbstractResponse extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\Response::getStatusMessage
|
||||||
*/
|
*/
|
||||||
public function testGetStatusMessage()
|
public function testGetStatusMessage()
|
||||||
{
|
{
|
||||||
|
@ -120,6 +125,17 @@ abstract class AbstractResponse extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\Response::getClientMessageId
|
||||||
|
*/
|
||||||
|
public function testGetClientMessageId()
|
||||||
|
{
|
||||||
|
$this->checkProperties('clientMessageId', 'clientMessageId', 'getClientMessageId');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\Response::getTransferId
|
||||||
*/
|
*/
|
||||||
public function testGetTransferId()
|
public function testGetTransferId()
|
||||||
{
|
{
|
||||||
|
@ -129,6 +145,7 @@ abstract class AbstractResponse extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\Response::getSmsCount
|
||||||
*/
|
*/
|
||||||
public function testGetSmsCount()
|
public function testGetSmsCount()
|
||||||
{
|
{
|
||||||
|
@ -142,6 +159,7 @@ abstract class AbstractResponse extends ApiTestCase
|
||||||
*
|
*
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
* @dataProvider isSuccessfulDataProvider
|
* @dataProvider isSuccessfulDataProvider
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\Response::isSuccessful
|
||||||
*/
|
*/
|
||||||
public function testIsSuccessful($statusCode, $expected)
|
public function testIsSuccessful($statusCode, $expected)
|
||||||
{
|
{
|
||||||
|
@ -180,6 +198,7 @@ abstract class AbstractResponse extends ApiTestCase
|
||||||
*
|
*
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
* @dataProvider getErrorMessageDataProvider
|
* @dataProvider getErrorMessageDataProvider
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\Response::getErrorMessage
|
||||||
*/
|
*/
|
||||||
public function testGetErrorMessage($successful, $expected)
|
public function testGetErrorMessage($successful, $expected)
|
||||||
{
|
{
|
||||||
|
|
|
@ -30,6 +30,7 @@ class RequestFactoryTest extends ApiTestCase
|
||||||
* @test
|
* @test
|
||||||
* @return void
|
* @return void
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\RequestFactory::__construct
|
||||||
*/
|
*/
|
||||||
public function testConstruct()
|
public function testConstruct()
|
||||||
{
|
{
|
||||||
|
@ -59,6 +60,7 @@ class RequestFactoryTest extends ApiTestCase
|
||||||
* @return void
|
* @return void
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
* @dataProvider getTextSmsRequestDataProvider
|
* @dataProvider getTextSmsRequestDataProvider
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\RequestFactory::getSmsRequest
|
||||||
*/
|
*/
|
||||||
public function testGetTextSmsRequest($encoding, $expectedClass)
|
public function testGetTextSmsRequest($encoding, $expectedClass)
|
||||||
{
|
{
|
||||||
|
@ -107,6 +109,7 @@ class RequestFactoryTest extends ApiTestCase
|
||||||
* @test
|
* @test
|
||||||
* @return void
|
* @return void
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\SMS\RequestFactory::getSmsLength
|
||||||
*/
|
*/
|
||||||
public function testGetSmsLengthInstance()
|
public function testGetSmsLengthInstance()
|
||||||
{
|
{
|
||||||
|
|
|
@ -45,6 +45,7 @@ class UrlTest extends ApiTestCase
|
||||||
* @test
|
* @test
|
||||||
* @return void
|
* @return void
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\Url\Url::getBaseUri
|
||||||
*/
|
*/
|
||||||
public function testGetBaseUri()
|
public function testGetBaseUri()
|
||||||
{
|
{
|
||||||
|
@ -63,6 +64,7 @@ class UrlTest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\Url\Url::getTextSmsUri
|
||||||
*/
|
*/
|
||||||
public function testGetTextSmsUri()
|
public function testGetTextSmsUri()
|
||||||
{
|
{
|
||||||
|
@ -78,6 +80,7 @@ class UrlTest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\Url\Url::getBinarySmsUri
|
||||||
*/
|
*/
|
||||||
public function testGetBinarySmsUri()
|
public function testGetBinarySmsUri()
|
||||||
{
|
{
|
||||||
|
|
|
@ -16,10 +16,13 @@ declare(strict_types=1);
|
||||||
namespace D3\LinkmobilityClient\Tests\ValueObject;
|
namespace D3\LinkmobilityClient\Tests\ValueObject;
|
||||||
|
|
||||||
use Assert\InvalidArgumentException;
|
use Assert\InvalidArgumentException;
|
||||||
|
use D3\LinkmobilityClient\Exceptions\RecipientException;
|
||||||
use D3\LinkmobilityClient\Tests\ApiTestCase;
|
use D3\LinkmobilityClient\Tests\ApiTestCase;
|
||||||
use D3\LinkmobilityClient\ValueObject\Recipient;
|
use D3\LinkmobilityClient\ValueObject\Recipient;
|
||||||
use libphonenumber\NumberParseException;
|
use libphonenumber\NumberParseException;
|
||||||
use libphonenumber\PhoneNumber;
|
use libphonenumber\PhoneNumber;
|
||||||
|
use libphonenumber\PhoneNumberFormat;
|
||||||
|
use libphonenumber\PhoneNumberType;
|
||||||
use libphonenumber\PhoneNumberUtil;
|
use libphonenumber\PhoneNumberUtil;
|
||||||
use PHPUnit\Framework\MockObject\MockObject;
|
use PHPUnit\Framework\MockObject\MockObject;
|
||||||
use ReflectionException;
|
use ReflectionException;
|
||||||
|
@ -29,17 +32,22 @@ class RecipientTest extends ApiTestCase
|
||||||
/** @var Recipient */
|
/** @var Recipient */
|
||||||
public $recipient;
|
public $recipient;
|
||||||
|
|
||||||
private $phoneNumberFixture = '01527565839';
|
private $phoneNumberFixture;
|
||||||
private $phoneCountryFixture = 'DE';
|
private $phoneCountryFixture = 'DE';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return void
|
* @return void
|
||||||
* @throws NumberParseException
|
* @throws NumberParseException
|
||||||
|
* @throws RecipientException
|
||||||
*/
|
*/
|
||||||
public function setUp(): void
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
$phoneUtil = PhoneNumberUtil::getInstance();
|
||||||
|
$example = $phoneUtil->getExampleNumberForType($this->phoneCountryFixture, PhoneNumberType::MOBILE);
|
||||||
|
$this->phoneNumberFixture = $phoneUtil->format($example, PhoneNumberFormat::NATIONAL);
|
||||||
|
|
||||||
$this->recipient = new Recipient($this->phoneNumberFixture, $this->phoneCountryFixture);
|
$this->recipient = new Recipient($this->phoneNumberFixture, $this->phoneCountryFixture);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -57,17 +65,21 @@ class RecipientTest extends ApiTestCase
|
||||||
* @test
|
* @test
|
||||||
* @return void
|
* @return void
|
||||||
* @throws NumberParseException
|
* @throws NumberParseException
|
||||||
|
* @throws RecipientException
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\Recipient::__construct
|
||||||
*/
|
*/
|
||||||
public function testConstructValid()
|
public function testConstructValid()
|
||||||
{
|
{
|
||||||
/** @var PhoneNumberUtil|MockObject $phoneNumberUtilMock */
|
/** @var PhoneNumberUtil|MockObject $phoneNumberUtilMock */
|
||||||
$phoneNumberUtilMock = $this->getMockBuilder(PhoneNumberUtil::class)
|
$phoneNumberUtilMock = $this->getMockBuilder(PhoneNumberUtil::class)
|
||||||
->onlyMethods(['parse', 'format'])
|
->onlyMethods(['parse', 'format', 'isValidNumber', 'getNumberType'])
|
||||||
->disableOriginalConstructor()
|
->disableOriginalConstructor()
|
||||||
->getMock();
|
->getMock();
|
||||||
$phoneNumberUtilMock->method('parse')->willReturn(new PhoneNumber());
|
$phoneNumberUtilMock->method('parse')->willReturn(new PhoneNumber());
|
||||||
$phoneNumberUtilMock->method('format')->willReturn('+491527565839');
|
$phoneNumberUtilMock->method('format')->willReturn('+491527565839');
|
||||||
|
$phoneNumberUtilMock->method('isValidNumber')->willReturn(true);
|
||||||
|
$phoneNumberUtilMock->method('getNumberType')->willReturn(PhoneNumberType::MOBILE);
|
||||||
|
|
||||||
/** @var Recipient|MockObject $recipientMock */
|
/** @var Recipient|MockObject $recipientMock */
|
||||||
$recipientMock = $this->getMockBuilder(Recipient::class)
|
$recipientMock = $this->getMockBuilder(Recipient::class)
|
||||||
|
@ -100,17 +112,20 @@ class RecipientTest extends ApiTestCase
|
||||||
* @param $number
|
* @param $number
|
||||||
* @param $country
|
* @param $country
|
||||||
* @param $validNumber
|
* @param $validNumber
|
||||||
|
* @param $numberType
|
||||||
* @param $expectedException
|
* @param $expectedException
|
||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
* @throws NumberParseException
|
* @throws NumberParseException
|
||||||
|
* @throws RecipientException
|
||||||
* @dataProvider constructInvalidDataProvider
|
* @dataProvider constructInvalidDataProvider
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\Recipient::__construct
|
||||||
*/
|
*/
|
||||||
public function testConstructInvalid($number, $country, $validNumber, $expectedException)
|
public function testConstructInvalid($number, $country, $validNumber, $numberType, $expectedException)
|
||||||
{
|
{
|
||||||
/** @var PhoneNumberUtil|MockObject $phoneNumberUtilMock */
|
/** @var PhoneNumberUtil|MockObject $phoneNumberUtilMock */
|
||||||
$phoneNumberUtilMock = $this->getMockBuilder(PhoneNumberUtil::class)
|
$phoneNumberUtilMock = $this->getMockBuilder(PhoneNumberUtil::class)
|
||||||
->onlyMethods(['parse', 'format', 'isValidNumber'])
|
->onlyMethods(['parse', 'format', 'isValidNumber', 'getNumberType'])
|
||||||
->disableOriginalConstructor()
|
->disableOriginalConstructor()
|
||||||
->getMock();
|
->getMock();
|
||||||
if ($number === 'abc') {
|
if ($number === 'abc') {
|
||||||
|
@ -120,6 +135,7 @@ class RecipientTest extends ApiTestCase
|
||||||
}
|
}
|
||||||
$phoneNumberUtilMock->method('format')->willReturn($number);
|
$phoneNumberUtilMock->method('format')->willReturn($number);
|
||||||
$phoneNumberUtilMock->method('isValidNumber')->willReturn($validNumber);
|
$phoneNumberUtilMock->method('isValidNumber')->willReturn($validNumber);
|
||||||
|
$phoneNumberUtilMock->method('getNumberType')->willReturn($numberType);
|
||||||
|
|
||||||
/** @var Recipient|MockObject $recipientMock */
|
/** @var Recipient|MockObject $recipientMock */
|
||||||
$recipientMock = $this->getMockBuilder(Recipient::class)
|
$recipientMock = $this->getMockBuilder(Recipient::class)
|
||||||
|
@ -137,17 +153,23 @@ class RecipientTest extends ApiTestCase
|
||||||
*/
|
*/
|
||||||
public function constructInvalidDataProvider(): array
|
public function constructInvalidDataProvider(): array
|
||||||
{
|
{
|
||||||
|
$phoneUtil = PhoneNumberUtil::getInstance();
|
||||||
|
$example = $phoneUtil->getExampleNumberForType($this->phoneCountryFixture, PhoneNumberType::MOBILE);
|
||||||
|
$phoneNumberFixture = $phoneUtil->format($example, PhoneNumberFormat::NATIONAL);
|
||||||
|
|
||||||
return [
|
return [
|
||||||
'empty number' => ['', 'DE', true, InvalidArgumentException::class],
|
'empty number' => ['', 'DE', true, PhoneNumberType::MOBILE, InvalidArgumentException::class],
|
||||||
'invalid country code' => [$this->phoneNumberFixture, 'DEX', true, InvalidArgumentException::class],
|
'invalid country code' => [$phoneNumberFixture, 'DEX', true, PhoneNumberType::MOBILE, InvalidArgumentException::class],
|
||||||
'unparsable' => ['abc', 'DE', true, NumberParseException::class],
|
'unparsable' => ['abc', 'DE', true, PhoneNumberType::MOBILE, NumberParseException::class],
|
||||||
'invalid number' => ['abc', 'DE', false, NumberParseException::class]
|
'invalid number' => ['abcd', 'DE', false, PhoneNumberType::MOBILE, RecipientException::class],
|
||||||
|
'not mobile number' => ['abcd', 'DE', false, PhoneNumberType::FIXED_LINE, RecipientException::class]
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\Recipient::getPhoneNumberUtil
|
||||||
*/
|
*/
|
||||||
public function testGetPhoneNumberUtil()
|
public function testGetPhoneNumberUtil()
|
||||||
{
|
{
|
||||||
|
@ -159,4 +181,65 @@ class RecipientTest extends ApiTestCase
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @return void
|
||||||
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\Recipient::getCountryCode
|
||||||
|
*/
|
||||||
|
public function testGetCountryCode()
|
||||||
|
{
|
||||||
|
$this->assertSame(
|
||||||
|
$this->phoneCountryFixture,
|
||||||
|
$this->callMethod(
|
||||||
|
$this->recipient,
|
||||||
|
'getCountryCode'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @return void
|
||||||
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\ValueObject::get
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\StringValueObject::get
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\StringValueObject::__toString
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\Recipient::get
|
||||||
|
*/
|
||||||
|
public function testGet()
|
||||||
|
{
|
||||||
|
$this->assertSame(
|
||||||
|
'+4915123456789',
|
||||||
|
(string) $this->recipient
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
'+4915123456789',
|
||||||
|
$this->callMethod(
|
||||||
|
$this->recipient,
|
||||||
|
'get'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @return void
|
||||||
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\ValueObject::getFormatted
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\StringValueObject::getFormatted
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\Recipient::getFormatted
|
||||||
|
*/
|
||||||
|
public function testGetFormatted()
|
||||||
|
{
|
||||||
|
$this->assertSame(
|
||||||
|
'4915123456789',
|
||||||
|
$this->callMethod(
|
||||||
|
$this->recipient,
|
||||||
|
'getFormatted'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,11 +16,14 @@ declare(strict_types=1);
|
||||||
namespace D3\LinkmobilityClient\Tests\ValueObject;
|
namespace D3\LinkmobilityClient\Tests\ValueObject;
|
||||||
|
|
||||||
use Assert\InvalidArgumentException;
|
use Assert\InvalidArgumentException;
|
||||||
|
use D3\LinkmobilityClient\Exceptions\NoSenderDefinedException;
|
||||||
use D3\LinkmobilityClient\Exceptions\RecipientException;
|
use D3\LinkmobilityClient\Exceptions\RecipientException;
|
||||||
use D3\LinkmobilityClient\Tests\ApiTestCase;
|
use D3\LinkmobilityClient\Tests\ApiTestCase;
|
||||||
use D3\LinkmobilityClient\ValueObject\Sender;
|
use D3\LinkmobilityClient\ValueObject\Sender;
|
||||||
use libphonenumber\NumberParseException;
|
use libphonenumber\NumberParseException;
|
||||||
use libphonenumber\PhoneNumber;
|
use libphonenumber\PhoneNumber;
|
||||||
|
use libphonenumber\PhoneNumberFormat;
|
||||||
|
use libphonenumber\PhoneNumberType;
|
||||||
use libphonenumber\PhoneNumberUtil;
|
use libphonenumber\PhoneNumberUtil;
|
||||||
use PHPUnit\Framework\MockObject\MockObject;
|
use PHPUnit\Framework\MockObject\MockObject;
|
||||||
use ReflectionException;
|
use ReflectionException;
|
||||||
|
@ -30,7 +33,7 @@ class SenderTest extends ApiTestCase
|
||||||
/** @var Sender */
|
/** @var Sender */
|
||||||
public $sender;
|
public $sender;
|
||||||
|
|
||||||
private $phoneNumberFixture = '015792300219';
|
private $phoneNumberFixture;
|
||||||
private $phoneCountryFixture = 'DE';
|
private $phoneCountryFixture = 'DE';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -42,6 +45,11 @@ class SenderTest extends ApiTestCase
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
$phoneUtil = PhoneNumberUtil::getInstance();
|
||||||
|
$example = $phoneUtil->getExampleNumberForType($this->phoneCountryFixture, PhoneNumberType::MOBILE);
|
||||||
|
$this->phoneNumberFixture = $phoneUtil->format($example, PhoneNumberFormat::NATIONAL);
|
||||||
|
|
||||||
|
/** @var Sender|MockObject sender */
|
||||||
$this->sender = new Sender($this->phoneNumberFixture, $this->phoneCountryFixture);
|
$this->sender = new Sender($this->phoneNumberFixture, $this->phoneCountryFixture);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,8 +69,10 @@ class SenderTest extends ApiTestCase
|
||||||
* @throws NumberParseException
|
* @throws NumberParseException
|
||||||
* @throws RecipientException
|
* @throws RecipientException
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @dataProvider constructValidDataProvider
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\Sender::__construct
|
||||||
*/
|
*/
|
||||||
public function testConstructValid()
|
public function testConstructValid($number, $country, $hasNumber)
|
||||||
{
|
{
|
||||||
/** @var PhoneNumberUtil|MockObject $phoneNumberUtilMock */
|
/** @var PhoneNumberUtil|MockObject $phoneNumberUtilMock */
|
||||||
$phoneNumberUtilMock = $this->getMockBuilder(PhoneNumberUtil::class)
|
$phoneNumberUtilMock = $this->getMockBuilder(PhoneNumberUtil::class)
|
||||||
|
@ -79,17 +89,33 @@ class SenderTest extends ApiTestCase
|
||||||
->disableOriginalConstructor()
|
->disableOriginalConstructor()
|
||||||
->getMock();
|
->getMock();
|
||||||
$senderMock->method('getPhoneNumberUtil')->willReturn($phoneNumberUtilMock);
|
$senderMock->method('getPhoneNumberUtil')->willReturn($phoneNumberUtilMock);
|
||||||
$senderMock->__construct($this->phoneNumberFixture, $this->phoneCountryFixture);
|
$senderMock->__construct($number, $country);
|
||||||
|
|
||||||
$this->assertSame(
|
$this->assertSame(
|
||||||
'4915792300219',
|
$hasNumber,
|
||||||
$this->callMethod(
|
$this->callMethod(
|
||||||
$senderMock,
|
$senderMock,
|
||||||
'get'
|
'get'
|
||||||
)
|
) === '4915792300219'
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array[]
|
||||||
|
*/
|
||||||
|
public function constructValidDataProvider(): array
|
||||||
|
{
|
||||||
|
$phoneUtil = PhoneNumberUtil::getInstance();
|
||||||
|
$example = $phoneUtil->getExampleNumberForType($this->phoneCountryFixture, PhoneNumberType::MOBILE);
|
||||||
|
$this->phoneNumberFixture = $phoneUtil->format($example, PhoneNumberFormat::NATIONAL);
|
||||||
|
|
||||||
|
return [
|
||||||
|
'null number' => [null, $this->phoneCountryFixture, false],
|
||||||
|
'null country' => [$this->phoneNumberFixture, null, false],
|
||||||
|
'all values' => [$this->phoneNumberFixture, $this->phoneCountryFixture, true]
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @param $number
|
* @param $number
|
||||||
|
@ -100,6 +126,7 @@ class SenderTest extends ApiTestCase
|
||||||
* @throws NumberParseException
|
* @throws NumberParseException
|
||||||
* @throws RecipientException
|
* @throws RecipientException
|
||||||
* @dataProvider constructInvalidDataProvider
|
* @dataProvider constructInvalidDataProvider
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\Sender::__construct
|
||||||
*/
|
*/
|
||||||
public function testConstructInvalid($number, $country, $validNumber, $expectedException)
|
public function testConstructInvalid($number, $country, $validNumber, $expectedException)
|
||||||
{
|
{
|
||||||
|
@ -109,12 +136,14 @@ class SenderTest extends ApiTestCase
|
||||||
->disableOriginalConstructor()
|
->disableOriginalConstructor()
|
||||||
->getMock();
|
->getMock();
|
||||||
if ($number === 'abc') {
|
if ($number === 'abc') {
|
||||||
$phoneNumberUtilMock->method('parse')->willThrowException(new NumberParseException(0, 'message'));
|
$phoneNumberUtilMock->expects($this->exactly((int) ($country !== 'DEX')))->method('parse')
|
||||||
|
->willThrowException(new NumberParseException(0, 'message'));
|
||||||
} else {
|
} else {
|
||||||
$phoneNumberUtilMock->method('parse')->willReturn(new PhoneNumber());
|
$phoneNumberUtilMock->expects($this->exactly((int) ($country !== 'DEX')))->method('parse')
|
||||||
|
->willReturn(new PhoneNumber());
|
||||||
}
|
}
|
||||||
$phoneNumberUtilMock->method('format')->willReturn($number);
|
$phoneNumberUtilMock->method('format')->willReturn($number);
|
||||||
$phoneNumberUtilMock->method('isValidNumber')->willReturn($validNumber);
|
$phoneNumberUtilMock->method('isValidNumber')->willReturn((bool) $validNumber);
|
||||||
|
|
||||||
/** @var Sender|MockObject $senderMock */
|
/** @var Sender|MockObject $senderMock */
|
||||||
$senderMock = $this->getMockBuilder(Sender::class)
|
$senderMock = $this->getMockBuilder(Sender::class)
|
||||||
|
@ -124,7 +153,12 @@ class SenderTest extends ApiTestCase
|
||||||
$senderMock->method('getPhoneNumberUtil')->willReturn($phoneNumberUtilMock);
|
$senderMock->method('getPhoneNumberUtil')->willReturn($phoneNumberUtilMock);
|
||||||
|
|
||||||
$this->expectException($expectedException);
|
$this->expectException($expectedException);
|
||||||
$senderMock->__construct($number, $country);
|
|
||||||
|
$this->callMethod(
|
||||||
|
$senderMock,
|
||||||
|
'__construct',
|
||||||
|
[$number, $country]
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -132,17 +166,22 @@ class SenderTest extends ApiTestCase
|
||||||
*/
|
*/
|
||||||
public function constructInvalidDataProvider(): array
|
public function constructInvalidDataProvider(): array
|
||||||
{
|
{
|
||||||
|
$phoneUtil = PhoneNumberUtil::getInstance();
|
||||||
|
$example = $phoneUtil->getExampleNumberForType($this->phoneCountryFixture, PhoneNumberType::MOBILE);
|
||||||
|
$phoneNumberFixture = $phoneUtil->format($example, PhoneNumberFormat::NATIONAL);
|
||||||
|
|
||||||
return [
|
return [
|
||||||
'empty number' => ['', 'DE', true, InvalidArgumentException::class],
|
'empty number' => ['', 'DE', true, InvalidArgumentException::class],
|
||||||
'invalid country code' => [$this->phoneNumberFixture, 'DEX', true, InvalidArgumentException::class],
|
'invalid country code' => [$phoneNumberFixture, 'DEX', true, InvalidArgumentException::class],
|
||||||
'unparsable' => ['abc', 'DE', true, NumberParseException::class],
|
'unparsable' => ['abc', 'DE', true, NumberParseException::class],
|
||||||
'invalid number' => ['abc', 'DE', false, NumberParseException::class]
|
'invalid number' => ['abcd', 'DE', false, RecipientException::class]
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\Sender::getPhoneNumberUtil
|
||||||
*/
|
*/
|
||||||
public function testGetPhoneNumberUtil()
|
public function testGetPhoneNumberUtil()
|
||||||
{
|
{
|
||||||
|
@ -154,4 +193,42 @@ class SenderTest extends ApiTestCase
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @return void
|
||||||
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\ValueObject::get
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\StringValueObject::get
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\Sender::get
|
||||||
|
*/
|
||||||
|
public function testGet()
|
||||||
|
{
|
||||||
|
$this->assertSame(
|
||||||
|
'+4915123456789',
|
||||||
|
$this->callMethod(
|
||||||
|
$this->sender,
|
||||||
|
'get'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @return void
|
||||||
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\ValueObject::getFormatted
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\StringValueObject::getFormatted
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\Sender::getFormatted
|
||||||
|
*/
|
||||||
|
public function testGetFormatted()
|
||||||
|
{
|
||||||
|
$this->assertSame(
|
||||||
|
'4915123456789',
|
||||||
|
$this->callMethod(
|
||||||
|
$this->sender,
|
||||||
|
'getFormatted'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -53,6 +53,7 @@ class SmsBinaryMessageTest extends ApiTestCase
|
||||||
* @test
|
* @test
|
||||||
* @return void
|
* @return void
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\SmsBinaryMessage::__construct
|
||||||
*/
|
*/
|
||||||
public function testConstructValid()
|
public function testConstructValid()
|
||||||
{
|
{
|
||||||
|
@ -89,6 +90,7 @@ class SmsBinaryMessageTest extends ApiTestCase
|
||||||
*
|
*
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
* @dataProvider constructInvalidDataProvider
|
* @dataProvider constructInvalidDataProvider
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\SmsBinaryMessage::__construct
|
||||||
*/
|
*/
|
||||||
public function testConstructInvalid($binaryMessage, $valid, $expectedException)
|
public function testConstructInvalid($binaryMessage, $valid, $expectedException)
|
||||||
{
|
{
|
||||||
|
@ -136,6 +138,7 @@ class SmsBinaryMessageTest extends ApiTestCase
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\SmsBinaryMessage::getSmsLength
|
||||||
*/
|
*/
|
||||||
public function testGetSmsLengthInstance()
|
public function testGetSmsLengthInstance()
|
||||||
{
|
{
|
||||||
|
@ -149,7 +152,9 @@ class SmsBinaryMessageTest extends ApiTestCase
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\SmsBinaryMessage::chunkCount
|
||||||
*/
|
*/
|
||||||
public function testGetChunkCount()
|
public function testGetChunkCount()
|
||||||
{
|
{
|
||||||
|
@ -180,7 +185,9 @@ class SmsBinaryMessageTest extends ApiTestCase
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\SmsBinaryMessage::length
|
||||||
*/
|
*/
|
||||||
public function testGetSize()
|
public function testGetSize()
|
||||||
{
|
{
|
||||||
|
@ -211,7 +218,10 @@ class SmsBinaryMessageTest extends ApiTestCase
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @test
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\SmsBinaryMessage::getMessageContent
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\SmsMessageAbstract::getMessageContent
|
||||||
*/
|
*/
|
||||||
public function testGetMessageContent()
|
public function testGetMessageContent()
|
||||||
{
|
{
|
||||||
|
|
|
@ -42,6 +42,7 @@ class SmsTextMessageTest extends SmsBinaryMessageTest
|
||||||
* @test
|
* @test
|
||||||
* @return void
|
* @return void
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\SmsTextMessage::__construct
|
||||||
*/
|
*/
|
||||||
public function testConstructValid()
|
public function testConstructValid()
|
||||||
{
|
{
|
||||||
|
@ -78,6 +79,7 @@ class SmsTextMessageTest extends SmsBinaryMessageTest
|
||||||
*
|
*
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
* @dataProvider constructInvalidDataProvider
|
* @dataProvider constructInvalidDataProvider
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\SmsTextMessage::__construct
|
||||||
*/
|
*/
|
||||||
public function testConstructInvalid($binaryMessage, $valid, $expectedException)
|
public function testConstructInvalid($binaryMessage, $valid, $expectedException)
|
||||||
{
|
{
|
||||||
|
|
|
@ -0,0 +1,88 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* For the full copyright and license information, please view the LICENSE
|
||||||
|
* file that was distributed with this source code.
|
||||||
|
*
|
||||||
|
* https://www.d3data.de
|
||||||
|
*
|
||||||
|
* @copyright (C) D3 Data Development (Inh. Thomas Dartsch)
|
||||||
|
* @author D3 Data Development - Daniel Seifert <support@shopmodule.com>
|
||||||
|
* @link https://www.oxidmodule.com
|
||||||
|
*/
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace D3\LinkmobilityClient\Tests\ValueObject;
|
||||||
|
|
||||||
|
use Assert\InvalidArgumentException;
|
||||||
|
use D3\LinkmobilityClient\Exceptions\NoSenderDefinedException;
|
||||||
|
use D3\LinkmobilityClient\Exceptions\RecipientException;
|
||||||
|
use D3\LinkmobilityClient\Tests\ApiTestCase;
|
||||||
|
use D3\LinkmobilityClient\ValueObject\Sender;
|
||||||
|
use D3\LinkmobilityClient\ValueObject\ValueObject;
|
||||||
|
use libphonenumber\NumberParseException;
|
||||||
|
use libphonenumber\PhoneNumber;
|
||||||
|
use libphonenumber\PhoneNumberFormat;
|
||||||
|
use libphonenumber\PhoneNumberType;
|
||||||
|
use libphonenumber\PhoneNumberUtil;
|
||||||
|
use PHPUnit\Framework\MockObject\MockObject;
|
||||||
|
use ReflectionException;
|
||||||
|
|
||||||
|
class ValueObjectTest extends ApiTestCase
|
||||||
|
{
|
||||||
|
public function setUp(): void
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
|
||||||
|
/** @var ValueObject|MockObject value */
|
||||||
|
$this->value = $this->getMockBuilder(ValueObject::class)
|
||||||
|
->disableOriginalConstructor()
|
||||||
|
->getMock();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @return void
|
||||||
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\ValueObject::__construct
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\ValueObject::get
|
||||||
|
*/
|
||||||
|
public function testConstructValid()
|
||||||
|
{
|
||||||
|
$phoneUtil = PhoneNumberUtil::getInstance();
|
||||||
|
$example = $phoneUtil->getExampleNumberForType('DE', PhoneNumberType::MOBILE);
|
||||||
|
$phoneNumberFixture = $phoneUtil->format($example, PhoneNumberFormat::NATIONAL);
|
||||||
|
|
||||||
|
$this->callMethod(
|
||||||
|
$this->value,
|
||||||
|
'__construct',
|
||||||
|
[$phoneNumberFixture]
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
'01512 3456789',
|
||||||
|
$this->getValue(
|
||||||
|
$this->value,
|
||||||
|
'value'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @return void
|
||||||
|
* @throws ReflectionException
|
||||||
|
* @covers \D3\LinkmobilityClient\ValueObject\ValueObject::__construct
|
||||||
|
*/
|
||||||
|
public function testConstructInvalid()
|
||||||
|
{
|
||||||
|
$this->expectException(InvalidArgumentException::class);
|
||||||
|
|
||||||
|
$this->callMethod(
|
||||||
|
$this->value,
|
||||||
|
'__construct',
|
||||||
|
['']
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
|
@ -5,7 +5,7 @@
|
||||||
convertNoticesToExceptions="true"
|
convertNoticesToExceptions="true"
|
||||||
convertWarningsToExceptions="true">
|
convertWarningsToExceptions="true">
|
||||||
|
|
||||||
<testsuite name="tankerkoenig">
|
<testsuite name="linkmobility">
|
||||||
<directory>./Tests</directory>
|
<directory>./Tests</directory>
|
||||||
</testsuite>
|
</testsuite>
|
||||||
|
|
||||||
|
|
|
@ -16,13 +16,8 @@ declare(strict_types=1);
|
||||||
namespace D3\LinkmobilityClient\RecipientsList;
|
namespace D3\LinkmobilityClient\RecipientsList;
|
||||||
|
|
||||||
use D3\LinkmobilityClient\Client;
|
use D3\LinkmobilityClient\Client;
|
||||||
use D3\LinkmobilityClient\Exceptions\ExceptionMessages;
|
|
||||||
use D3\LinkmobilityClient\Exceptions\RecipientException;
|
|
||||||
use D3\LinkmobilityClient\ValueObject\Recipient;
|
use D3\LinkmobilityClient\ValueObject\Recipient;
|
||||||
use Iterator;
|
use Iterator;
|
||||||
use libphonenumber\NumberParseException;
|
|
||||||
use libphonenumber\PhoneNumberType;
|
|
||||||
use libphonenumber\PhoneNumberUtil;
|
|
||||||
|
|
||||||
class RecipientsList implements RecipientsListInterface, Iterator
|
class RecipientsList implements RecipientsListInterface, Iterator
|
||||||
{
|
{
|
||||||
|
@ -41,14 +36,6 @@ class RecipientsList implements RecipientsListInterface, Iterator
|
||||||
$this->setClient($client);
|
$this->setClient($client);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @return PhoneNumberUtil
|
|
||||||
*/
|
|
||||||
protected function getPhoneNumberUtil(): PhoneNumberUtil
|
|
||||||
{
|
|
||||||
return PhoneNumberUtil::getInstance();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param Recipient $recipient
|
* @param Recipient $recipient
|
||||||
*
|
*
|
||||||
|
@ -56,30 +43,7 @@ class RecipientsList implements RecipientsListInterface, Iterator
|
||||||
*/
|
*/
|
||||||
public function add(Recipient $recipient): RecipientsListInterface
|
public function add(Recipient $recipient): RecipientsListInterface
|
||||||
{
|
{
|
||||||
$phoneUtil = $this->getPhoneNumberUtil();
|
$this->recipients[ md5(serialize($recipient)) ] = $recipient;
|
||||||
try {
|
|
||||||
$phoneNumber = $phoneUtil->parse($recipient->get(), $recipient->getCountryCode());
|
|
||||||
|
|
||||||
if (false === $phoneUtil->isValidNumber($phoneNumber)) {
|
|
||||||
throw new RecipientException(ExceptionMessages::INVALID_RECIPIENT_PHONE);
|
|
||||||
} elseif (
|
|
||||||
false === in_array(
|
|
||||||
$phoneUtil->getNumberType($phoneNumber),
|
|
||||||
[
|
|
||||||
PhoneNumberType::MOBILE,
|
|
||||||
PhoneNumberType::FIXED_LINE_OR_MOBILE
|
|
||||||
]
|
|
||||||
)
|
|
||||||
) {
|
|
||||||
throw new RecipientException(ExceptionMessages::NOT_A_MOBILE_NUMBER);
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->recipients[ md5(serialize($recipient)) ] = $recipient;
|
|
||||||
} catch (NumberParseException $e) {
|
|
||||||
$this->client->getLoggerHandler()->getLogger()->info($e->getMessage(), [$recipient]);
|
|
||||||
} catch (RecipientException $e) {
|
|
||||||
$this->client->getLoggerHandler()->getLogger()->info($e->getMessage(), [$recipient]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,12 +16,23 @@ declare(strict_types=1);
|
||||||
namespace D3\LinkmobilityClient\ValueObject;
|
namespace D3\LinkmobilityClient\ValueObject;
|
||||||
|
|
||||||
use Assert\Assert;
|
use Assert\Assert;
|
||||||
|
use D3\LinkmobilityClient\Exceptions\ExceptionMessages;
|
||||||
|
use D3\LinkmobilityClient\Exceptions\RecipientException;
|
||||||
use libphonenumber\NumberParseException;
|
use libphonenumber\NumberParseException;
|
||||||
use libphonenumber\PhoneNumberFormat;
|
use libphonenumber\PhoneNumberFormat;
|
||||||
|
use libphonenumber\PhoneNumberType;
|
||||||
use libphonenumber\PhoneNumberUtil;
|
use libphonenumber\PhoneNumberUtil;
|
||||||
|
|
||||||
class Recipient extends StringValueObject
|
class Recipient extends StringValueObject
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected $allowedNumberTypes = [
|
||||||
|
PhoneNumberType::MOBILE,
|
||||||
|
PhoneNumberType::FIXED_LINE_OR_MOBILE
|
||||||
|
];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var string
|
* @var string
|
||||||
*/
|
*/
|
||||||
|
@ -32,16 +43,29 @@ class Recipient extends StringValueObject
|
||||||
* @param string $iso2CountryCode
|
* @param string $iso2CountryCode
|
||||||
*
|
*
|
||||||
* @throws NumberParseException
|
* @throws NumberParseException
|
||||||
|
* @throws RecipientException
|
||||||
*/
|
*/
|
||||||
public function __construct(string $number, string $iso2CountryCode)
|
public function __construct(string $number, string $iso2CountryCode)
|
||||||
{
|
{
|
||||||
|
Assert::that($number)->notEmpty();
|
||||||
Assert::that($iso2CountryCode)->string()->length(2);
|
Assert::that($iso2CountryCode)->string()->length(2);
|
||||||
|
|
||||||
$phoneUtil = $this->getPhoneNumberUtil();
|
$phoneUtil = $this->getPhoneNumberUtil();
|
||||||
|
|
||||||
$phoneNumber = $phoneUtil->parse($number, strtoupper($iso2CountryCode));
|
$phoneNumber = $phoneUtil->parse($number, strtoupper($iso2CountryCode));
|
||||||
$number = $phoneUtil->format($phoneNumber, PhoneNumberFormat::E164);
|
$number = $phoneUtil->format( $phoneNumber, PhoneNumberFormat::E164 );
|
||||||
|
|
||||||
|
if (false === $phoneUtil->isValidNumber($phoneNumber)) {
|
||||||
|
throw new RecipientException(ExceptionMessages::INVALID_RECIPIENT_PHONE);
|
||||||
|
} elseif (
|
||||||
|
false === in_array(
|
||||||
|
$phoneUtil->getNumberType($phoneNumber),
|
||||||
|
$this->allowedNumberTypes
|
||||||
|
)
|
||||||
|
) {
|
||||||
|
throw new RecipientException( ExceptionMessages::NOT_A_MOBILE_NUMBER);
|
||||||
|
}
|
||||||
|
|
||||||
parent::__construct($number);
|
parent::__construct($number);
|
||||||
$this->countryCode = $iso2CountryCode;
|
$this->countryCode = $iso2CountryCode;
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,7 +35,7 @@ class SmsBinaryMessage extends SmsMessageAbstract
|
||||||
public function getMessageContent()
|
public function getMessageContent()
|
||||||
{
|
{
|
||||||
return str_split(
|
return str_split(
|
||||||
base64_encode($this->get()),
|
base64_encode(parent::getMessageContent()),
|
||||||
SmsLength::MAXIMUM_CHARACTERS_UCS2_SINGLE
|
SmsLength::MAXIMUM_CHARACTERS_UCS2_SINGLE
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue