mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2025-05-31 14:54:34 -04:00
Fixes for chart tests
This commit is contained in:
parent
c60045da58
commit
38031ec7a3
@ -12,6 +12,7 @@
|
|||||||
namespace App\Http\Controllers;
|
namespace App\Http\Controllers;
|
||||||
|
|
||||||
use App\Http\Requests\Chart\ShowChartRequest;
|
use App\Http\Requests\Chart\ShowChartRequest;
|
||||||
|
use App\Services\Chart\ChartService;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
|
|
||||||
@ -25,8 +26,8 @@ class ChartController extends BaseController
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @OA\Post(
|
* @OA\Post(
|
||||||
* path="/api/v1/charts",
|
* path="/api/v1/charts/totals",
|
||||||
* operationId="getCharts",
|
* operationId="getChartTotals",
|
||||||
* tags={"charts"},
|
* tags={"charts"},
|
||||||
* summary="Get chart data",
|
* summary="Get chart data",
|
||||||
* description="Get chart data",
|
* description="Get chart data",
|
||||||
@ -67,10 +68,11 @@ class ChartController extends BaseController
|
|||||||
* @param Request $request
|
* @param Request $request
|
||||||
* @return Response|mixed
|
* @return Response|mixed
|
||||||
*/
|
*/
|
||||||
public function index(ShowChartRequest $request)
|
public function totals(ShowChartRequest $request)
|
||||||
{
|
{
|
||||||
|
$cs = new ChartService(auth()->user()->company());
|
||||||
|
|
||||||
return response()->json([],200);
|
return response()->json($cs->totals($request->input('start_date'), $request->input('end_date')),200);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -29,6 +29,22 @@ class ShowChartRequest extends Request
|
|||||||
public function rules()
|
public function rules()
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
'start_date' => 'date',
|
||||||
|
'end_date' => 'date',
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function prepareForValidation()
|
||||||
|
{
|
||||||
|
$input = $this->all();
|
||||||
|
|
||||||
|
if(!array_key_exists('start_date', $input))
|
||||||
|
$input['start_date'] = now()->subDays(20);
|
||||||
|
|
||||||
|
if(!array_key_exists('end_date', $input))
|
||||||
|
$input['end_date'] = now();
|
||||||
|
|
||||||
|
$this->replace($input);
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -50,7 +50,7 @@ class ChartService
|
|||||||
->where('company_id', $this->company->id)
|
->where('company_id', $this->company->id)
|
||||||
->where('is_deleted', 0)
|
->where('is_deleted', 0)
|
||||||
->distinct()
|
->distinct()
|
||||||
->get(['currency_id']);
|
->pluck('currency_id as id');
|
||||||
|
|
||||||
/* Merge and filter by unique */
|
/* Merge and filter by unique */
|
||||||
$currencies = $currencies->merge($expense_currencies)->unique();
|
$currencies = $currencies->merge($expense_currencies)->unique();
|
||||||
@ -72,10 +72,11 @@ class ChartService
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
public function totals($start_date, $end_date)
|
public function totals($start_date, $end_date) :array
|
||||||
{
|
{
|
||||||
$data = [];
|
$data = [];
|
||||||
|
|
||||||
|
$data['currencies'] = $this->getCurrencyCodes();
|
||||||
$data['revenue'] = $this->getRevenue($start_date, $end_date);
|
$data['revenue'] = $this->getRevenue($start_date, $end_date);
|
||||||
$data['outstanding'] = $this->getOutstanding($start_date, $end_date);
|
$data['outstanding'] = $this->getOutstanding($start_date, $end_date);
|
||||||
$data['expenses'] = $this->getExpenses($start_date, $end_date);
|
$data['expenses'] = $this->getExpenses($start_date, $end_date);
|
||||||
@ -110,7 +111,7 @@ class ChartService
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getRevenue($start_date, $end_date)
|
private function getRevenue($start_date, $end_date) :array
|
||||||
{
|
{
|
||||||
$revenue = $this->getRevenueQuery($start_date, $end_date);
|
$revenue = $this->getRevenueQuery($start_date, $end_date);
|
||||||
$revenue = $this->parseTotals($revenue);
|
$revenue = $this->parseTotals($revenue);
|
||||||
@ -119,7 +120,7 @@ class ChartService
|
|||||||
return $revenue;
|
return $revenue;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getOutstanding($start_date, $end_date)
|
private function getOutstanding($start_date, $end_date) :array
|
||||||
{
|
{
|
||||||
$outstanding = $this->getOutstandingQuery($start_date, $end_date);
|
$outstanding = $this->getOutstandingQuery($start_date, $end_date);
|
||||||
$outstanding = $this->parseTotals($outstanding);
|
$outstanding = $this->parseTotals($outstanding);
|
||||||
@ -128,16 +129,15 @@ class ChartService
|
|||||||
return $outstanding;
|
return $outstanding;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getExpenses($start_date, $end_date)
|
private function getExpenses($start_date, $end_date) :array
|
||||||
{
|
{
|
||||||
$expenses = $this->getExpenseQuery($start_date, $end_date);
|
$expenses = $this->getExpenseQuery($start_date, $end_date);
|
||||||
$expenses = $this->parseTotals($expenses);
|
$expenses = $this->parseTotals($expenses);
|
||||||
$expenses = $this->addCountryCodes($expenses);
|
$expenses = $this->addCountryCodes($expenses);
|
||||||
|
|
||||||
return $expenses;
|
return $expenses;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function parseTotals($data_set)
|
private function parseTotals($data_set) :array
|
||||||
{
|
{
|
||||||
/* Find the key where the company currency amount lives*/
|
/* Find the key where the company currency amount lives*/
|
||||||
$c_key = array_search($this->company->id , array_column($data_set, 'currency_id'));
|
$c_key = array_search($this->company->id , array_column($data_set, 'currency_id'));
|
||||||
@ -160,22 +160,25 @@ class ChartService
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private function addCountryCodes($data_set)
|
private function addCountryCodes($data_set) :array
|
||||||
{
|
{
|
||||||
|
|
||||||
$currencies = Cache::get('currencies');
|
$currencies = Cache::get('currencies');
|
||||||
|
|
||||||
foreach($data_set as $key => $value)
|
foreach($data_set as $key => $value)
|
||||||
{
|
{
|
||||||
$data_set[$key]['code'] = $this->getCode($currencies, $value);
|
$data_set[$key]->currency_id = str_replace('"', '', $value->currency_id);
|
||||||
|
$data_set[$key]->code = $this->getCode($currencies, $data_set[$key]->currency_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $data_set;
|
return $data_set;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getCode($currencies, $currency_id)
|
private function getCode($currencies, $currency_id) :string
|
||||||
{
|
{
|
||||||
|
nlog($currency_id);
|
||||||
|
|
||||||
$currency = $currencies->filter(function ($item) use($currency_id) {
|
$currency = $currencies->filter(function ($item) use($currency_id) {
|
||||||
return $item->id == $currency_id;
|
return $item->id == $currency_id;
|
||||||
})->first();
|
})->first();
|
||||||
|
@ -31,6 +31,9 @@ Route::group(['middleware' => ['api_db', 'token_auth', 'locale'], 'prefix' => 'a
|
|||||||
Route::get('activities', 'ActivityController@index');
|
Route::get('activities', 'ActivityController@index');
|
||||||
Route::get('activities/download_entity/{activity}', 'ActivityController@downloadHistoricalEntity');
|
Route::get('activities/download_entity/{activity}', 'ActivityController@downloadHistoricalEntity');
|
||||||
|
|
||||||
|
|
||||||
|
Route::post('charts/totals', 'ChartController@totals')->name('chart.totals');
|
||||||
|
|
||||||
Route::post('claim_license', 'LicenseController@index')->name('license.index');
|
Route::post('claim_license', 'LicenseController@index')->name('license.index');
|
||||||
|
|
||||||
Route::resource('clients', 'ClientController'); // name = (clients. index / create / show / update / destroy / edit
|
Route::resource('clients', 'ClientController'); // name = (clients. index / create / show / update / destroy / edit
|
||||||
|
@ -12,8 +12,10 @@ namespace Tests\Unit\Chart;
|
|||||||
|
|
||||||
use App\DataMapper\ClientSettings;
|
use App\DataMapper\ClientSettings;
|
||||||
use App\Models\Client;
|
use App\Models\Client;
|
||||||
|
use App\Models\Invoice;
|
||||||
use App\Services\Chart\ChartService;
|
use App\Services\Chart\ChartService;
|
||||||
use App\Utils\Ninja;
|
use App\Utils\Ninja;
|
||||||
|
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
||||||
use Tests\MockAccountData;
|
use Tests\MockAccountData;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
|
|
||||||
@ -24,6 +26,7 @@ use Tests\TestCase;
|
|||||||
class ChartCurrencyTest extends TestCase
|
class ChartCurrencyTest extends TestCase
|
||||||
{
|
{
|
||||||
use MockAccountData;
|
use MockAccountData;
|
||||||
|
use DatabaseTransactions;
|
||||||
|
|
||||||
public function setUp() :void
|
public function setUp() :void
|
||||||
{
|
{
|
||||||
@ -32,6 +35,42 @@ class ChartCurrencyTest extends TestCase
|
|||||||
$this->makeTestData();
|
$this->makeTestData();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testRevenueValues()
|
||||||
|
{
|
||||||
|
|
||||||
|
Invoice::factory()->create([
|
||||||
|
'client_id' => $this->client->id,
|
||||||
|
'user_id' => $this->user->id,
|
||||||
|
'company_id' => $this->company->id,
|
||||||
|
'paid_to_date' => 100,
|
||||||
|
'status_id' => 4,
|
||||||
|
'date' => now(),
|
||||||
|
'due_date'=> now(),
|
||||||
|
'number' => 'db_record'
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->assertDatabaseHas('invoices', ['number' => 'db_record']);
|
||||||
|
|
||||||
|
$cs = new ChartService($this->company);
|
||||||
|
nlog($cs->getRevenueQuery(now()->subDays(20)->format('Y-m-d'), now()->addDays(100)->format('Y-m-d')));
|
||||||
|
|
||||||
|
$data = [
|
||||||
|
'start_date' => now()->subDays(30)->format('Y-m-d'),
|
||||||
|
'end_date' => now()->addDay()->format('Y-m-d')
|
||||||
|
];
|
||||||
|
|
||||||
|
$response = $this->withHeaders([
|
||||||
|
'X-API-SECRET' => config('ninja.api_secret'),
|
||||||
|
'X-API-TOKEN' => $this->token,
|
||||||
|
])->post('/api/v1/charts/totals', $data);
|
||||||
|
|
||||||
|
$response->assertStatus(200);
|
||||||
|
|
||||||
|
nlog($response->json());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public function testgetCurrencyCodes()
|
public function testgetCurrencyCodes()
|
||||||
{
|
{
|
||||||
$settings = ClientSettings::defaults();
|
$settings = ClientSettings::defaults();
|
||||||
@ -61,6 +100,23 @@ class ChartCurrencyTest extends TestCase
|
|||||||
$this->assertFalse(in_array("AUD", $cs->getCurrencyCodes()));
|
$this->assertFalse(in_array("AUD", $cs->getCurrencyCodes()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testGetChartTotalsApi()
|
||||||
|
{
|
||||||
|
|
||||||
|
$data = [
|
||||||
|
'start_date' => now()->subDays(30)->format('Y-m-d'),
|
||||||
|
'end_date' => now()->format('Y-m-d')
|
||||||
|
];
|
||||||
|
|
||||||
|
$response = $this->withHeaders([
|
||||||
|
'X-API-SECRET' => config('ninja.api_secret'),
|
||||||
|
'X-API-TOKEN' => $this->token,
|
||||||
|
])->post('/api/v1/charts/totals', $data);
|
||||||
|
|
||||||
|
$response->assertStatus(200);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public function testClientServiceDataSetBuild()
|
public function testClientServiceDataSetBuild()
|
||||||
{
|
{
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user