Keep big integer as integer instead of lossely casting to float
Closes #874 Fixes #1135
This commit is contained in:
		
							parent
							
								
									d7d67ff39b
								
							
						
					
					
						commit
						5441b2fa73
					
				| @ -17,6 +17,7 @@ and this project adheres to [Semantic Versioning](https://semver.org). | ||||
| - Formula Parser: Wrong line count for stuff like "MyOtherSheet!A:D" [#1215](https://github.com/PHPOffice/PhpSpreadsheet/issues/1215) | ||||
| - Call garbage collector after removing a column to prevent stale cached values | ||||
| - Trying to remove a column that doesn't exist deletes the latest column | ||||
| - Keep big integer as integer instead of lossely casting to float [#874](https://github.com/PHPOffice/PhpSpreadsheet/pull/874) | ||||
| 
 | ||||
| ## [1.9.0] - 2019-08-17 | ||||
| 
 | ||||
|  | ||||
| @ -217,7 +217,7 @@ class Cell | ||||
| 
 | ||||
|                 break; | ||||
|             case DataType::TYPE_NUMERIC: | ||||
|                 $this->value = (float) $pValue; | ||||
|                 $this->value = 0 + $pValue; | ||||
| 
 | ||||
|                 break; | ||||
|             case DataType::TYPE_FORMULA: | ||||
|  | ||||
							
								
								
									
										30
									
								
								tests/PhpSpreadsheetTests/Cell/CellTest.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								tests/PhpSpreadsheetTests/Cell/CellTest.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,30 @@ | ||||
| <?php | ||||
| 
 | ||||
| namespace PhpOffice\PhpSpreadsheetTests\Cell; | ||||
| 
 | ||||
| use PhpOffice\PhpSpreadsheet\Spreadsheet; | ||||
| use PHPUnit\Framework\TestCase; | ||||
| 
 | ||||
| class CellTest extends TestCase | ||||
| { | ||||
|     /** | ||||
|      * @dataProvider providerSetValueExplicit | ||||
|      * | ||||
|      * @param mixed $expected | ||||
|      * @param mixed $value | ||||
|      * @param string $dataType | ||||
|      */ | ||||
|     public function testSetValueExplicit($expected, $value, string $dataType) | ||||
|     { | ||||
|         $spreadsheet = new Spreadsheet(); | ||||
|         $cell = $spreadsheet->getActiveSheet()->getCell('A1'); | ||||
|         $cell->setValueExplicit($value, $dataType); | ||||
| 
 | ||||
|         self::assertSame($expected, $cell->getValue()); | ||||
|     } | ||||
| 
 | ||||
|     public function providerSetValueExplicit() | ||||
|     { | ||||
|         return require 'data/Cell/SetValueExplicit.php'; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										26
									
								
								tests/data/Cell/SetValueExplicit.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								tests/data/Cell/SetValueExplicit.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,26 @@ | ||||
| <?php | ||||
| 
 | ||||
| use PhpOffice\PhpSpreadsheet\Cell\DataType; | ||||
| 
 | ||||
| return [ | ||||
|     [ | ||||
|         1234567890123456789, | ||||
|         '01234567890123456789', | ||||
|         DataType::TYPE_NUMERIC, | ||||
|     ], | ||||
|     [ | ||||
|         123.456, | ||||
|         '123.456', | ||||
|         DataType::TYPE_NUMERIC, | ||||
|     ], | ||||
|     [ | ||||
|         1234567890123456789, | ||||
|         1234567890123456789, | ||||
|         DataType::TYPE_NUMERIC, | ||||
|     ], | ||||
|     [ | ||||
|         123.456, | ||||
|         123.456, | ||||
|         DataType::TYPE_NUMERIC, | ||||
|     ], | ||||
| ]; | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Adrien Crivelli
						Adrien Crivelli