diff --git a/composer.json b/composer.json index ea15727..d37185e 100644 --- a/composer.json +++ b/composer.json @@ -39,6 +39,7 @@ "require": { "php": "^8.0", "ext-dom": "*", + "ext-mbstring": "*", "ext-simplexml": "*", "ext-xmlwriter": "*", "ext-zlib": "*", diff --git a/src/Individual.php b/src/Individual.php index 8d9967b..a4f8730 100644 --- a/src/Individual.php +++ b/src/Individual.php @@ -15,12 +15,13 @@ class Individual public function __construct($title, $name, $surname, $phone, $houseNum, $postcode, $overseas = false) { $this->title = $title; - $this->surname = $surname; - $this->forename = $name; $this->phone = $phone; - $this->houseNum = $houseNum; $this->postcode = $postcode; $this->isOverseas = $overseas; + + $this->setForename($name); + $this->setSurname($surname); + $this->setHouseNum($houseNum); } public function getTitle() @@ -40,7 +41,7 @@ public function getSurname() public function setSurname($value) { - $this->surname = $value; + $this->surname = mb_substr($value, 0, 35); } public function getForename() @@ -50,7 +51,7 @@ public function getForename() public function setForename($value) { - $this->forename = $value; + $this->forename = mb_substr($value, 0, 35); } public function getPhone() @@ -70,7 +71,7 @@ public function getHouseNum() public function setHouseNum($value) { - $this->houseNum = substr($value, 0, 40); + $this->houseNum = mb_substr($value, 0, 40); } public function getPostcode() diff --git a/tests/GovTalk/GiftAid/IndividualTest.php b/tests/GovTalk/GiftAid/IndividualTest.php index b0f6199..62ee1c8 100644 --- a/tests/GovTalk/GiftAid/IndividualTest.php +++ b/tests/GovTalk/GiftAid/IndividualTest.php @@ -42,6 +42,22 @@ public function testIndividualCreation() $this->assertEquals($this->individual->getIsOverseas(), 'no'); } + public function testIndividualCreationWithLongNameAndAddressValues() + { + $testIndividual = new Individual( + title: '', + name: str_repeat('a', 36), + surname: str_repeat('b', 36), + houseNum: str_repeat('c', 41), + postcode: 'N11XX', + phone: '07777 777777', + ); + + $this->assertEquals(35, strlen($testIndividual->getForename())); + $this->assertEquals(35, strlen($testIndividual->getSurname())); + $this->assertEquals(40, strlen($testIndividual->getHouseNum())); + } + public function testForeignIndividualCreation() { $this->assertEquals($this->foreign->getTitle(), 'Ds');