2
0
forked from Wavyzz/dolibarr
This commit is contained in:
Laurent Destailleur
2023-12-29 16:51:05 +01:00
7 changed files with 159 additions and 78 deletions

View File

@@ -842,7 +842,7 @@ class AccountingAccount extends CommonObject
} }
$suggestedid = $accountingAccount['dom']; // There is a doubt for this case. Is it an error on vat or we just forgot to fill vat number ? $suggestedid = $accountingAccount['dom']; // There is a doubt for this case. Is it an error on vat or we just forgot to fill vat number ?
$suggestedaccountingaccountfor = 'eecwithoutvatnumber'; $suggestedaccountingaccountfor = 'eecwithoutvatnumber';
} elseif ($isSellerInEEC && $isBuyerInEEC && !empty($product->accountancy_code_sell_intra)) { } elseif ($isSellerInEEC && $isBuyerInEEC) {
// European intravat sale // European intravat sale
if ($type == 'customer' && !empty($product->accountancy_code_sell_intra)) { if ($type == 'customer' && !empty($product->accountancy_code_sell_intra)) {
$code_p = $product->accountancy_code_sell_intra; $code_p = $product->accountancy_code_sell_intra;

View File

@@ -727,7 +727,7 @@ class Facture extends CommonInvoice
$sql .= ", ".(empty($this->date_pointoftax) ? "null" : "'".$this->db->idate($this->date_pointoftax)."'"); $sql .= ", ".(empty($this->date_pointoftax) ? "null" : "'".$this->db->idate($this->date_pointoftax)."'");
$sql .= ", ".($this->note_private ? "'".$this->db->escape($this->note_private)."'" : "null"); $sql .= ", ".($this->note_private ? "'".$this->db->escape($this->note_private)."'" : "null");
$sql .= ", ".($this->note_public ? "'".$this->db->escape($this->note_public)."'" : "null"); $sql .= ", ".($this->note_public ? "'".$this->db->escape($this->note_public)."'" : "null");
$sql .= ", ".($this->ref_client ? "'".$this->db->escape($this->ref_client)."'" : "null"); $sql .= ", ".($this->ref_customer ? "'".$this->db->escape($this->ref_customer)."'" : ($this->ref_client ? "'".$this->db->escape($this->ref_client)."'" : "null"));
$sql .= ", ".($this->fk_account > 0 ? $this->fk_account : 'NULL'); $sql .= ", ".($this->fk_account > 0 ? $this->fk_account : 'NULL');
$sql .= ", ".($this->module_source ? "'".$this->db->escape($this->module_source)."'" : "null"); $sql .= ", ".($this->module_source ? "'".$this->db->escape($this->module_source)."'" : "null");
$sql .= ", ".($this->pos_source != '' ? "'".$this->db->escape($this->pos_source)."'" : "null"); $sql .= ", ".($this->pos_source != '' ? "'".$this->db->escape($this->pos_source)."'" : "null");

View File

@@ -264,12 +264,23 @@ class CMailFile
// This convert an embedd file with src="/viewimage.php?modulepart... into a cid link // This convert an embedd file with src="/viewimage.php?modulepart... into a cid link
// TODO Exclude viewimage used for the read tracker ? // TODO Exclude viewimage used for the read tracker ?
$findimg = $this->findHtmlImages($dolibarr_main_data_root.'/medias'); $findimg = $this->findHtmlImages($dolibarr_main_data_root.'/medias');
if ($findimg<0) {
dol_syslog("CMailFile::CMailfile: Error on findHtmlImages");
$this->error = 'ErrorInAddAttachementsImageBaseOnMedia';
return;
}
} }
if (!empty($conf->global->MAIN_MAIL_ADD_INLINE_IMAGES_IF_DATA)) { if (!empty($conf->global->MAIN_MAIL_ADD_INLINE_IMAGES_IF_DATA)) {
// Search into the body for <img src="data:image/ext;base64,..." to replace them with an embedded file // Search into the body for <img src="data:image/ext;base64,..." to replace them with an embedded file
// This convert an embedded file with src="data:image... into a cid link + attached file // This convert an embedded file with src="data:image... into a cid link + attached file
$findimg = $this->findHtmlImagesIsSrcData($upload_dir_tmp); $resultImageData = $this->findHtmlImagesIsSrcData($upload_dir_tmp);
if ($resultImageData<0) {
dol_syslog("CMailFile::CMailfile: Error on findHtmlImagesInSrcData");
$this->error = 'ErrorInAddAttachementsImageBaseOnMedia';
return;
}
$findimg += $resultImageData;
} }
// Set atleastoneimage if there is at least one embedded file (into ->html_images) // Set atleastoneimage if there is at least one embedded file (into ->html_images)
@@ -1892,7 +1903,7 @@ class CMailFile
// We search (into mail body this->html), if we find some strings like "... file=xxx.img" // We search (into mail body this->html), if we find some strings like "... file=xxx.img"
// For example when: // For example when:
// <img alt="" src="/viewimage.php?modulepart=medias&amp;entity=1&amp;file=image/picture.jpg" style="height:356px; width:1040px" /> // <img alt="" src="/src="data:image....;base64,...." />
$matches = array(); $matches = array();
preg_match_all('/src="data:image\/('.implode('|', $extensions).');base64,([^"]+)"/Ui', $this->html, $matches); // If "xxx.ext" or 'xxx.ext' found preg_match_all('/src="data:image\/('.implode('|', $extensions).');base64,([^"]+)"/Ui', $this->html, $matches); // If "xxx.ext" or 'xxx.ext' found
@@ -1903,7 +1914,7 @@ class CMailFile
return -1; return -1;
} }
$i = 0; $i = count($this->html_images);
foreach ($matches[1] as $key => $ext) { foreach ($matches[1] as $key => $ext) {
// We save the image to send in disk // We save the image to send in disk
$filecontent = $matches[2][$key]; $filecontent = $matches[2][$key];

View File

@@ -72,7 +72,7 @@ if (GETPOST('button_removefilter_x', 'alpha') || GETPOST('button_removefilter.x'
$search_all = ""; $search_all = "";
$search_ref = ""; $search_ref = "";
$search_company = ""; $search_company = "";
$search_thirdparty = ""; $search_thirdparty = "";
$search_name = ""; $search_name = "";
$search_amount = ""; $search_amount = "";
$search_status = ''; $search_status = '';
@@ -135,7 +135,10 @@ $sql .= " p.rowid as pid, p.ref, p.title, p.public";
$sqlfields = $sql; // $sql fields to remove for count total $sqlfields = $sql; // $sql fields to remove for count total
$sql .= " FROM ".MAIN_DB_PREFIX."don as d LEFT JOIN ".MAIN_DB_PREFIX."projet AS p"; $sql .= " FROM ".MAIN_DB_PREFIX."don as d LEFT JOIN ".MAIN_DB_PREFIX."projet AS p";
$sql .= " ON p.rowid = d.fk_projet WHERE d.entity IN (".getEntity('donation').")"; $sql .= " ON p.rowid = d.fk_projet";
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . "societe AS s ON s.rowid = d.fk_soc";
$sql .= " WHERE d.entity IN (". getEntity('donation') . ")";
if ($search_status != '' && $search_status != '-4') { if ($search_status != '' && $search_status != '-4') {
$sql .= " AND d.fk_statut IN (".$db->sanitize($search_status).")"; $sql .= " AND d.fk_statut IN (".$db->sanitize($search_status).")";
} }
@@ -148,6 +151,9 @@ if (trim($search_all) != '') {
if (trim($search_company) != '') { if (trim($search_company) != '') {
$sql .= natural_search('d.societe', $search_company); $sql .= natural_search('d.societe', $search_company);
} }
if (trim($search_thirdparty) != '') {
$sql .= natural_search("s.nom", $search_thirdparty);
}
if (trim($search_name) != '') { if (trim($search_name) != '') {
$sql .= natural_search(array('d.lastname', 'd.firstname'), $search_name); $sql .= natural_search(array('d.lastname', 'd.firstname'), $search_name);
} }

View File

@@ -246,23 +246,23 @@ class Odf
break; break;
case 'strong': case 'strong':
case 'b': case 'b':
$odtResult .= '<text:span text:style-name="boldText">' . ($tag['children'] != null ? $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations) : $this->encode_chars($tag['innerText'], $encode, $charset)) . '</text:span>'; $odtResult .= '<text:span text:style-name="boldText">' . ($tag['children'] != null ? $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations, $encode) : $this->encode_chars($tag['innerText'], $encode, $charset)) . '</text:span>';
break; break;
case 'i': case 'i':
case 'em': case 'em':
$odtResult .= '<text:span text:style-name="italicText">' . ($tag['children'] != null ? $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations) : $this->encode_chars($tag['innerText'], $encode, $charset)) . '</text:span>'; $odtResult .= '<text:span text:style-name="italicText">' . ($tag['children'] != null ? $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations, $encode) : $this->encode_chars($tag['innerText'], $encode, $charset)) . '</text:span>';
break; break;
case 'u': case 'u':
$odtResult .= '<text:span text:style-name="underlineText">' . ($tag['children'] != null ? $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations) : $this->encode_chars($tag['innerText'], $encode, $charset)) . '</text:span>'; $odtResult .= '<text:span text:style-name="underlineText">' . ($tag['children'] != null ? $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations, $encode) : $this->encode_chars($tag['innerText'], $encode, $charset)) . '</text:span>';
break; break;
case 's': case 's':
$odtResult .= '<text:span text:style-name="strikethroughText">' . ($tag['children'] != null ? $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations) : $this->encode_chars($tag['innerText'], $encode, $charset)) . '</text:span>'; $odtResult .= '<text:span text:style-name="strikethroughText">' . ($tag['children'] != null ? $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations, $encode) : $this->encode_chars($tag['innerText'], $encode, $charset)) . '</text:span>';
break; break;
case 'sub': case 'sub':
$odtResult .= '<text:span text:style-name="subText">' . ($tag['children'] != null ? $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations) : $this->encode_chars($tag['innerText'], $encode, $charset)) . '</text:span>'; $odtResult .= '<text:span text:style-name="subText">' . ($tag['children'] != null ? $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations, $encode) : $this->encode_chars($tag['innerText'], $encode, $charset)) . '</text:span>';
break; break;
case 'sup': case 'sup':
$odtResult .= '<text:span text:style-name="supText">' . ($tag['children'] != null ? $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations) : $this->encode_chars($tag['innerText'], $encode, $charset)) . '</text:span>'; $odtResult .= '<text:span text:style-name="supText">' . ($tag['children'] != null ? $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations, $encode) : $this->encode_chars($tag['innerText'], $encode, $charset)) . '</text:span>';
break; break;
case 'span': case 'span':
if (isset($tag['attributes']['style'])) { if (isset($tag['attributes']['style'])) {
@@ -299,12 +299,12 @@ class Odf
// Generate a unique id for the style (using microtime and random because some CPUs are really fast...) // Generate a unique id for the style (using microtime and random because some CPUs are really fast...)
$key = floatval(str_replace('.', '', microtime(true))) + rand(0, 10); $key = floatval(str_replace('.', '', microtime(true))) + rand(0, 10);
$customStyles[$key] = $odtStyles; $customStyles[$key] = $odtStyles;
$odtResult .= '<text:span text:style-name="customStyle' . $key . '">' . ($tag['children'] != null ? $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations) : $this->encode_chars($tag['innerText'], $encode, $charset)) . '</text:span>'; $odtResult .= '<text:span text:style-name="customStyle' . $key . '">' . ($tag['children'] != null ? $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations, $encode) : $this->encode_chars($tag['innerText'], $encode, $charset)) . '</text:span>';
} }
} }
break; break;
default: default:
$odtResult .= $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations); $odtResult .= $this->_replaceHtmlWithOdtTag($tag['children'], $customStyles, $fontDeclarations, $encode);
break; break;
} }
} }

