ChooseTest.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 ChooseTest extends TestCase
  8. {
  9. protected function setUp(): void
  10. {
  11. Functions::setCompatibilityMode(Functions::COMPATIBILITY_EXCEL);
  12. }
  13. /**
  14. * @dataProvider providerCHOOSE
  15. *
  16. * @param mixed $expectedResult
  17. */
  18. public function testCHOOSE($expectedResult, ...$args): void
  19. {
  20. $result = LookupRef::CHOOSE(...$args);
  21. self::assertEquals($expectedResult, $result);
  22. }
  23. public function providerCHOOSE(): array
  24. {
  25. return require 'tests/data/Calculation/LookupRef/CHOOSE.php';
  26. }
  27. /**
  28. * @dataProvider providerChooseArray
  29. */
  30. public function testChooseArray(array $expectedResult, string $values, array $selections): void
  31. {
  32. $calculation = Calculation::getInstance();
  33. $selections = implode(',', $selections);
  34. $formula = "=CHOOSE({$values}, {$selections})";
  35. $result = $calculation->_calculateFormulaValue($formula);
  36. self::assertEquals($expectedResult, $result);
  37. }
  38. public function providerChooseArray(): array
  39. {
  40. return [
  41. 'row vector' => [
  42. [['Orange', 'Blue', 'Yellow']],
  43. '{2, 5, 3}',
  44. ['"Red"', '"Orange"', '"Yellow"', '"Green"', '"Blue"'],
  45. ],
  46. ];
  47. }
  48. }