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
{
public $agent_cost_calc;
public function __construct()
{
$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
{
private $calculate_agent_cost;
private $csv_cost_calc;
public function __construct()
{
$this->calculate_agent_cost = env('GITEA_CALCULATE_AGENT_COST');
$this->csv_cost_calc = new CsvCostCalc();
}
function handle_agent_issue($agents_issue_time, $time)

View File

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

View File

@ -2,6 +2,9 @@
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 PHPUnit\Framework\TestCase;
@ -9,12 +12,15 @@ class CsvDataHandlingTest extends TestCase
{
protected function setUp(): void
{
$this->csv_data_handling = new CsvDataHandling();
$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
$agents_issue_time = [];
@ -41,7 +47,7 @@ class CsvDataHandlingTest extends TestCase
$this->assertEquals(['agent1' => 8, 'agent2' => 10], $result);
}
public function getIssueTotalTime()
public function testGetIssueTotalTime()
{
// Arrange
$issue_time = [
@ -60,40 +66,64 @@ class CsvDataHandlingTest extends TestCase
public function testHandle_csv_time()
{
// Arrange
$array = [
'total_time_cost' => 0,
'agent_cost' => 0,
'Progetto' => ' test',
'#' => 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 = [
['id' => 1, 'title' => 'Issue 1'],
['id' => 2, 'title' => 'Issue 2'],
];
$issue = [];
$issue_time = [
['user_name' => 'agent1', 'time' => 5],
['user_name' => 'agent1', 'time' => 3],
['user_name' => 'agent2', 'time' => 10],
[
'id' => 1,
'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 = [
['name' => 'agent1', 'cost_per_hour' => 50],
['name' => 'agent2', 'cost_per_hour' => 60],
];
$company_agents = ["Agent1", "Agent2"];
$this->csv_data_handling->method('total_time_cost')
->with($array, 18)
->willReturn(['total_time_cost' => 1800]);
$expected = array_merge($array, [
'Tempo totale' => '00:18:00',
'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
$result = $this->csv_data_handling->handle_csv_time($array, $issue, $issue_time, $company_agents);
// 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()
{
$issue = [
'repository' => ['name' => 'test'],
'number' => 0,

View File

@ -1,15 +1,105 @@
<?php
namespace Tests\Http\Controllers;
namespace Tests\Controllers;
use App\Http\Controllers\IssueValidationController;
use Exception;
use PHPUnit\Framework\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));
}
}