View File

@@ -5133,6 +5133,7 @@ div.ui-tooltip.mytooltip {
color: var(--tooltipfontcolor); color: var(--tooltipfontcolor);
line-height: 1.6em; line-height: 1.6em;
min-width: 550px; min-width: 550px;
pointer-events: none;
} }
<?php <?php

View File

@@ -24,18 +24,19 @@
* \remarks To run this script as CLI: phpunit filename.php * \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 //define('TEST_DB_FORCE_TYPE','mysql'); // This is to force using mysql driver
//require_once 'PHPUnit/Autoload.php'; //require_once 'PHPUnit/Autoload.php';
require_once dirname(__FILE__).'/../../htdocs/master.inc.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/class/CMailFile.class.php';
require_once dirname(__FILE__) . '/../../htdocs/core/lib/files.lib.php';
if (empty($user->id)) { if (empty($user->id)) {
print "Load permissions for admin user nb 1\n"; print "Load permissions for admin user nb 1\n";
$user->fetch(1); $user->fetch(1);
$user->getrights(); $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 * @backupGlobals disabled
* @backupStaticAttributes enabled * @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 class CMailFileTest extends PHPUnit\Framework\TestCase
{ {
@@ -64,13 +65,13 @@ class CMailFileTest extends PHPUnit\Framework\TestCase
parent::__construct($name); parent::__construct($name);
//$this->sharedFixture //$this->sharedFixture
global $conf,$user,$langs,$db; global $conf, $user, $langs, $db;
$this->savconf=$conf; $this->savconf = $conf;
$this->savuser=$user; $this->savuser = $user;
$this->savlangs=$langs; $this->savlangs = $langs;
$this->savdb=$db; $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 " - db ".$db->db;
print "\n"; print "\n";
} }
@@ -82,23 +83,23 @@ class CMailFileTest extends PHPUnit\Framework\TestCase
*/ */
public static function setUpBeforeClass(): void 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. $db->begin(); // This is to have all actions inside a transaction even if test launched without suite.
print __METHOD__."\n"; print __METHOD__ . "\n";
} }
/** /**
* tearDownAfterClass * tearDownAfterClass
* *
* @return void * @return void
*/ */
public static function tearDownAfterClass(): void public static function tearDownAfterClass(): void
{ {
global $conf,$user,$langs,$db; global $conf, $user, $langs, $db;
$db->rollback(); $db->rollback();
print __METHOD__."\n"; print __METHOD__ . "\n";
} }
/** /**
@@ -108,24 +109,25 @@ class CMailFileTest extends PHPUnit\Framework\TestCase
*/ */
protected function setUp(): void protected function setUp(): void
{ {
global $conf,$user,$langs,$db; global $conf, $user, $langs, $db;
$conf=$this->savconf; $conf = $this->savconf;
$user=$this->savuser; $user = $this->savuser;
$langs=$this->savlangs; $langs = $this->savlangs;
$db=$this->savdb; $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 * End phpunit tests
* *
* @return void * @return void
*/ */
protected function tearDown(): void protected function tearDown(): void
{ {
print __METHOD__."\n"; print __METHOD__ . "\n";
} }
/** /**
@@ -135,16 +137,16 @@ class CMailFileTest extends PHPUnit\Framework\TestCase
*/ */
public function testCMailFileText() public function testCMailFileText()
{ {
global $conf,$user,$langs,$db; global $conf, $user, $langs, $db;
$conf=$this->savconf; $conf = $this->savconf;
$user=$this->savuser; $user = $this->savuser;
$langs=$this->savlangs; $langs = $this->savlangs;
$db=$this->savdb; $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(); $result = $localobject->sendfile();
print __METHOD__." result=".$result."\n"; print __METHOD__ . " result=" . $result . "\n";
$this->assertFalse($result); // False because mail send disabled $this->assertFalse($result); // False because mail send disabled
return $result; return $result;
@@ -157,54 +159,115 @@ class CMailFileTest extends PHPUnit\Framework\TestCase
*/ */
public function testCMailFileStatic() public function testCMailFileStatic()
{ {
global $conf,$user,$langs,$db; global $conf, $user, $langs, $db;
$conf=$this->savconf; $conf = $this->savconf;
$user=$this->savuser; $user = $this->savuser;
$langs=$this->savlangs; $langs = $this->savlangs;
$db=$this->savdb; $db = $this->savdb;
$localobject=new CMailFile('', '', '', ''); $localobject = new CMailFile('', '', '', '');
$src='John Doe <john@doe.com>'; $src = 'John Doe <john@doe.com>';
$result=$localobject->getValidAddress($src, 0); $result = $localobject->getValidAddress($src, 0);
print __METHOD__." result=".$result."\n"; print __METHOD__ . " result=" . $result . "\n";
$this->assertEquals($result, 'John Doe <john@doe.com>'); $this->assertEquals($result, 'John Doe <john@doe.com>');
$src='John Doe <john@doe.com>'; $src = 'John Doe <john@doe.com>';
$result=$localobject->getValidAddress($src, 1); $result = $localobject->getValidAddress($src, 1);
print __METHOD__." result=".$result."\n"; print __METHOD__ . " result=" . $result . "\n";
$this->assertEquals($result, '<john@doe.com>'); $this->assertEquals($result, '<john@doe.com>');
$src='John Doe <john@doe.com>'; $src = 'John Doe <john@doe.com>';
$result=$localobject->getValidAddress($src, 2); $result = $localobject->getValidAddress($src, 2);
print __METHOD__." result=".$result."\n"; print __METHOD__ . " result=" . $result . "\n";
$this->assertEquals($result, 'john@doe.com'); $this->assertEquals($result, 'john@doe.com');
$src='John Doe <john@doe.com>'; $src = 'John Doe <john@doe.com>';
$result=$localobject->getValidAddress($src, 3, 0); $result = $localobject->getValidAddress($src, 3, 0);
print __METHOD__." result=".$result."\n"; print __METHOD__ . " result=" . $result . "\n";
$this->assertEquals($result, '"John Doe" <john@doe.com>'); $this->assertEquals($result, '"John Doe" <john@doe.com>');
$src='John Doe <john@doe.com>'; $src = 'John Doe <john@doe.com>';
$result=$localobject->getValidAddress($src, 3, 1); $result = $localobject->getValidAddress($src, 3, 1);
print __METHOD__." result=".$result."\n"; print __METHOD__ . " result=" . $result . "\n";
$this->assertEquals($result, '"=?UTF-8?B?Sm9obiBEb2U=?=" <john@doe.com>'); $this->assertEquals($result, '"=?UTF-8?B?Sm9obiBEb2U=?=" <john@doe.com>');
$src='John Doe <john@doe.com>'; $src = 'John Doe <john@doe.com>';
$result=$localobject->getValidAddress($src, 4); $result = $localobject->getValidAddress($src, 4);
print __METHOD__." result=".$result."\n"; print __METHOD__ . " result=" . $result . "\n";
$this->assertEquals($result, 'John Doe'); $this->assertEquals($result, 'John Doe');
$src='John Doe <john@doe.com>, John Doe2 <john@doe3.com>, John Doe3 <john@doe2.com>'; $src = 'John Doe <john@doe.com>, John Doe2 <john@doe3.com>, John Doe3 <john@doe2.com>';
$result=$localobject->getValidAddress($src, 4); $result = $localobject->getValidAddress($src, 4);
print __METHOD__." result=".$result."\n"; print __METHOD__ . " result=" . $result . "\n";
$this->assertEquals($result, 'John Doe,John Doe2,John Doe3'); $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>'; $src = 'John Doe <john@doe.com>, John Doe2 <john@doe3.com>, John Doe3 <john@doe2.com>';
$result=$localobject->getValidAddress($src, 4, 0, 2); $result = $localobject->getValidAddress($src, 4, 0, 2);
print __METHOD__." result=".$result."\n"; print __METHOD__ . " result=" . $result . "\n";
$this->assertEquals($result, 'John Doe,John Doe2...'); $this->assertEquals($result, 'John Doe,John Doe2...');
return $result; 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&amp;entity=1&amp;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;
}
} }