From 4af97321e9b9c55f90b21a613f0a90dd7d043aa4 Mon Sep 17 00:00:00 2001 From: Nabeel Shahzad Date: Thu, 16 Jan 2020 14:02:59 -0500 Subject: [PATCH 1/3] Fix subfleet not being attached to an airline on creation in import #479 --- app/Services/ImportExport/AircraftImporter.php | 13 ++++++++----- tests/ImporterTest.php | 9 ++++++--- 2 files changed, 14 insertions(+), 8 deletions(-) diff --git a/app/Services/ImportExport/AircraftImporter.php b/app/Services/ImportExport/AircraftImporter.php index 95d62e028..d062483c9 100644 --- a/app/Services/ImportExport/AircraftImporter.php +++ b/app/Services/ImportExport/AircraftImporter.php @@ -4,6 +4,7 @@ use App\Contracts\ImportExport; use App\Models\Aircraft; +use App\Models\Airline; use App\Models\Enums\AircraftState; use App\Models\Enums\AircraftStatus; use App\Models\Subfleet; @@ -32,7 +33,8 @@ class AircraftImporter extends ImportExport ]; /** - * Find the subfleet specified, or just create it on the fly + * Find the subfleet specified, or just create it on the fly and attach it to the + * first airline that's been found * * @param $type * @@ -40,11 +42,12 @@ class AircraftImporter extends ImportExport */ protected function getSubfleet($type) { - $subfleet = Subfleet::firstOrCreate([ + return Subfleet::firstOrCreate([ 'type' => $type, - ], ['name' => $type]); - - return $subfleet; + ], [ + 'name' => $type, + 'airline_id' => Airline::where('active', true)->first()->id, + ]); } /** diff --git a/tests/ImporterTest.php b/tests/ImporterTest.php index 3c8febb00..8fda44a26 100644 --- a/tests/ImporterTest.php +++ b/tests/ImporterTest.php @@ -564,7 +564,8 @@ public function testFlightImporterEmptyCustomFields(): void */ public function testAircraftImporter(): void { - $subfleet = factory(App\Models\Subfleet::class)->create(['type' => 'A32X']); + factory(App\Models\Airline::class)->create(); + // $subfleet = factory(App\Models\Subfleet::class)->create(['type' => 'A32X']); $file_path = base_path('tests/data/aircraft.csv'); $status = $this->importSvc->importAircraft($file_path); @@ -579,8 +580,10 @@ public function testAircraftImporter(): void $this->assertNotNull($aircraft); $this->assertNotNull($aircraft->hex_code); - $this->assertEquals($subfleet->id, $aircraft->id); - $this->assertEquals($subfleet->type, $aircraft->subfleet->type); + //$this->assertEquals($subfleet->id, $aircraft->id); + $this->assertNotNull($aircraft->subfleet); + $this->assertNotNull($aircraft->subfleet->airline); + $this->assertEquals('A32X', $aircraft->subfleet->type); $this->assertEquals('A320-211', $aircraft->name); $this->assertEquals('N309US', $aircraft->registration); $this->assertEquals(null, $aircraft->zfw); From 92f4e9de1233614119a03d1febb675301c2dc64d Mon Sep 17 00:00:00 2001 From: Nabeel Shahzad Date: Thu, 16 Jan 2020 14:05:15 -0500 Subject: [PATCH 2/3] Call airline name with optional() around subfleet --- resources/views/admin/subfleets/table.blade.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/resources/views/admin/subfleets/table.blade.php b/resources/views/admin/subfleets/table.blade.php index ccb49a809..b4bb41a76 100644 --- a/resources/views/admin/subfleets/table.blade.php +++ b/resources/views/admin/subfleets/table.blade.php @@ -15,7 +15,7 @@ {{ $subfleet->name }} - {{ $subfleet->airline->name }} + {{ optional($subfleet->airline)->name }} {{ $subfleet->type }} {{ $subfleet->aircraft->count() }} From b8277afafbb3f6ab6c9e14294b399fbee97161e1 Mon Sep 17 00:00:00 2001 From: Nabeel Shahzad Date: Thu, 16 Jan 2020 14:06:04 -0500 Subject: [PATCH 3/3] Minor cleanup --- tests/ImporterTest.php | 1 - 1 file changed, 1 deletion(-) diff --git a/tests/ImporterTest.php b/tests/ImporterTest.php index 8fda44a26..e7e5ff3c8 100644 --- a/tests/ImporterTest.php +++ b/tests/ImporterTest.php @@ -580,7 +580,6 @@ public function testAircraftImporter(): void $this->assertNotNull($aircraft); $this->assertNotNull($aircraft->hex_code); - //$this->assertEquals($subfleet->id, $aircraft->id); $this->assertNotNull($aircraft->subfleet); $this->assertNotNull($aircraft->subfleet->airline); $this->assertEquals('A32X', $aircraft->subfleet->type);