NumberLibTest.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  1. <?php
  2. App::uses('NumberLib', 'Tools.Utility');
  3. App::uses('MyCakeTestCase', 'Tools.TestSuite');
  4. class NumberLibTest extends MyCakeTestCase {
  5. public $NumberLib = null;
  6. public function setUp() {
  7. parent::setUp();
  8. //$this->NumberLib = new NumberLib();
  9. }
  10. public function testMoney() {
  11. $is = NumberLib::money(22.11);
  12. $expected = '22,11 €';
  13. $this->assertSame($expected, $is);
  14. $is = NumberLib::money(-22.11);
  15. $expected = '-22,11 €';
  16. $this->assertSame($expected, $is);
  17. }
  18. public function testPrice() {
  19. $is = NumberLib::price(22.11);
  20. $expected = '22,11 €';
  21. $this->assertSame($expected, $is);
  22. $is = NumberLib::price(-22.11);
  23. $expected = '0,00 €';
  24. $this->assertSame($expected, $is);
  25. }
  26. public function testCurrency() {
  27. $is = NumberLib::currency(22.11);
  28. $expected = '22,11 €';
  29. $this->assertSame($expected, $is);
  30. $is = NumberLib::currency(-22.11);
  31. $expected = '-22,11 €';
  32. $this->assertSame($expected, $is);
  33. $is = NumberLib::currency(-22.11, 'EUR', array('signed'=>true));
  34. $expected = '-22,11 €';
  35. $this->assertSame($expected, $is);
  36. $is = NumberLib::currency(22.11, 'EUR', array('signed'=>true));
  37. $expected = '+22,11 €';
  38. $this->assertSame($expected, $is);
  39. }
  40. /**
  41. * 2012-04-06 ms
  42. */
  43. public function testToPercentage() {
  44. $is = NumberLib::toPercentage(22.11, 2, '.');
  45. $expected = '22.11%';
  46. $this->assertSame($expected, $is);
  47. $is = NumberLib::toPercentage(22.11, 2, ',');
  48. $expected = '22,11%';
  49. $this->assertSame($expected, $is);
  50. $is = NumberLib::toPercentage(22.11, 0, ',');
  51. $expected = '22%';
  52. $this->assertSame($expected, $is);
  53. }
  54. /**
  55. *2011-04-14 lb
  56. */
  57. public function testRoundTo() {
  58. //increment = 10
  59. $values = array(
  60. '22' => 20,
  61. '15' => 20,
  62. '3.4' => 0,
  63. '6' => 10,
  64. '-3.12' => 0,
  65. '-10' => -10
  66. );
  67. foreach ($values as $was => $expected) {
  68. $is = NumberLib::roundTo($was, 10);
  69. $this->assertSame($expected, $is, null, $was);
  70. }
  71. //increment = 0.1
  72. $values2 = array(
  73. '22' => 22.0,
  74. '15.234' => 15.2,
  75. '3.4' => 3.4,
  76. '6.131' => 6.1,
  77. '-3.17' => -3.2,
  78. '-10.99' => -11.0
  79. );
  80. foreach ($values2 as $was => $expected) {
  81. $is = NumberLib::roundTo($was, 0.1);
  82. $this->assertSame($expected, $is, null, $was);
  83. }
  84. }
  85. /**
  86. *2011-04-14 lb
  87. */
  88. public function testRoundUpTo() {
  89. //increment = 10
  90. $values = array(
  91. '22.765' => 30.0,
  92. '15.22' => 20.0,
  93. '3.4' => 10.0,
  94. '6' => 10.0,
  95. '-3.12' => -0.0,
  96. '-10' => -10.0
  97. );
  98. foreach ($values as $was => $expected) {
  99. $is = NumberLib::roundUpTo($was, 10);
  100. $this->assertSame($expected, $is, null, $was);
  101. }
  102. //increment = 5
  103. $values = array(
  104. '22' => 25.0,
  105. '15.234' => 20.0,
  106. '3.4' => 5.0,
  107. '6.131' => 10.0,
  108. '-3.17' => -0.0,
  109. '-10.99' => -10.0
  110. );
  111. foreach ($values as $was => $expected) {
  112. $is = NumberLib::roundUpTo($was, 5);
  113. $this->assertSame($expected, $is, null, $was);
  114. }
  115. }
  116. /**
  117. *2011-04-14 lb
  118. */
  119. public function testRoundDownTo() {
  120. //increment = 10
  121. $values = array(
  122. '22.765' => 20.0,
  123. '15.22' => 10.0,
  124. '3.4' => 0.0,
  125. '6' => 0.0,
  126. '-3.12' => -10.0,
  127. '-10' => -10.0
  128. );
  129. foreach ($values as $was => $expected) {
  130. $is = NumberLib::roundDownTo($was, 10);
  131. $this->assertSame($expected, $is, null, $was);
  132. }
  133. //increment = 3
  134. $values = array(
  135. '22' => 21.0,
  136. '15.234' => 15.0,
  137. '3.4' => 3.0,
  138. '6.131' => 6.0,
  139. '-3.17' => -6.0,
  140. '-10.99' => -12.0
  141. );
  142. foreach ($values as $was => $expected) {
  143. $is = NumberLib::roundDownTo($was, 3);
  144. $this->assertSame($expected, $is, null, $was);
  145. }
  146. }
  147. /**
  148. *2011-04-15 lb
  149. */
  150. public function testGetDecimalPlaces() {
  151. $values = array(
  152. '100' => -2,
  153. '0.0001' => 4,
  154. '10' => -1,
  155. '0.1' => 1,
  156. '1' => 0,
  157. '0.001' => 3
  158. );
  159. foreach ($values as $was => $expected) {
  160. $is = NumberLib::getDecimalPlaces($was, 10);
  161. $this->assertSame($expected, $is); //, null, $was
  162. }
  163. }
  164. /**
  165. * Test spacer format options for currency() method
  166. *
  167. * @return void
  168. */
  169. public function testCurrencySpacer() {
  170. $this->skipIf(true, 'TODO');
  171. $result = NumberLib::currency('4.111', 'EUR');
  172. $expected = '€4,11';
  173. $this->assertEquals($expected, $result);
  174. $result = NumberLib::currency('4.111', 'EUR', array('spacer' => false));
  175. $expected = '€4,11';
  176. $this->assertEquals($expected, $result);
  177. $result = NumberLib::currency('4.111', 'EUR', array('spacer' => true));
  178. $expected = '€ 4,11';
  179. $this->assertEquals($expected, $result);
  180. $result = NumberLib::currency('-4.111', 'GBP', array('spacer' => false, 'negative' => '-'));
  181. $expected = '-£4.11';
  182. $this->assertEquals($expected, $result);
  183. $result = NumberLib::currency('-4.111', 'GBP', array('spacer' => true, 'negative' => '-'));
  184. $expected = '-£ 4.11';
  185. $this->assertEquals($expected, $result);
  186. $result = NumberLib::currency('4.111', 'EUR', array('spacer' => '&nbsp;', 'escape' => false));
  187. $expected = '€&nbsp;4,11';
  188. $this->assertEquals($expected, $result);
  189. }
  190. }