88 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace PhpSpreadsheetTests\Cell;
 | |
| 
 | |
| use PhpSpreadsheet\Cell;
 | |
| use PhpSpreadsheet\Cell\DataType;
 | |
| use PhpSpreadsheet\Cell\DefaultValueBinder;
 | |
| use PhpSpreadsheet\RichText;
 | |
| 
 | |
| class DefaultValueBinderTest extends \PHPUnit_Framework_TestCase
 | |
| {
 | |
|     protected $cellStub;
 | |
| 
 | |
|     public function setUp()
 | |
|     {
 | |
|         if (!defined('PHPSPREADSHEET_ROOT')) {
 | |
|             define('PHPSPREADSHEET_ROOT', APPLICATION_PATH . '/');
 | |
|         }
 | |
|         require_once PHPSPREADSHEET_ROOT . '/Bootstrap.php';
 | |
|     }
 | |
| 
 | |
|     protected function createCellStub()
 | |
|     {
 | |
|         // Create a stub for the Cell class.
 | |
|         $this->cellStub = $this->getMockBuilder(Cell::class)
 | |
|             ->disableOriginalConstructor()
 | |
|             ->getMock();
 | |
|         // Configure the stub.
 | |
|         $this->cellStub->expects($this->any())
 | |
|              ->method('setValueExplicit')
 | |
|              ->will($this->returnValue(true));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @dataProvider binderProvider
 | |
|      */
 | |
|     public function testBindValue($value)
 | |
|     {
 | |
|         $this->createCellStub();
 | |
|         $binder = new DefaultValueBinder();
 | |
|         $result = $binder->bindValue($this->cellStub, $value);
 | |
|         $this->assertTrue($result);
 | |
|     }
 | |
| 
 | |
|     public function binderProvider()
 | |
|     {
 | |
|         return [
 | |
|             [null],
 | |
|             [''],
 | |
|             ['ABC'],
 | |
|             ['=SUM(A1:B2)'],
 | |
|             [true],
 | |
|             [false],
 | |
|             [123],
 | |
|             [-123.456],
 | |
|             ['123'],
 | |
|             ['-123.456'],
 | |
|             ['#REF!'],
 | |
|             [new \DateTime()],
 | |
|         ];
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @dataProvider providerDataTypeForValue
 | |
|      */
 | |
|     public function testDataTypeForValue()
 | |
|     {
 | |
|         list($args, $expectedResult) = func_get_args();
 | |
|         $result = call_user_func_array([DefaultValueBinder::class, 'dataTypeForValue'], $args);
 | |
|         $this->assertEquals($expectedResult, $result);
 | |
|     }
 | |
| 
 | |
|     public function providerDataTypeForValue()
 | |
|     {
 | |
|         return require 'data/Cell/DefaultValueBinder.php';
 | |
|     }
 | |
| 
 | |
|     public function testDataTypeForRichTextObject()
 | |
|     {
 | |
|         $objRichText = new RichText();
 | |
|         $objRichText->createText('Hello World');
 | |
| 
 | |
|         $expectedResult = DataType::TYPE_INLINE;
 | |
|         $result = DefaultValueBinder::dataTypeForValue($objRichText);
 | |
|         $this->assertEquals($expectedResult, $result);
 | |
|     }
 | |
| }
 | 
