Files
investbrain/tests/ImportExportTest.php
T

73 lines
2.0 KiB
PHP
Raw Normal View History

2024-10-28 19:20:52 -05:00
<?php
namespace Tests;
use App\Exports\BackupExport;
use App\Models\BackupImport as BackupImportModel;
2025-01-28 17:14:49 -06:00
use App\Models\Transaction;
use App\Models\User;
2024-10-28 19:20:52 -05:00
use Illuminate\Foundation\Testing\RefreshDatabase;
2025-01-28 17:14:49 -06:00
use Maatwebsite\Excel\Facades\Excel;
2024-10-28 19:20:52 -05:00
class ImportExportTest extends TestCase
{
use RefreshDatabase;
public function test_can_create_exports(): void
{
Excel::fake();
$this->actingAs($user = User::factory()->create());
Transaction::factory(5)->buy()->lastYear()->symbol('AAPL')->create();
2025-01-28 17:14:49 -06:00
Excel::download(new BackupExport, now()->format('Y_m_d').'_investbrain_backup.xlsx');
2024-10-28 19:20:52 -05:00
2025-01-28 17:14:49 -06:00
Excel::assertDownloaded(now()->format('Y_m_d').'_investbrain_backup.xlsx', function (BackupExport $export) {
2024-10-28 19:20:52 -05:00
return true;
});
}
public function test_backup_job_completes(): void
{
$this->actingAs($user = User::factory()->create());
$backup_job = BackupImportModel::create([
'user_id' => auth()->user()->id,
2025-01-28 17:14:49 -06:00
'path' => __DIR__.'/0000_00_00_import_test.xlsx',
2024-10-28 19:20:52 -05:00
]);
$backup_job->refresh();
$this->assertEquals('success', $backup_job->status);
}
public function test_backup_job_inserts_rows(): void
{
$this->actingAs($user = User::factory()->create());
BackupImportModel::create([
'user_id' => auth()->user()->id,
2025-01-28 17:14:49 -06:00
'path' => __DIR__.'/0000_00_00_import_test.xlsx',
2024-10-28 19:20:52 -05:00
]);
$this->assertEquals(3, $user->transactions->count());
}
public function test_backup_job_calculates_correct_holding_data(): void
{
$this->actingAs($user = User::factory()->create());
BackupImportModel::create([
'user_id' => auth()->user()->id,
2025-01-28 17:14:49 -06:00
'path' => __DIR__.'/0000_00_00_import_test.xlsx',
2024-10-28 19:20:52 -05:00
]);
$holding = $user->holdings->first();
$this->assertEquals('AAPL', $holding->symbol);
$this->assertEquals(6, $holding->quantity);
$this->assertEqualsWithDelta(233.33, $holding->average_cost_basis, 0.01);
}
}