MatchTest.php 1.5 KB

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