2012-10-25 10:44:47 +00:00
|
|
|
<?php
|
|
|
|
|
2016-08-25 04:53:15 +00:00
|
|
|
namespace PhpSpreadsheetTests\Cell;
|
2016-03-22 14:35:50 +00:00
|
|
|
|
2016-08-16 15:33:57 +00:00
|
|
|
use PhpSpreadsheet\CachedObjectStorage\Memory;
|
2016-08-16 14:24:47 +00:00
|
|
|
use PhpSpreadsheet\Cell;
|
|
|
|
use PhpSpreadsheet\Cell\AdvancedValueBinder;
|
|
|
|
use PhpSpreadsheet\Cell\DataType;
|
2016-08-16 15:33:57 +00:00
|
|
|
use PhpSpreadsheet\Shared\StringHelper;
|
|
|
|
use PhpSpreadsheet\Style\NumberFormat;
|
|
|
|
use PhpSpreadsheet\Worksheet;
|
2016-08-14 04:08:43 +00:00
|
|
|
|
2016-03-22 14:35:50 +00:00
|
|
|
class AdvancedValueBinderTest extends \PHPUnit_Framework_TestCase
|
2012-10-25 10:44:47 +00:00
|
|
|
{
|
|
|
|
public function setUp()
|
|
|
|
{
|
2016-08-16 14:24:47 +00:00
|
|
|
if (!defined('PHPSPREADSHEET_ROOT')) {
|
|
|
|
define('PHPSPREADSHEET_ROOT', APPLICATION_PATH . '/');
|
2012-10-25 10:44:47 +00:00
|
|
|
}
|
2016-08-16 15:33:57 +00:00
|
|
|
require_once PHPSPREADSHEET_ROOT . '/Bootstrap.php';
|
2012-10-25 10:44:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function provider()
|
|
|
|
{
|
2016-08-14 04:08:43 +00:00
|
|
|
if (!class_exists(NumberFormat::class)) {
|
2015-05-17 16:34:30 +00:00
|
|
|
$this->setUp();
|
2012-10-25 10:44:47 +00:00
|
|
|
}
|
2016-08-14 04:08:43 +00:00
|
|
|
$currencyUSD = NumberFormat::FORMAT_CURRENCY_USD_SIMPLE;
|
|
|
|
$currencyEURO = str_replace('$', '€', NumberFormat::FORMAT_CURRENCY_USD_SIMPLE);
|
2012-10-25 10:44:47 +00:00
|
|
|
|
2016-08-16 15:33:57 +00:00
|
|
|
return [
|
|
|
|
['10%', 0.1, NumberFormat::FORMAT_PERCENTAGE_00, ',', '.', '$'],
|
|
|
|
['$10.11', 10.11, $currencyUSD, ',', '.', '$'],
|
|
|
|
['$1,010.12', 1010.12, $currencyUSD, ',', '.', '$'],
|
|
|
|
['$20,20', 20.2, $currencyUSD, '.', ',', '$'],
|
|
|
|
['$2.020,20', 2020.2, $currencyUSD, '.', ',', '$'],
|
|
|
|
['€2.020,20', 2020.2, $currencyEURO, '.', ',', '€'],
|
|
|
|
['€ 2.020,20', 2020.2, $currencyEURO, '.', ',', '€'],
|
|
|
|
['€2,020.22', 2020.22, $currencyEURO, ',', '.', '€'],
|
|
|
|
];
|
2012-10-25 10:44:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @dataProvider provider
|
|
|
|
*/
|
|
|
|
public function testCurrency($value, $valueBinded, $format, $thousandsSeparator, $decimalSeparator, $currencyCode)
|
|
|
|
{
|
2013-02-21 11:29:32 +00:00
|
|
|
$sheet = $this->getMock(
|
2016-08-14 04:08:43 +00:00
|
|
|
Worksheet::class,
|
2016-08-16 15:33:57 +00:00
|
|
|
['getStyle', 'getNumberFormat', 'setFormatCode', 'getCellCacheController']
|
2015-05-17 13:00:02 +00:00
|
|
|
);
|
2016-08-14 04:08:43 +00:00
|
|
|
$cache = $this->getMockBuilder(Memory::class)
|
2015-05-17 13:00:02 +00:00
|
|
|
->disableOriginalConstructor()
|
|
|
|
->getMock();
|
2013-02-21 11:29:32 +00:00
|
|
|
$cache->expects($this->any())
|
|
|
|
->method('getParent')
|
|
|
|
->will($this->returnValue($sheet));
|
2012-10-25 10:44:47 +00:00
|
|
|
|
|
|
|
$sheet->expects($this->once())
|
|
|
|
->method('getStyle')
|
|
|
|
->will($this->returnSelf());
|
|
|
|
$sheet->expects($this->once())
|
|
|
|
->method('getNumberFormat')
|
|
|
|
->will($this->returnSelf());
|
|
|
|
$sheet->expects($this->once())
|
|
|
|
->method('setFormatCode')
|
|
|
|
->with($format)
|
|
|
|
->will($this->returnSelf());
|
2013-02-21 11:29:32 +00:00
|
|
|
$sheet->expects($this->any())
|
|
|
|
->method('getCellCacheController')
|
|
|
|
->will($this->returnValue($cache));
|
2012-10-25 10:44:47 +00:00
|
|
|
|
2016-08-14 04:08:43 +00:00
|
|
|
StringHelper::setCurrencyCode($currencyCode);
|
|
|
|
StringHelper::setDecimalSeparator($decimalSeparator);
|
|
|
|
StringHelper::setThousandsSeparator($thousandsSeparator);
|
2012-10-25 10:44:47 +00:00
|
|
|
|
2016-08-14 04:08:43 +00:00
|
|
|
$cell = new Cell(null, DataType::TYPE_STRING, $sheet);
|
2012-10-25 10:44:47 +00:00
|
|
|
|
2016-08-14 04:08:43 +00:00
|
|
|
$binder = new AdvancedValueBinder();
|
2012-10-25 10:44:47 +00:00
|
|
|
$binder->bindValue($cell, $value);
|
|
|
|
$this->assertEquals($valueBinded, $cell->getValue());
|
|
|
|
}
|
2015-05-17 16:34:30 +00:00
|
|
|
}
|