delete the user bids when a flight is deleted #103
This commit is contained in:
parent
904f64939f
commit
c65da0a0af
@ -9,6 +9,7 @@ use App\Repositories\AirlineRepository;
|
|||||||
use App\Repositories\AirportRepository;
|
use App\Repositories\AirportRepository;
|
||||||
use App\Repositories\FlightRepository;
|
use App\Repositories\FlightRepository;
|
||||||
use App\Repositories\SubfleetRepository;
|
use App\Repositories\SubfleetRepository;
|
||||||
|
use App\Services\FlightService;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Flash;
|
use Flash;
|
||||||
use Response;
|
use Response;
|
||||||
@ -18,17 +19,20 @@ class FlightController extends BaseController
|
|||||||
private $airlineRepo,
|
private $airlineRepo,
|
||||||
$airportRepo,
|
$airportRepo,
|
||||||
$flightRepo,
|
$flightRepo,
|
||||||
|
$flightSvc,
|
||||||
$subfleetRepo;
|
$subfleetRepo;
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
AirlineRepository $airlineRepo,
|
AirlineRepository $airlineRepo,
|
||||||
AirportRepository $airportRepo,
|
AirportRepository $airportRepo,
|
||||||
FlightRepository $flightRepo,
|
FlightRepository $flightRepo,
|
||||||
|
FlightService $flightSvc,
|
||||||
SubfleetRepository $subfleetRepo
|
SubfleetRepository $subfleetRepo
|
||||||
) {
|
) {
|
||||||
$this->airlineRepo = $airlineRepo;
|
$this->airlineRepo = $airlineRepo;
|
||||||
$this->airportRepo = $airportRepo;
|
$this->airportRepo = $airportRepo;
|
||||||
$this->flightRepo = $flightRepo;
|
$this->flightRepo = $flightRepo;
|
||||||
|
$this->flightSvc = $flightSvc;
|
||||||
$this->subfleetRepo = $subfleetRepo;
|
$this->subfleetRepo = $subfleetRepo;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -161,6 +165,7 @@ class FlightController extends BaseController
|
|||||||
/**
|
/**
|
||||||
* @param $id
|
* @param $id
|
||||||
* @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector
|
* @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector
|
||||||
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public function destroy($id)
|
public function destroy($id)
|
||||||
{
|
{
|
||||||
@ -171,7 +176,7 @@ class FlightController extends BaseController
|
|||||||
return redirect(route('admin.flights.index'));
|
return redirect(route('admin.flights.index'));
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->flightRepo->delete($id);
|
$this->flightSvc->deleteFlight($flight);
|
||||||
|
|
||||||
Flash::success('Flight deleted successfully.');
|
Flash::success('Flight deleted successfully.');
|
||||||
return redirect(route('admin.flights.index'));
|
return redirect(route('admin.flights.index'));
|
||||||
|
@ -7,6 +7,7 @@ use Illuminate\Http\Request;
|
|||||||
use App\Http\Controllers\AppBaseController;
|
use App\Http\Controllers\AppBaseController;
|
||||||
use App\Repositories\UserRepository;
|
use App\Repositories\UserRepository;
|
||||||
|
|
||||||
|
use App\Models\User;
|
||||||
use App\Models\UserBid;
|
use App\Models\UserBid;
|
||||||
|
|
||||||
use App\Http\Resources\Flight as FlightResource;
|
use App\Http\Resources\Flight as FlightResource;
|
||||||
|
@ -16,6 +16,18 @@ use App\Models\UserBid;
|
|||||||
|
|
||||||
class FlightService extends BaseService
|
class FlightService extends BaseService
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* Delete a flight, and all the user bids, etc associated with it
|
||||||
|
* @param Flight $flight
|
||||||
|
* @throws \Exception
|
||||||
|
*/
|
||||||
|
public function deleteFlight(Flight $flight)
|
||||||
|
{
|
||||||
|
$where = ['flight_id' => $flight->id];
|
||||||
|
UserBid::where($where)->delete();
|
||||||
|
$flight->delete();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allow a user to bid on a flight. Check settings and all that good stuff
|
* Allow a user to bid on a flight. Check settings and all that good stuff
|
||||||
* @param Flight $flight
|
* @param Flight $flight
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
#use Swagger\Serializer;
|
#use Swagger\Serializer;
|
||||||
|
use App\Models\User;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test API calls and authentication, etc
|
* Test API calls and authentication, etc
|
||||||
@ -18,6 +19,7 @@ class ApiTest extends TestCase
|
|||||||
*/
|
*/
|
||||||
public function testApiAuthentication()
|
public function testApiAuthentication()
|
||||||
{
|
{
|
||||||
|
$user = factory(User::class)->create();
|
||||||
$airport = factory(App\Models\Airport::class)->create();
|
$airport = factory(App\Models\Airport::class)->create();
|
||||||
|
|
||||||
$uri = '/api/airports/' . $airport->icao;
|
$uri = '/api/airports/' . $airport->icao;
|
||||||
@ -37,15 +39,15 @@ class ApiTest extends TestCase
|
|||||||
->assertStatus(200)
|
->assertStatus(200)
|
||||||
->assertJson(['icao' => $airport->icao], true);
|
->assertJson(['icao' => $airport->icao], true);
|
||||||
|
|
||||||
$this->withHeaders(['x-api-key' => 'testadminapikey'])->get($uri)
|
$this->withHeaders(['x-api-key' => $user->api_key])->get($uri)
|
||||||
->assertStatus(200)
|
->assertStatus(200)
|
||||||
->assertJson(['icao' => $airport->icao], true);
|
->assertJson(['icao' => $airport->icao], true);
|
||||||
|
|
||||||
$this->withHeaders(['x-API-key' => 'testadminapikey'])->get($uri)
|
$this->withHeaders(['x-API-key' => $user->api_key])->get($uri)
|
||||||
->assertStatus(200)
|
->assertStatus(200)
|
||||||
->assertJson(['icao' => $airport->icao], true);
|
->assertJson(['icao' => $airport->icao], true);
|
||||||
|
|
||||||
$this->withHeaders(['X-API-KEY' => 'testadminapikey'])->get($uri)
|
$this->withHeaders(['X-API-KEY' => $user->api_key])->get($uri)
|
||||||
->assertStatus(200)
|
->assertStatus(200)
|
||||||
->assertJson(['icao' => $airport->icao], true);
|
->assertJson(['icao' => $airport->icao], true);
|
||||||
}
|
}
|
||||||
@ -55,19 +57,12 @@ class ApiTest extends TestCase
|
|||||||
*/
|
*/
|
||||||
public function testAirportRequest()
|
public function testAirportRequest()
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
$airport = factory(App\Models\Airport::class)->create();
|
$airport = factory(App\Models\Airport::class)->create();
|
||||||
|
|
||||||
$response = $this->withHeaders($this->apiHeaders())->get('/api/airports/' . $airport->icao);
|
$response = $this->withHeaders($this->apiHeaders())->get('/api/airports/' . $airport->icao);
|
||||||
$response->assertStatus(200);
|
$response->assertStatus(200);
|
||||||
$response->assertJson(['icao' => $airport->icao], true);
|
$response->assertJson(['icao' => $airport->icao], true);
|
||||||
|
|
||||||
/*$body = $response->json();
|
|
||||||
$serializer = new Serializer();
|
|
||||||
$swagger = $serializer->deserialize(\json_encode($body));
|
|
||||||
echo $swagger;*/
|
|
||||||
|
|
||||||
$this->withHeaders($this->apiHeaders())->get('/api/airports/UNK')
|
$this->withHeaders($this->apiHeaders())->get('/api/airports/UNK')
|
||||||
->assertStatus(404);
|
->assertStatus(404);
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
use App\Services\FlightService;
|
use App\Services\FlightService;
|
||||||
use App\Models\Flight;
|
use App\Models\Flight;
|
||||||
use App\Models\User;
|
use App\Models\User;
|
||||||
|
use App\Models\UserBid;
|
||||||
|
|
||||||
class FlightTest extends TestCase
|
class FlightTest extends TestCase
|
||||||
{
|
{
|
||||||
@ -59,11 +60,15 @@ class FlightTest extends TestCase
|
|||||||
*/
|
*/
|
||||||
public function testBids()
|
public function testBids()
|
||||||
{
|
{
|
||||||
$user = User::find(1);
|
$user = factory(User::class)->create();
|
||||||
|
$headers = [
|
||||||
|
'x-api-key' => $user->api_key,
|
||||||
|
];
|
||||||
|
|
||||||
$flight = $this->addFlight();
|
$flight = $this->addFlight();
|
||||||
|
|
||||||
$bid = $this->flightSvc->addBid($flight, $user);
|
$bid = $this->flightSvc->addBid($flight, $user);
|
||||||
$this->assertEquals(1, $bid->user_id);
|
$this->assertEquals($user->id, $bid->user_id);
|
||||||
$this->assertEquals($flight->id, $bid->flight_id);
|
$this->assertEquals($flight->id, $bid->flight_id);
|
||||||
$this->assertTrue($flight->has_bid);
|
$this->assertTrue($flight->has_bid);
|
||||||
|
|
||||||
@ -71,15 +76,23 @@ class FlightTest extends TestCase
|
|||||||
$flight = Flight::find($flight->id);
|
$flight = Flight::find($flight->id);
|
||||||
$this->assertTrue($flight->has_bid);
|
$this->assertTrue($flight->has_bid);
|
||||||
|
|
||||||
|
# Check the table and make sure thee entry is there
|
||||||
|
$user_bid = UserBid::where(['flight_id'=>$flight->id, 'user_id'=>$user->id])->get();
|
||||||
|
$this->assertNotNull($user_bid);
|
||||||
|
|
||||||
|
$user->refresh();
|
||||||
|
$this->assertEquals(1, $user->bids->count());
|
||||||
|
|
||||||
# Query the API and see that the user has the bids
|
# Query the API and see that the user has the bids
|
||||||
# And pull the flight details for the user/bids
|
# And pull the flight details for the user/bids
|
||||||
$req = $this->get('/api/user', self::$auth_headers);
|
$req = $this->get('/api/user', $headers);
|
||||||
$req->assertStatus(200);
|
$req->assertStatus(200);
|
||||||
|
|
||||||
$body = $req->json();
|
$body = $req->json();
|
||||||
$this->assertEquals(1, sizeof($body['bids']));
|
$this->assertEquals(1, sizeof($body['bids']));
|
||||||
$this->assertEquals($flight->id, $body['bids'][0]['flight_id']);
|
$this->assertEquals($flight->id, $body['bids'][0]['flight_id']);
|
||||||
|
|
||||||
$req = $this->get('/api/users/1/bids', self::$auth_headers);
|
$req = $this->get('/api/users/'.$user->id.'/bids', $headers);
|
||||||
|
|
||||||
$body = $req->json();
|
$body = $req->json();
|
||||||
$req->assertStatus(200);
|
$req->assertStatus(200);
|
||||||
@ -92,17 +105,18 @@ class FlightTest extends TestCase
|
|||||||
$flight = Flight::find($flight->id);
|
$flight = Flight::find($flight->id);
|
||||||
$this->assertFalse($flight->has_bid);
|
$this->assertFalse($flight->has_bid);
|
||||||
|
|
||||||
$user = User::find(1);
|
$user->refresh();
|
||||||
$bids = $user->bids()->get();
|
$bids = $user->bids()->get();
|
||||||
$this->assertTrue($bids->isEmpty());
|
$this->assertTrue($bids->isEmpty());
|
||||||
|
|
||||||
$req = $this->get('/api/user', self::$auth_headers);
|
$req = $this->get('/api/user', $headers);
|
||||||
$req->assertStatus(200);
|
$req->assertStatus(200);
|
||||||
|
|
||||||
$body = $req->json();
|
$body = $req->json();
|
||||||
|
$this->assertEquals($user->id, $body['id']);
|
||||||
$this->assertEquals(0, sizeof($body['bids']));
|
$this->assertEquals(0, sizeof($body['bids']));
|
||||||
|
|
||||||
$req = $this->get('/api/users/1/bids', self::$auth_headers);
|
$req = $this->get('/api/users/'.$user->id.'/bids', $headers);
|
||||||
$req->assertStatus(200);
|
$req->assertStatus(200);
|
||||||
$body = $req->json();
|
$body = $req->json();
|
||||||
|
|
||||||
@ -116,7 +130,7 @@ class FlightTest extends TestCase
|
|||||||
{
|
{
|
||||||
setting('bids.disable_flight_on_bid', true);
|
setting('bids.disable_flight_on_bid', true);
|
||||||
|
|
||||||
$user1 = User::find(1);
|
$user1 = factory(User::class)->create();;
|
||||||
$user2 = factory(User::class)->create();
|
$user2 = factory(User::class)->create();
|
||||||
|
|
||||||
$flight = $this->addFlight();
|
$flight = $this->addFlight();
|
||||||
@ -127,4 +141,47 @@ class FlightTest extends TestCase
|
|||||||
$bidRepeat = $this->flightSvc->addBid($flight, $user2);
|
$bidRepeat = $this->flightSvc->addBid($flight, $user2);
|
||||||
$this->assertNull($bidRepeat);
|
$this->assertNull($bidRepeat);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Delete a flight and make sure all the bids are gone
|
||||||
|
*/
|
||||||
|
public function testDeleteFlight()
|
||||||
|
{
|
||||||
|
$user = factory(User::class)->create();
|
||||||
|
$headers = [
|
||||||
|
'x-api-key' => $user->api_key,
|
||||||
|
];
|
||||||
|
|
||||||
|
$flight = $this->addFlight();
|
||||||
|
|
||||||
|
$bid = $this->flightSvc->addBid($flight, $user);
|
||||||
|
$this->assertEquals($user->id, $bid->user_id);
|
||||||
|
$this->assertEquals($flight->id, $bid->flight_id);
|
||||||
|
$this->assertTrue($flight->has_bid);
|
||||||
|
|
||||||
|
$this->flightSvc->deleteFlight($flight);
|
||||||
|
|
||||||
|
$empty_flight = Flight::find($flight->id);
|
||||||
|
$this->assertNull($empty_flight);
|
||||||
|
|
||||||
|
# Make sure no bids exist
|
||||||
|
$user_bids = UserBid::where('flight_id', $flight->id)->get();
|
||||||
|
|
||||||
|
#$this->assertEquals(0, $user_bid->count());
|
||||||
|
|
||||||
|
# Query the API and see that the user has the bids
|
||||||
|
# And pull the flight details for the user/bids
|
||||||
|
$req = $this->get('/api/user', $headers);
|
||||||
|
$req->assertStatus(200);
|
||||||
|
$body = $req->json();
|
||||||
|
|
||||||
|
$this->assertEquals($user->id, $body['id']);
|
||||||
|
$this->assertEquals(0, sizeof($body['bids']));
|
||||||
|
|
||||||
|
$req = $this->get('/api/users/'.$user->id.'/bids', $headers);
|
||||||
|
$req->assertStatus(200);
|
||||||
|
|
||||||
|
$body = $req->json();
|
||||||
|
$this->assertEquals(0, sizeof($body));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user