LookupTest.php 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. <?php
  2. namespace PhpOffice\PhpSpreadsheetTests\Calculation\Functions\LookupRef;
  3. use PhpOffice\PhpSpreadsheet\Calculation\Calculation;
  4. use PhpOffice\PhpSpreadsheet\Calculation\Functions;
  5. use PhpOffice\PhpSpreadsheet\Calculation\LookupRef;
  6. use PHPUnit\Framework\TestCase;
  7. class LookupTest extends TestCase
  8. {
  9. protected function setUp(): void
  10. {
  11. Functions::setCompatibilityMode(Functions::COMPATIBILITY_EXCEL);
  12. }
  13. /**
  14. * @dataProvider providerLOOKUP
  15. *
  16. * @param mixed $expectedResult
  17. */
  18. public function testLOOKUP($expectedResult, ...$args): void
  19. {
  20. $result = LookupRef::LOOKUP(...$args);
  21. self::assertEquals($expectedResult, $result);
  22. }
  23. public function providerLOOKUP(): array
  24. {
  25. return require 'tests/data/Calculation/LookupRef/LOOKUP.php';
  26. }
  27. /**
  28. * @dataProvider providerLookupArray
  29. */
  30. public function testLookupArray(array $expectedResult, string $values, string $lookup, string $return): void
  31. {
  32. $calculation = Calculation::getInstance();
  33. $formula = "=LOOKUP({$values}, {$lookup}, {$return})";
  34. $result = $calculation->_calculateFormulaValue($formula);
  35. self::assertEquals($expectedResult, $result);
  36. }
  37. public function providerLookupArray(): array
  38. {
  39. return [
  40. 'row vector' => [
  41. [['Orange', 'Green', 'Red']],
  42. '{4.19, 5.77, 4.14}',
  43. '{4.14; 4.19; 5.17; 5.77; 6.39}',
  44. '{"Red"; "Orange"; "Yellow"; "Green"; "Blue"}',
  45. ],
  46. ];
  47. }
  48. }