| 
									
										
										
										
											2020-01-04 17:34:21 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-27 10:28:36 +00:00
										 |  |  | namespace PhpOffice\PhpSpreadsheetTests\Writer\Xls; | 
					
						
							| 
									
										
										
										
											2020-01-04 17:34:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | use PhpOffice\PhpSpreadsheet\IOFactory; | 
					
						
							|  |  |  | use PhpOffice\PhpSpreadsheet\NamedRange; | 
					
						
							|  |  |  | use PhpOffice\PhpSpreadsheet\Shared\File; | 
					
						
							|  |  |  | use PHPUnit\Framework\TestCase; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class FormulaErrTest extends TestCase | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-04-27 10:28:36 +00:00
										 |  |  |     protected function tearDown(): void | 
					
						
							| 
									
										
										
										
											2020-01-04 17:34:21 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |         $filename = tempnam(File::sysGetTempDir(), 'phpspreadsheet-test'); | 
					
						
							|  |  |  |         if (file_exists($filename)) { | 
					
						
							|  |  |  |             unlink($filename); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testFormulaError() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $obj = new \PhpOffice\PhpSpreadsheet\Spreadsheet(); | 
					
						
							|  |  |  |         $sheet0 = $obj->setActiveSheetIndex(0); | 
					
						
							|  |  |  |         $sheet0->setCellValue('A1', 2); | 
					
						
							|  |  |  |         $obj->addNamedRange(new NamedRange('DEFNAM', $sheet0, 'A1')); | 
					
						
							|  |  |  |         $sheet0->setCellValue('B1', '=2*DEFNAM'); | 
					
						
							|  |  |  |         $sheet0->setCellValue('C1', '=DEFNAM=2'); | 
					
						
							|  |  |  |         $sheet0->setCellValue('D1', '=CONCAT("X",DEFNAM)'); | 
					
						
							|  |  |  |         $writer = IOFactory::createWriter($obj, 'Xls'); | 
					
						
							|  |  |  |         $filename = tempnam(File::sysGetTempDir(), 'phpspreadsheet-test'); | 
					
						
							|  |  |  |         $writer->save($filename); | 
					
						
							|  |  |  |         $reader = IOFactory::createReader('Xls'); | 
					
						
							|  |  |  |         $robj = $reader->load($filename); | 
					
						
							|  |  |  |         $sheet0 = $robj->setActiveSheetIndex(0); | 
					
						
							|  |  |  |         $a1 = $sheet0->getCell('A1')->getCalculatedValue(); | 
					
						
							|  |  |  |         self::assertEquals(2, $a1); | 
					
						
							|  |  |  |         $b1 = $sheet0->getCell('B1')->getCalculatedValue(); | 
					
						
							|  |  |  |         self::assertEquals(4, $b1); | 
					
						
							|  |  |  |         $c1 = $sheet0->getCell('C1')->getCalculatedValue(); | 
					
						
							|  |  |  |         $tru = true; | 
					
						
							|  |  |  |         self::assertEquals($tru, $c1); | 
					
						
							|  |  |  |         $d1 = $sheet0->getCell('D1')->getCalculatedValue(); | 
					
						
							|  |  |  |         self::assertEquals('X2', $d1); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |