46 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace PhpOffice\PhpSpreadsheetTests\Writer\Xls;
 | |
| 
 | |
| use PhpOffice\PhpSpreadsheet\IOFactory;
 | |
| use PhpOffice\PhpSpreadsheet\NamedRange;
 | |
| use PhpOffice\PhpSpreadsheet\Shared\File;
 | |
| use PHPUnit\Framework\TestCase;
 | |
| 
 | |
| class FormulaErrTest extends TestCase
 | |
| {
 | |
|     protected function tearDown(): void
 | |
|     {
 | |
|         $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);
 | |
|     }
 | |
| }
 | 
