2021-12-17 08:04:34 +01: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://opensource.org/licenses/AAL
|
|
|
|
*/
|
|
|
|
namespace Tests\Unit;
|
|
|
|
|
|
|
|
use App\Models\Currency;
|
|
|
|
use App\Models\Invoice;
|
|
|
|
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
|
|
|
use Illuminate\Support\Facades\Cache;
|
|
|
|
use Tests\MockAccountData;
|
|
|
|
use Tests\TestCase;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @test
|
|
|
|
*/
|
|
|
|
class RedisVsDatabaseTest extends TestCase
|
|
|
|
{
|
|
|
|
|
|
|
|
public function setUp() :void
|
|
|
|
{
|
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
// $this->markTestSkipped('Skip test no company gateways installed');
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testRedisSpeed()
|
|
|
|
{
|
|
|
|
$start = microtime(true);
|
|
|
|
|
|
|
|
$currencies = Cache::get('currencies');
|
|
|
|
|
2021-12-17 08:57:26 +01:00
|
|
|
$currencies->filter(function ($item) {
|
2021-12-17 08:04:34 +01:00
|
|
|
return $item->id == 17;
|
|
|
|
})->first();
|
|
|
|
|
2021-12-17 08:57:26 +01:00
|
|
|
nlog(microtime(true) - $start);
|
2021-12-17 08:04:34 +01:00
|
|
|
|
|
|
|
$this->assertTrue(true);
|
|
|
|
// nlog($total_time);
|
|
|
|
//0.0012960433959961
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testDbSpeed()
|
|
|
|
{
|
|
|
|
$start = microtime(true);
|
|
|
|
|
|
|
|
$currency = Currency::find(17);
|
|
|
|
|
2021-12-17 08:57:26 +01:00
|
|
|
nlog(microtime(true) - $start);
|
2021-12-17 08:04:34 +01:00
|
|
|
|
|
|
|
$this->assertTrue(true);
|
|
|
|
// nlog($total_time);
|
|
|
|
// 0.006152868270874
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|