forked from Wavyzz/dolibarr
Merge
This commit is contained in:
@@ -24,18 +24,19 @@
|
||||
* \remarks To run this script as CLI: phpunit filename.php
|
||||
*/
|
||||
|
||||
global $conf,$user,$langs,$db;
|
||||
global $conf, $user, $langs, $db;
|
||||
//define('TEST_DB_FORCE_TYPE','mysql'); // This is to force using mysql driver
|
||||
//require_once 'PHPUnit/Autoload.php';
|
||||
require_once dirname(__FILE__).'/../../htdocs/master.inc.php';
|
||||
require_once dirname(__FILE__).'/../../htdocs/core/class/CMailFile.class.php';
|
||||
require_once dirname(__FILE__) . '/../../htdocs/master.inc.php';
|
||||
require_once dirname(__FILE__) . '/../../htdocs/core/class/CMailFile.class.php';
|
||||
require_once dirname(__FILE__) . '/../../htdocs/core/lib/files.lib.php';
|
||||
|
||||
if (empty($user->id)) {
|
||||
print "Load permissions for admin user nb 1\n";
|
||||
$user->fetch(1);
|
||||
$user->getrights();
|
||||
}
|
||||
$conf->global->MAIN_DISABLE_ALL_MAILS=1;
|
||||
$conf->global->MAIN_DISABLE_ALL_MAILS = 1;
|
||||
|
||||
|
||||
/**
|
||||
@@ -43,7 +44,7 @@ $conf->global->MAIN_DISABLE_ALL_MAILS=1;
|
||||
*
|
||||
* @backupGlobals disabled
|
||||
* @backupStaticAttributes enabled
|
||||
* @remarks backupGlobals must be disabled to have db,conf,user and lang not erased.
|
||||
* @remarks backupGlobals must be disabled to have db,conf,user and lang not erased.
|
||||
*/
|
||||
class CMailFileTest extends PHPUnit\Framework\TestCase
|
||||
{
|
||||
@@ -64,13 +65,13 @@ class CMailFileTest extends PHPUnit\Framework\TestCase
|
||||
parent::__construct($name);
|
||||
|
||||
//$this->sharedFixture
|
||||
global $conf,$user,$langs,$db;
|
||||
$this->savconf=$conf;
|
||||
$this->savuser=$user;
|
||||
$this->savlangs=$langs;
|
||||
$this->savdb=$db;
|
||||
global $conf, $user, $langs, $db;
|
||||
$this->savconf = $conf;
|
||||
$this->savuser = $user;
|
||||
$this->savlangs = $langs;
|
||||
$this->savdb = $db;
|
||||
|
||||
print __METHOD__." db->type=".$db->type." user->id=".$user->id;
|
||||
print __METHOD__ . " db->type=" . $db->type . " user->id=" . $user->id;
|
||||
//print " - db ".$db->db;
|
||||
print "\n";
|
||||
}
|
||||
@@ -82,23 +83,23 @@ class CMailFileTest extends PHPUnit\Framework\TestCase
|
||||
*/
|
||||
public static function setUpBeforeClass(): void
|
||||
{
|
||||
global $conf,$user,$langs,$db;
|
||||
global $conf, $user, $langs, $db;
|
||||
$db->begin(); // This is to have all actions inside a transaction even if test launched without suite.
|
||||
|
||||
print __METHOD__."\n";
|
||||
print __METHOD__ . "\n";
|
||||
}
|
||||
|
||||
/**
|
||||
* tearDownAfterClass
|
||||
*
|
||||
* @return void
|
||||
* @return void
|
||||
*/
|
||||
public static function tearDownAfterClass(): void
|
||||
{
|
||||
global $conf,$user,$langs,$db;
|
||||
global $conf, $user, $langs, $db;
|
||||
$db->rollback();
|
||||
|
||||
print __METHOD__."\n";
|
||||
print __METHOD__ . "\n";
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -108,24 +109,25 @@ class CMailFileTest extends PHPUnit\Framework\TestCase
|
||||
*/
|
||||
protected function setUp(): void
|
||||
{
|
||||
global $conf,$user,$langs,$db;
|
||||
$conf=$this->savconf;
|
||||
$user=$this->savuser;
|
||||
$langs=$this->savlangs;
|
||||
$db=$this->savdb;
|
||||
global $conf, $user, $langs, $db;
|
||||
$conf = $this->savconf;
|
||||
$user = $this->savuser;
|
||||
$langs = $this->savlangs;
|
||||
$db = $this->savdb;
|
||||
|
||||
$conf->global->MAIN_DISABLE_ALL_MAILS=1; // If I comment/remove this lien, unit test still works alone but failed when ran from AllTest. Don't know why.
|
||||
$conf->global->MAIN_DISABLE_ALL_MAILS = 1; // If I comment/remove this lien, unit test still works alone but failed when ran from AllTest. Don't know why.
|
||||
|
||||
print __METHOD__."\n";
|
||||
print __METHOD__ . "\n";
|
||||
}
|
||||
|
||||
/**
|
||||
* End phpunit tests
|
||||
*
|
||||
* @return void
|
||||
* @return void
|
||||
*/
|
||||
protected function tearDown(): void
|
||||
{
|
||||
print __METHOD__."\n";
|
||||
print __METHOD__ . "\n";
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -135,16 +137,16 @@ class CMailFileTest extends PHPUnit\Framework\TestCase
|
||||
*/
|
||||
public function testCMailFileText()
|
||||
{
|
||||
global $conf,$user,$langs,$db;
|
||||
$conf=$this->savconf;
|
||||
$user=$this->savuser;
|
||||
$langs=$this->savlangs;
|
||||
$db=$this->savdb;
|
||||
global $conf, $user, $langs, $db;
|
||||
$conf = $this->savconf;
|
||||
$user = $this->savuser;
|
||||
$langs = $this->savlangs;
|
||||
$db = $this->savdb;
|
||||
|
||||
$localobject=new CMailFile('Test', 'test@test.com', 'from@from.com', 'Message txt', array(), array(), array(), '', '', 1, 0);
|
||||
$localobject = new CMailFile('Test', 'test@test.com', 'from@from.com', 'Message txt', array(), array(), array(), '', '', 1, 0);
|
||||
|
||||
$result=$localobject->sendfile();
|
||||
print __METHOD__." result=".$result."\n";
|
||||
$result = $localobject->sendfile();
|
||||
print __METHOD__ . " result=" . $result . "\n";
|
||||
$this->assertFalse($result); // False because mail send disabled
|
||||
|
||||
return $result;
|
||||
@@ -157,54 +159,115 @@ class CMailFileTest extends PHPUnit\Framework\TestCase
|
||||
*/
|
||||
public function testCMailFileStatic()
|
||||
{
|
||||
global $conf,$user,$langs,$db;
|
||||
$conf=$this->savconf;
|
||||
$user=$this->savuser;
|
||||
$langs=$this->savlangs;
|
||||
$db=$this->savdb;
|
||||
global $conf, $user, $langs, $db;
|
||||
$conf = $this->savconf;
|
||||
$user = $this->savuser;
|
||||
$langs = $this->savlangs;
|
||||
$db = $this->savdb;
|
||||
|
||||
$localobject=new CMailFile('', '', '', '');
|
||||
$localobject = new CMailFile('', '', '', '');
|
||||
|
||||
$src='John Doe <john@doe.com>';
|
||||
$result=$localobject->getValidAddress($src, 0);
|
||||
print __METHOD__." result=".$result."\n";
|
||||
$src = 'John Doe <john@doe.com>';
|
||||
$result = $localobject->getValidAddress($src, 0);
|
||||
print __METHOD__ . " result=" . $result . "\n";
|
||||
$this->assertEquals($result, 'John Doe <john@doe.com>');
|
||||
|
||||
$src='John Doe <john@doe.com>';
|
||||
$result=$localobject->getValidAddress($src, 1);
|
||||
print __METHOD__." result=".$result."\n";
|
||||
$src = 'John Doe <john@doe.com>';
|
||||
$result = $localobject->getValidAddress($src, 1);
|
||||
print __METHOD__ . " result=" . $result . "\n";
|
||||
$this->assertEquals($result, '<john@doe.com>');
|
||||
|
||||
$src='John Doe <john@doe.com>';
|
||||
$result=$localobject->getValidAddress($src, 2);
|
||||
print __METHOD__." result=".$result."\n";
|
||||
$src = 'John Doe <john@doe.com>';
|
||||
$result = $localobject->getValidAddress($src, 2);
|
||||
print __METHOD__ . " result=" . $result . "\n";
|
||||
$this->assertEquals($result, 'john@doe.com');
|
||||
|
||||
$src='John Doe <john@doe.com>';
|
||||
$result=$localobject->getValidAddress($src, 3, 0);
|
||||
print __METHOD__." result=".$result."\n";
|
||||
$src = 'John Doe <john@doe.com>';
|
||||
$result = $localobject->getValidAddress($src, 3, 0);
|
||||
print __METHOD__ . " result=" . $result . "\n";
|
||||
$this->assertEquals($result, '"John Doe" <john@doe.com>');
|
||||
|
||||
$src='John Doe <john@doe.com>';
|
||||
$result=$localobject->getValidAddress($src, 3, 1);
|
||||
print __METHOD__." result=".$result."\n";
|
||||
$src = 'John Doe <john@doe.com>';
|
||||
$result = $localobject->getValidAddress($src, 3, 1);
|
||||
print __METHOD__ . " result=" . $result . "\n";
|
||||
$this->assertEquals($result, '"=?UTF-8?B?Sm9obiBEb2U=?=" <john@doe.com>');
|
||||
|
||||
$src='John Doe <john@doe.com>';
|
||||
$result=$localobject->getValidAddress($src, 4);
|
||||
print __METHOD__." result=".$result."\n";
|
||||
$src = 'John Doe <john@doe.com>';
|
||||
$result = $localobject->getValidAddress($src, 4);
|
||||
print __METHOD__ . " result=" . $result . "\n";
|
||||
$this->assertEquals($result, 'John Doe');
|
||||
|
||||
$src='John Doe <john@doe.com>, John Doe2 <john@doe3.com>, John Doe3 <john@doe2.com>';
|
||||
$result=$localobject->getValidAddress($src, 4);
|
||||
print __METHOD__." result=".$result."\n";
|
||||
$src = 'John Doe <john@doe.com>, John Doe2 <john@doe3.com>, John Doe3 <john@doe2.com>';
|
||||
$result = $localobject->getValidAddress($src, 4);
|
||||
print __METHOD__ . " result=" . $result . "\n";
|
||||
$this->assertEquals($result, 'John Doe,John Doe2,John Doe3');
|
||||
|
||||
$src='John Doe <john@doe.com>, John Doe2 <john@doe3.com>, John Doe3 <john@doe2.com>';
|
||||
$result=$localobject->getValidAddress($src, 4, 0, 2);
|
||||
print __METHOD__." result=".$result."\n";
|
||||
$src = 'John Doe <john@doe.com>, John Doe2 <john@doe3.com>, John Doe3 <john@doe2.com>';
|
||||
$result = $localobject->getValidAddress($src, 4, 0, 2);
|
||||
print __METHOD__ . " result=" . $result . "\n";
|
||||
$this->assertEquals($result, 'John Doe,John Doe2...');
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
/**
|
||||
* testCMailFileHTMLWithImage
|
||||
*
|
||||
* @return int
|
||||
*/
|
||||
public function testCMailFileHTMLWithImage()
|
||||
{
|
||||
global $conf, $user, $langs, $db;
|
||||
|
||||
$conf = $this->savconf;
|
||||
$user = $this->savuser;
|
||||
$langs = $this->savlangs;
|
||||
$db = $this->savdb;
|
||||
$conf->global->MAIN_MAIL_ADD_INLINE_IMAGES_IF_IN_MEDIAS = 1;
|
||||
$conf->global->MAIN_MAIL_ADD_INLINE_IMAGES_IF_DATA = 1;
|
||||
|
||||
dol_delete_dir_recursive(DOL_DATA_ROOT . '/medias/image');
|
||||
dol_mkdir(DOL_DATA_ROOT . '/medias/image');
|
||||
dol_copy(dirname(__FILE__) . '/img250x20.png', DOL_DATA_ROOT . '/medias/image/img250x20.png');
|
||||
|
||||
$msg = '<html><body>';
|
||||
$msg .= '<img alt="" src="/viewimage.php?modulepart=medias&entity=1&file=image/img250x20.png" style="height:39px; width:150px" />';
|
||||
$msg .= ' <p>From wikipedia</p> <img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==" alt="Red dot" />';
|
||||
$msg .= '</body></html>';
|
||||
|
||||
|
||||
$localobject = new CMailFile('Test', 'test@test.com', 'from@from.com', $msg, array(), array(), array(), '', '', 0, -1, '', '', '', '', 'standard', '', '/tmp');
|
||||
|
||||
$result = count($localobject->html_images);
|
||||
print __METHOD__ . " result count image detected in the mail=" . $result . "\n";
|
||||
$this->assertEquals($result, 2);
|
||||
|
||||
|
||||
foreach ($localobject->html_images as $i => $val)
|
||||
if ($localobject->html_images[$i]) {
|
||||
if (preg_match('/img250x20\.png/i', $localobject->html_images[$i]['fullpath'])) {
|
||||
print __METHOD__ . " content type must be image png =" . $localobject->html_images[$i]['content_type'] . "\n";
|
||||
$this->assertEquals($localobject->html_images[$i]['content_type'], 'image/png');
|
||||
|
||||
print __METHOD__ . " type must be cidfromurl =" . $localobject->html_images[$i]['type'] . "\n";
|
||||
$this->assertEquals($localobject->html_images[$i]['type'], 'cidfromurl');
|
||||
|
||||
$fileSize = 9744;
|
||||
print __METHOD__ . " File size must be =" . $fileSize . "\n";
|
||||
$this->assertEquals(dol_filesize($localobject->html_images[$i]['fullpath']), $fileSize);
|
||||
} elseif (preg_match('/\.png/i', $localobject->html_images[$i]['fullpath'])) {
|
||||
print __METHOD__ . " content type must be image png =" . $localobject->html_images[$i]['content_type'] . "\n";
|
||||
$this->assertEquals($localobject->html_images[$i]['content_type'], 'image/png');
|
||||
|
||||
print __METHOD__ . " type must be cidfromdata =" . $localobject->html_images[$i]['type'] . "\n";
|
||||
$this->assertEquals($localobject->html_images[$i]['type'], 'cidfromdata');
|
||||
|
||||
$fileSize = 85;
|
||||
print __METHOD__ . " File size must be =" . $fileSize . "\n";
|
||||
$this->assertEquals(dol_filesize($localobject->html_images[$i]['fullpath']), $fileSize);
|
||||
}
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user