add: more tests

This commit is contained in:
Michael 2024-08-14 13:52:30 +02:00
parent fcd76cf130
commit 3d08b14f11
6 changed files with 154 additions and 36 deletions

View File

@ -8,6 +8,8 @@ use RuntimeException;
class CsvAgentCost class CsvAgentCost
{ {
public $agent_cost_calc;
public function __construct() public function __construct()
{ {
$this->internal_percentage_to_deduct = (float) getenv('PRICE_INTERNAL_PERCENTAGE_TO_DEDUCT', null); $this->internal_percentage_to_deduct = (float) getenv('PRICE_INTERNAL_PERCENTAGE_TO_DEDUCT', null);

View File

@ -6,13 +6,11 @@ use App\Http\Controllers\CsvController\CsvCostCalc\CsvCostCalc;
class CsvDataHandling class CsvDataHandling
{ {
private $calculate_agent_cost;
private $csv_cost_calc;
public function __construct() public function __construct()
{ {
$this->calculate_agent_cost = env('GITEA_CALCULATE_AGENT_COST'); $this->calculate_agent_cost = env('GITEA_CALCULATE_AGENT_COST');
$this->csv_cost_calc = new CsvCostCalc(); $this->csv_cost_calc = new CsvCostCalc();
} }
function handle_agent_issue($agents_issue_time, $time) function handle_agent_issue($agents_issue_time, $time)

View File

@ -9,7 +9,7 @@ class IssueValidationController extends Controller
public function __construct() public function __construct()
{} {}
private function date_to_datetime(string $date) function date_to_datetime(string $date)
{ {
$date = str_replace('/', '-', $date); $date = str_replace('/', '-', $date);
$datetime = new DateTime($date); $datetime = new DateTime($date);
@ -17,7 +17,7 @@ class IssueValidationController extends Controller
return $datetime->format('Y-m-d H:i:s'); return $datetime->format('Y-m-d H:i:s');
} }
private function search_requested_by($issue_labels){ function search_requested_by($issue_labels){
foreach ($issue_labels as $key => $label) { foreach ($issue_labels as $key => $label) {
if (strpos($label['name'],'RequestBy') !== false) { if (strpos($label['name'],'RequestBy') !== false) {
return true; return true;
@ -26,7 +26,7 @@ class IssueValidationController extends Controller
return false; return false;
} }
private function get_issue_total_time(array $issue_time) function get_issue_total_time(array $issue_time)
{ {
$count = 0; $count = 0;
foreach ($issue_time as $time) { foreach ($issue_time as $time) {
@ -36,7 +36,7 @@ class IssueValidationController extends Controller
return $count; return $count;
} }
private function check_issue_is_billed(array $issue_labels, array $issue_time): bool { function check_issue_is_billed(array $issue_labels, array $issue_time): bool {
$issue_time = $this->get_issue_total_time($issue_time); $issue_time = $this->get_issue_total_time($issue_time);
$issue_time = (gmdate('H:i:s', $issue_time) !== '00:00:00'); $issue_time = (gmdate('H:i:s', $issue_time) !== '00:00:00');
$label_requested_by_index = $this->search_requested_by($issue_labels); $label_requested_by_index = $this->search_requested_by($issue_labels);

View File

@ -2,6 +2,9 @@
namespace Tests\Http\Controllers\CsvController; namespace Tests\Http\Controllers\CsvController;
use App\Http\Controllers\CsvController\CsvCostCalc\CsvAgentCost;
use App\Http\Controllers\CsvController\CsvCostCalc\CsvCostCalc;
use App\Http\Controllers\CsvController\CsvCostCalc\CsvMinuteCostCalc;
use App\Http\Controllers\CsvController\CsvDataHandling; use App\Http\Controllers\CsvController\CsvDataHandling;
use PHPUnit\Framework\TestCase; use PHPUnit\Framework\TestCase;
@ -9,12 +12,15 @@ class CsvDataHandlingTest extends TestCase
{ {
protected function setUp(): void protected function setUp(): void
{ {
$this->csv_data_handling = new CsvDataHandling();
$this->mockCsvMinuteCostCalc = $this->createMock(CsvMinuteCostCalc::class); $this->mockCsvMinuteCostCalc = $this->createMock(CsvMinuteCostCalc::class);
$this->csv_data_handling = new CsvDataHandling();
$this->csv_data_handling->csv_cost_calc->CsvTotalCostCalc->CsvMinuteCostCalc = $this->mockCsvMinuteCostCalc;
$this->csv_data_handling->csv_cost_calc->CsvAgentCost->CsvMinuteCostCalc = $this->mockCsvMinuteCostCalc;
$this->csv_data_handling->calculate_agent_cost = true; // Example percentage
$this->csv_data_handling->csv_cost_calc->CsvAgentCost->internal_percentage_to_deduct = 10; // Example percentage
} }
public function handleAgentIssue() public function testHandleAgentIssue()
{ {
// Arrange // Arrange
$agents_issue_time = []; $agents_issue_time = [];
@ -41,7 +47,7 @@ class CsvDataHandlingTest extends TestCase
$this->assertEquals(['agent1' => 8, 'agent2' => 10], $result); $this->assertEquals(['agent1' => 8, 'agent2' => 10], $result);
} }
public function getIssueTotalTime() public function testGetIssueTotalTime()
{ {
// Arrange // Arrange
$issue_time = [ $issue_time = [
@ -60,40 +66,64 @@ class CsvDataHandlingTest extends TestCase
public function testHandle_csv_time() public function testHandle_csv_time()
{ {
// Arrange
$array = [ $array = [
'total_time_cost' => 0, 'Progetto' => ' test',
'agent_cost' => 0, '#' => 169,
'Titolo' => 'Test',
'URL' => ' https://git.test.test/test/issues/169',
'Aperto_il' => ' 2024-07-19T10:43:07+02:00',
'Chiuso_il' => ' 2024-07-31T09:50:32+02:00',
'Etichette' => ' Priority/Medium,RequestBy/Customer,Status/Resolved,',
'Kind' => ',',
'Request By' => 'RequestBy/Client',
'Priority' => 'Priority/High',
]; ];
$issue = [ $issue = [];
['id' => 1, 'title' => 'Issue 1'],
['id' => 2, 'title' => 'Issue 2'],
];
$issue_time = [ $issue_time = [
['user_name' => 'agent1', 'time' => 5], [
['user_name' => 'agent1', 'time' => 3], 'id' => 1,
['user_name' => 'agent2', 'time' => 10], 'created' => "2024-07-24T18:48:42+02:00",
'time' => 600,
'user_id' => 8,
'user_name' => "Agent1",
'issue_id' => 1,
],
[
'id' => 2,
'created' => "2024-07-24T18:48:42+02:00",
'time' => 480,
'user_id' => 2,
'user_name' => "Agent2",
'issue_id' => 2,
],
]; ];
$company_agents = [ $company_agents = ["Agent1", "Agent2"];
['name' => 'agent1', 'cost_per_hour' => 50],
['name' => 'agent2', 'cost_per_hour' => 60],
];
$this->csv_data_handling->method('total_time_cost') $expected = array_merge($array, [
->with($array, 18) 'Tempo totale' => '00:18:00',
->willReturn(['total_time_cost' => 1800]); 'Costo totale' => 180.00,
'Agent1' => '00:10:00',
'Agent1 costo' => 90.00,
'Agent2' => '00:08:00',
'Agent2 costo' => 72.00,
]
);
$this->mockCsvMinuteCostCalc
->method('select_correct_cost')
->with('RequestBy/Client', 'Priority/High')
->willReturn(10); // Mocked return value
$this->csv_data_handling->method('agent_cost_calc')
->with($array, $company_agents, ['agent1' => 8, 'agent2' => 10])
->willReturn(['agent_cost' => 800]);
// Act // Act
$result = $this->csv_data_handling->handle_csv_time($array, $issue, $issue_time, $company_agents); $result = $this->csv_data_handling->handle_csv_time($array, $issue, $issue_time, $company_agents);
// Assert // Assert
$this->assertEquals(['total_time_cost' => 1800, 'agent_cost' => 800], $result); $this->assertEquals($expected, $result);
} }
} }

View File

@ -15,8 +15,6 @@ class CsvDataInitTest extends TestCase
public function testInitialize_csv_data() public function testInitialize_csv_data()
{ {
$issue = [ $issue = [
'repository' => ['name' => 'test'], 'repository' => ['name' => 'test'],
'number' => 0, 'number' => 0,

View File

@ -1,15 +1,105 @@
<?php <?php
namespace Tests\Http\Controllers; namespace Tests\Controllers;
use App\Http\Controllers\IssueValidationController; use App\Http\Controllers\IssueValidationController;
use Exception;
use PHPUnit\Framework\TestCase; use PHPUnit\Framework\TestCase;
class IssueValidationControllerTest extends TestCase class IssueValidationControllerTest extends TestCase
{ {
public function testHandle_single_issue() protected function setUp(): void
{ {
$this->issue_validation_controller = new IssueValidationController();
}
public function testValidDateConversion()
{
$this->assertEquals('2024-08-14 00:00:00', $this->issue_validation_controller->date_to_datetime('2024/08/14'));
$this->assertEquals('2024-12-31 00:00:00', $this->issue_validation_controller->date_to_datetime('2024/12/31'));
}
public function testInvalidDateFormat()
{
$this->expectException(Exception::class);
$this->issue_validation_controller->date_to_datetime('invalid-date');
}
public function testIssueIsBilled()
{
$labels = [['name' => 'RequestBy: User1']];
$issue_time = [['time' => 3600]]; // 1 hour
$this->assertTrue($this->issue_validation_controller->check_issue_is_billed($labels, $issue_time));
}
public function testIssueIsNotBilledDueToNoTime()
{
$labels = [['name' => 'RequestBy: User1']];
$issue_time = [['time' => 0]];
$this->assertFalse($this->issue_validation_controller->check_issue_is_billed($labels, $issue_time));
}
public function testIssueIsNotBilledDueToNoLabel()
{
$labels = [['name' => 'Bug']];
$issue_time = [['time' => 3600]];
$this->assertFalse($this->issue_validation_controller->check_issue_is_billed($labels, $issue_time));
}
public function testTotalTimeCalculation()
{
$issue_time = [['time' => 10], ['time' => 20], ['time' => 30]];
$this->assertEquals(60, $this->issue_validation_controller->get_issue_total_time($issue_time));
}
public function testEmptyTimeArray()
{
$issue_time = [];
$this->assertEquals(0, $this->issue_validation_controller->get_issue_total_time($issue_time));
}
public function testSingleTimeEntry()
{
$issue_time = [['time' => 15]];
$this->assertEquals(15, $this->issue_validation_controller->get_issue_total_time($issue_time));
}
public function testIssueWithinDateRangeAndBilled()
{
$issue = ['closed_at' => '2024-08-15T10:00:00Z', 'labels' => [['name' => 'RequestBy: User1']]];
$issue_time = [['time' => 3600]]; // 1 hour
$this->assertTrue($this->issue_validation_controller->handle_single_issue('2024-08-14', '2024-08-16', $issue, $issue_time));
}
public function testIssueOutsideDateRange()
{
$issue = ['closed_at' => '2024-08-13T10:00:00Z', 'labels' => [['name' => 'RequestBy: User1']]];
$issue_time = [['time' => 3600]];
$this->assertFalse($this->issue_validation_controller->handle_single_issue('2024-08-14', '2024-08-16', $issue, $issue_time));
}
public function testIssueNotBilled()
{
$issue = ['closed_at' => '2024-08-15T10:00:00Z', 'labels' => [['name' => 'Bug']]];
$issue_time = [['time' => 0]];
$this->assertFalse($this->issue_validation_controller->handle_single_issue('2024-08-14', '2024-08-16', $issue, $issue_time));
}
public function testLabelExists()
{
$labels = [['name' => 'RequestBy: User1'], ['name' => 'Bug']];
$this->assertTrue($this->issue_validation_controller->search_requested_by($labels));
}
public function testLabelDoesNotExist()
{
$labels = [['name' => 'Bug'], ['name' => 'Feature']];
$this->assertFalse($this->issue_validation_controller->search_requested_by($labels));
}
public function testEmptyLabels()
{
$labels = [];
$this->assertFalse($this->issue_validation_controller->search_requested_by($labels));
} }
} }