MRoundTest.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. <?php
  2. namespace PhpOffice\PhpSpreadsheetTests\Calculation\Functions\MathTrig;
  3. use PhpOffice\PhpSpreadsheet\Calculation\Calculation;
  4. class MRoundTest extends AllSetupTeardown
  5. {
  6. /**
  7. * @dataProvider providerMROUND
  8. *
  9. * @param mixed $expectedResult
  10. * @param mixed $formula
  11. */
  12. public function testMROUND($expectedResult, $formula): void
  13. {
  14. $this->mightHaveException($expectedResult);
  15. $sheet = $this->getSheet();
  16. $sheet->setCellValue('A2', 1.3);
  17. $sheet->setCellValue('A3', 2.7);
  18. $sheet->setCellValue('A4', -3.8);
  19. $sheet->setCellValue('A5', -5.2);
  20. $sheet->getCell('A1')->setValue("=MROUND($formula)");
  21. $result = $sheet->getCell('A1')->getCalculatedValue();
  22. self::assertEqualsWithDelta($expectedResult, $result, 1E-12);
  23. }
  24. public function providerMROUND(): array
  25. {
  26. return require 'tests/data/Calculation/MathTrig/MROUND.php';
  27. }
  28. /**
  29. * @dataProvider providerMRoundArray
  30. */
  31. public function testMRoundArray(array $expectedResult, string $argument1, string $argument2): void
  32. {
  33. $calculation = Calculation::getInstance();
  34. $formula = "=MROUND({$argument1},{$argument2})";
  35. $result = $calculation->_calculateFormulaValue($formula);
  36. self::assertEqualsWithDelta($expectedResult, $result, 1.0e-14);
  37. }
  38. public function providerMRoundArray(): array
  39. {
  40. return [
  41. 'first argument row vector' => [
  42. [[0.15, 1.375, 931.675, 3.15]],
  43. '{0.14527, 1.3725, 931.6829, 3.14159265}',
  44. '0.025',
  45. ],
  46. 'first argument column vector' => [
  47. [[0.15], [1.375], [931.675], [3.15]],
  48. '{0.14527; 1.3725; 931.6829; 3.14159265}',
  49. '0.025',
  50. ],
  51. 'first argument matrix' => [
  52. [[0.15, 1.375], [931.675, 3.15]],
  53. '{0.14527, 1.3725; 931.6829, 3.14159265}',
  54. '0.025',
  55. ],
  56. 'second argument row vector' => [
  57. [[123.125, 123.125, 123.1, 123.2, 125]],
  58. '123.12345',
  59. '{0.005, 0.025, 0.1, 0.2, 5}',
  60. ],
  61. 'second argument column vector' => [
  62. [[123.125], [123.125], [123.1], [123.2], [125]],
  63. '123.12345',
  64. '{0.005; 0.025; 0.1; 0.2; 5}',
  65. ],
  66. 'second argument matrix' => [
  67. [[123.125, 123.125], [123.2, 125.0]],
  68. '123.12345',
  69. '{0.005, 0.025; 0.2, 5}',
  70. ],
  71. 'A row and a column vector' => [
  72. [
  73. [0.145, 0.15, 0.2, 0.0],
  74. [1.375, 1.375, 1.4, 0.0],
  75. [931.685, 931.675, 931.6, 930.0],
  76. [3.14, 3.15, 3.2, 5.0],
  77. ],
  78. '{0.14527; 1.37250; 931.68290; 3.14159265}',
  79. '{0.005, 0.025, 0.2, 5}',
  80. ],
  81. 'Two row vectors' => [
  82. [[0.145, 1.375, 931.6, 5.0]],
  83. '{0.14527, 1.3725, 931.6, 3.14159265}',
  84. '{0.005, 0.025, 0.2, 5}',
  85. ],
  86. 'Two column vectors' => [
  87. [[0.145], [1.375], [931.6], [5.0]],
  88. '{0.14527; 1.37250; 931.6; 5}',
  89. '{0.005; 0.025; 0.2; 5}',
  90. ],
  91. ];
  92. }
  93. }