X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=tests%2Fphpunit%2FCRM%2FUtils%2FTokenTest.php;h=450397298c5c7b9b49a42c29fdd43607cd161039;hb=d23a840949552b4781dde118914209bbb504a553;hp=c42ca966f0bf027af611ff55a7c019b78f8dcdcd;hpb=2efe239ba80ed985fa2c0aff5b2a4023670a5859;p=civicrm-core.git diff --git a/tests/phpunit/CRM/Utils/TokenTest.php b/tests/phpunit/CRM/Utils/TokenTest.php index c42ca966f0..450397298c 100644 --- a/tests/phpunit/CRM/Utils/TokenTest.php +++ b/tests/phpunit/CRM/Utils/TokenTest.php @@ -78,6 +78,11 @@ class CRM_Utils_TokenTest extends CiviUnitTestCase { $escapeSmarty = TRUE; CRM_Utils_Token::replaceGreetingTokens($tokenString, $contactDetails, $contactId, $className, $escapeSmarty); $this->assertEquals($tokenString, 'First Name: Morticia Last Name: Addams Birth Date: Prefix: Ms. Suffix: '); + + // Test compatibility with custom tokens (#14943) + $tokenString = 'Custom {custom.custom}'; + CRM_Utils_Token::replaceGreetingTokens($tokenString, $contactDetails, $contactId, $className, $escapeSmarty); + $this->assertEquals($tokenString, 'Custom '); } /** @@ -142,4 +147,53 @@ class CRM_Utils_TokenTest extends CiviUnitTestCase { } } + /** + * This is a basic test of the token processor (currently testing TokenCompatSubscriber) + * and makes sure that greeting + contact tokens are replaced. + * This is a good example to copy/expand when creating additional tests for token processor + * in "real" situations. + * + * @throws \CRM_Core_Exception + */ + public function testTokenProcessor() { + $params['contact_id'] = $this->individualCreate(); + + // Prepare the processor and general context. + $tokenProc = new \Civi\Token\TokenProcessor(\Civi::dispatcher(), [ + // Unique(ish) identifier for our controller/use-case. + 'controller' => 'civicrm_tokentest', + + // Provide hints about what data will be available for each row. + // Ex: 'schema' => ['contactId', 'activityId', 'caseId'], + 'schema' => ['contactId'], + + // Whether to enable Smarty evaluation. + 'smarty' => (defined('CIVICRM_MAIL_SMARTY') && CIVICRM_MAIL_SMARTY), + ]); + + // Define message templates. + $tokenProc->addMessage('body_html', 'Good morning,

{contact.email_greeting} {contact.display_name}

. {custom.foobar} Bye!', 'text/html'); + $tokenProc->addMessage('body_text', 'Good morning, {contact.email_greeting} {contact.display_name} Bye!', 'text/plain'); + + $expect[$params['contact_id']]['html'] = 'Good morning,

Dear Anthony Mr. Anthony Anderson II

. Bye!'; + $expect[$params['contact_id']]['text'] = 'Good morning, Dear Anthony Mr. Anthony Anderson II Bye!'; + + // Define row data. + foreach (explode(',', $params['contact_id']) as $contactId) { + $context = ['contactId' => $contactId]; + $tokenProc->addRow()->context($context); + } + + $tokenProc->evaluate(); + + $this->assertNotEmpty($tokenProc->getRows()); + foreach ($tokenProc->getRows() as $tokenRow) { + /** @var \Civi\Token\TokenRow $tokenRow */ + $html = $tokenRow->render('body_html'); + $text = $tokenRow->render('body_text'); + $this->assertEquals($expect[$params['contact_id']]['html'], $html); + $this->assertEquals($expect[$params['contact_id']]['text'], $text); + } + } + }