mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-26 09:12:52 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			127 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			127 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Invoice Ninja (https://invoiceninja.com).
 | |
|  *
 | |
|  * @link https://github.com/invoiceninja/invoiceninja source repository
 | |
|  *
 | |
|  * @copyright Copyright (c) 2021. Invoice Ninja LLC (https://invoiceninja.com)
 | |
|  *
 | |
|  * @license https://www.elastic.co/licensing/elastic-license
 | |
|  */
 | |
| 
 | |
| namespace Tests\Unit;
 | |
| 
 | |
| use App\Utils\Number;
 | |
| use Tests\TestCase;
 | |
| 
 | |
| /**
 | |
|  * @test
 | |
|  * @covers  App\Utils\Number
 | |
|  */
 | |
| class NumberTest extends TestCase
 | |
| {
 | |
| 
 | |
|     public function testConvertDecimalCommaFloats()
 | |
|     {
 | |
|         $value = '22,00';
 | |
| 
 | |
|         $res = Number::parseFloat($value);
 | |
| 
 | |
|         $this->assertEquals(22.0, $res);
 | |
|         
 | |
|         $value = '22.00';
 | |
| 
 | |
|         $res = Number::parseFloat($value);
 | |
| 
 | |
|         $this->assertEquals(22.0, $res);
 | |
| 
 | |
|         $value = '1,000.00';
 | |
| 
 | |
|         $res = Number::parseFloat($value);
 | |
| 
 | |
|         $this->assertEquals(1000.0, $res);
 | |
| 
 | |
|         $value = '1.000,00';
 | |
| 
 | |
|         $res = Number::parseFloat($value);
 | |
| 
 | |
|         $this->assertEquals(1000.0, $res);
 | |
| 
 | |
|     }
 | |
|     public function testFloatPrecision()
 | |
|     {
 | |
|         $value = 1.1;
 | |
| 
 | |
|         $precision = (int) strpos(strrev($value), ".");
 | |
| 
 | |
|         $result =  round($value, $precision);
 | |
| 
 | |
|         $this->assertEquals(1.1, $result);
 | |
|     }
 | |
| 
 | |
| 
 | |
|     public function testFloatPrecision1()
 | |
|     {
 | |
|         $value = "1.1";
 | |
| 
 | |
|         $precision = (int) strpos(strrev($value), ".");
 | |
| 
 | |
|         $result =  round($value, $precision);
 | |
| 
 | |
|         $this->assertEquals(1.1, $result);
 | |
|     }
 | |
| 
 | |
| 
 | |
|     public function testFloatPrecision2()
 | |
|     {
 | |
|         $value = 9.975;
 | |
| 
 | |
|         $precision = (int) strpos(strrev($value), ".");
 | |
| 
 | |
|         $result =  round($value, $precision);
 | |
| 
 | |
|         $this->assertEquals(9.975, $result);
 | |
|     }
 | |
| 
 | |
|     public function testFloatPrecision3()
 | |
|     {
 | |
|         $value = "9.975";
 | |
| 
 | |
|         $precision = (int) strpos(strrev($value), ".");
 | |
| 
 | |
|         $result =  round($value, $precision);
 | |
| 
 | |
|         $this->assertEquals(9.975, $result);
 | |
|     }
 | |
| 
 | |
|     public function testRoundingThreeLow()
 | |
|     {
 | |
|         $rounded = Number::roundValue(3.144444444444, 3);
 | |
| 
 | |
|         $this->assertEquals(3.144, $rounded);
 | |
|     }
 | |
| 
 | |
|     public function testRoundingThreeHigh()
 | |
|     {
 | |
|         $rounded = Number::roundValue(3.144944444444, 3);
 | |
| 
 | |
|         $this->assertEquals(3.145, $rounded);
 | |
|     }
 | |
| 
 | |
|     public function testRoundingTwoLow()
 | |
|     {
 | |
|         $rounded = Number::roundValue(2.145);
 | |
| 
 | |
|         $this->assertEquals(2.15, $rounded);
 | |
|     }
 | |
| 
 | |
|     public function testParsingStringCurrency()
 | |
|     {
 | |
|         $amount = '€7,99';
 | |
| 
 | |
|         $converted_amount = Number::parseFloat($amount);
 | |
| 
 | |
|         $this->assertEquals(7.99, $converted_amount);
 | |
|     }
 | |
| }
 |