1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-14 15:13:29 +01:00
invoiceninja/tests/Unit/TaskRoundingTest.php

242 lines
6.3 KiB
PHP
Raw Normal View History

2024-05-07 01:59:00 +02:00
<?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 Tests\TestCase;
2024-05-09 23:19:52 +02:00
use App\Models\Task;
use App\Models\Client;
use Tests\MockAccountData;
use App\Utils\Traits\MakesHash;
use App\DataMapper\ClientSettings;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Support\Facades\Session;
use Illuminate\Foundation\Testing\DatabaseTransactions;
2024-05-07 01:59:00 +02:00
/**
* @test
*/
class TaskRoundingTest extends TestCase
{
public int $task_round_to_nearest = 1;
public bool $task_round_up = true;
2024-05-09 23:19:52 +02:00
use MakesHash;
use DatabaseTransactions;
use MockAccountData;
private $faker;
protected function setUp() :void
2024-05-07 01:59:00 +02:00
{
parent::setUp();
2024-05-09 23:19:52 +02:00
$this->makeTestData();
Session::start();
$this->faker = \Faker\Factory::create();
Model::reguard();
2024-05-07 01:59:00 +02:00
}
2024-06-12 06:52:26 +02:00
public function testRoundDownToMinute()
{
$start_time = 1718071646;
$end_time = 1718078906;
$this->task_round_to_nearest = 60;
$this->task_round_up = false;
$rounded = $start_time + 7260;
$this->assertEquals($rounded, $end_time);
$this->assertEquals($rounded, $this->roundTimeLog($start_time, $end_time));
}
2024-05-07 01:59:00 +02:00
public function testRoundUp()
{
$start_time = 1714942800;
$end_time = 1714943220; //7:07am
$this->task_round_to_nearest = 600;
//calculated time = 7:10am
$rounded = 1714943400;
$this->assertEquals($rounded, $this->roundTimeLog($start_time, $end_time));
}
2024-05-09 09:23:34 +02:00
public function testRoundUp2()
{
$start_time = 1715237056;
$end_time = $start_time + 60*7;
$this->task_round_to_nearest = 600;
$rounded = $start_time + 60*10;
$this->assertEquals($rounded, $this->roundTimeLog($start_time, $end_time));
}
public function testRoundUp3()
{
$start_time = 1715213100;
$end_time = $start_time + 60*15;
$this->task_round_to_nearest = 900;
$rounded = $start_time + 60*15;
$this->assertEquals($rounded, $this->roundTimeLog($start_time, $end_time));
2024-05-09 23:19:52 +02:00
// $s = \Carbon\Carbon::createFromTimestamp($start_time);
// $e = \Carbon\Carbon::createFromTimestamp($end_time);
// $x = \Carbon\Carbon::createFromTimestamp($rounded);
// echo $s->format('Y-m-d H:i:s').PHP_EOL;
// echo $e->format('Y-m-d H:i:s').PHP_EOL;
// echo $x->format('Y-m-d H:i:s').PHP_EOL;
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
}
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
public function testRoundUp4()
{
$start_time = 1715238000;
$end_time = 1715238900;
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
$this->task_round_to_nearest = 900;
$rounded = $start_time + 60*15;
// $s = \Carbon\Carbon::createFromTimestamp($start_time);
// $e = \Carbon\Carbon::createFromTimestamp($end_time);
// $x = \Carbon\Carbon::createFromTimestamp($rounded);
// echo $s->format('Y-m-d H:i:s').PHP_EOL;
// echo $e->format('Y-m-d H:i:s').PHP_EOL;
// echo $x->format('Y-m-d H:i:s').PHP_EOL;
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
$this->assertEquals($rounded, $this->roundTimeLog($start_time, $end_time));
2024-05-09 09:23:34 +02:00
}
2024-05-09 23:19:52 +02:00
public function testRoundingViaBulkAction()
{
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
$this->company->settings->default_task_rate = 41;
$this->company->settings->task_round_to_nearest = 900;
$this->company->settings->task_round_up = true;
$this->company->saveSettings($this->company->settings, $this->company);
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
$settings = ClientSettings::defaults();
$settings->default_task_rate = 41;
$settings->task_round_to_nearest = 900;
$settings->task_round_up = true;
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
$c = Client::factory()->create([
'user_id' => $this->user->id,
'company_id' => $this->company->id,
// 'settings' => $settings,
]);
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
$var = time()-800;
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
$data = [
'client_id' => $c->hashed_id,
'description' => 'Test Task',
'time_log' => '[[1681165417,1681165432,"sumtin",true],['.$var.',0]]',
'assigned_user' => [],
'project' => [],
'user' => [],
];
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
$response = $this->withHeaders([
'X-API-SECRET' => config('ninja.api_secret'),
'X-API-TOKEN' => $this->token,
])->postJson("/api/v1/tasks/", $data);
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
$response->assertStatus(200);
$arr = $response->json();
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
$i = $arr['data']['id'];
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
$data = [
'ids' => [$i],
'action' => 'stop'
];
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
$response = $this->withHeaders([
'X-API-SECRET' => config('ninja.api_secret'),
'X-API-TOKEN' => $this->token,
])->postJson("/api/v1/tasks/bulk", $data);
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
$response->assertStatus(200);
$arr = $response->json();
2024-05-09 09:23:34 +02:00
2024-05-09 23:19:52 +02:00
$task = Task::find($this->decodePrimaryKey($i));
}
2024-05-09 09:23:34 +02:00
2024-05-07 01:59:00 +02:00
public function testRoundDown()
{
$start_time = 1714942800;
$end_time = 1714943220; //7:07am
$this->task_round_to_nearest = 600;
$this->task_round_up = false;
//calculated time = 7:10am
$rounded = $start_time;
$this->assertEquals($rounded, $this->roundTimeLog($start_time, $end_time));
}
2024-06-12 06:52:26 +02:00
// public function roundTimeLog(int $start_time, int $end_time): int
// {
// if($this->task_round_to_nearest == 1)
// return $end_time;
// $interval = $end_time - $start_time;
// if($this->task_round_up)
// return $start_time + (int)ceil($interval/$this->task_round_to_nearest)*$this->task_round_to_nearest;
// return $start_time - (int)floor($interval/$this->task_round_to_nearest) * $this->task_round_to_nearest;
// }
2024-05-07 01:59:00 +02:00
public function roundTimeLog(int $start_time, int $end_time): int
{
2024-06-12 06:52:26 +02:00
if($this->task_round_to_nearest == 1 || $end_time == 0)
2024-05-07 01:59:00 +02:00
return $end_time;
$interval = $end_time - $start_time;
2024-06-12 06:52:26 +02:00
2024-05-07 01:59:00 +02:00
if($this->task_round_up)
return $start_time + (int)ceil($interval/$this->task_round_to_nearest)*$this->task_round_to_nearest;
2024-06-12 06:52:26 +02:00
if($interval <= $this->task_round_to_nearest)
return $start_time;
return $start_time + (int)floor($interval/$this->task_round_to_nearest) * $this->task_round_to_nearest;
2024-05-07 01:59:00 +02:00
}
2024-06-12 06:52:26 +02:00
2024-05-07 01:59:00 +02:00
}