2017-06-20 00:30:39 +08:00
|
|
|
<?php
|
|
|
|
|
2017-12-13 06:58:27 +08:00
|
|
|
use App\Services\FlightService;
|
|
|
|
use App\Models\Flight;
|
|
|
|
use App\Models\User;
|
2017-06-20 00:30:39 +08:00
|
|
|
|
|
|
|
class FlightTest extends TestCase
|
|
|
|
{
|
|
|
|
public function setUp()
|
|
|
|
{
|
|
|
|
parent::setUp();
|
2017-08-15 12:36:49 +08:00
|
|
|
$this->addData('base');
|
2017-12-13 06:58:27 +08:00
|
|
|
|
|
|
|
$this->flightSvc = app(FlightService::class);
|
2017-06-20 00:30:39 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
public function addFlight()
|
|
|
|
{
|
2017-12-13 11:50:55 +08:00
|
|
|
$flight = factory(App\Models\Flight::class)->create();
|
|
|
|
$flight->subfleets()->syncWithoutDetaching([
|
|
|
|
factory(App\Models\Subfleet::class)->create()->id
|
|
|
|
]);
|
2017-12-13 06:58:27 +08:00
|
|
|
|
2017-12-13 11:50:55 +08:00
|
|
|
return $flight;
|
2017-08-15 12:36:49 +08:00
|
|
|
}
|
|
|
|
|
2017-11-23 01:52:02 +08:00
|
|
|
public function testGetFlight()
|
2017-08-15 12:36:49 +08:00
|
|
|
{
|
2017-12-13 11:50:55 +08:00
|
|
|
$flight = $this->addFlight();
|
|
|
|
|
|
|
|
$req = $this->get('/api/flights/'.$flight->id, self::$auth_headers);
|
2017-12-13 06:58:27 +08:00
|
|
|
$req->assertStatus(200);
|
|
|
|
|
|
|
|
$body = $req->json();
|
2017-12-13 11:50:55 +08:00
|
|
|
$this->assertEquals($flight->id, $body['id']);
|
|
|
|
$this->assertEquals($flight->dpt_airport_id, $body['dpt_airport_id']);
|
|
|
|
$this->assertEquals($flight->arr_airport_id, $body['arr_airport_id']);
|
2017-12-12 21:25:11 +08:00
|
|
|
|
|
|
|
$this->get('/api/flights/INVALID', self::$auth_headers)
|
|
|
|
->assertStatus(404);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Search based on all different criteria
|
|
|
|
*/
|
|
|
|
public function testSearchFlight()
|
|
|
|
{
|
2017-12-13 11:50:55 +08:00
|
|
|
$flight = $this->addFlight();
|
2017-12-12 21:25:11 +08:00
|
|
|
|
|
|
|
# search specifically for a flight ID
|
2017-12-13 11:50:55 +08:00
|
|
|
$query = 'flight_id=' . $flight->id;
|
2017-12-12 21:25:11 +08:00
|
|
|
$req = $this->get('/api/flights/search?' . $query, self::$auth_headers);
|
|
|
|
$req->assertStatus(200);
|
2017-06-20 00:30:39 +08:00
|
|
|
}
|
2017-12-13 06:58:27 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Add/remove a bid, test the API, etc
|
|
|
|
* @throws \App\Services\Exception
|
|
|
|
*/
|
|
|
|
public function testBids()
|
|
|
|
{
|
|
|
|
$user = User::find(1);
|
2017-12-13 11:50:55 +08:00
|
|
|
$flight = $this->addFlight();
|
2017-12-13 06:58:27 +08:00
|
|
|
|
|
|
|
$bid = $this->flightSvc->addBid($flight, $user);
|
|
|
|
$this->assertEquals(1, $bid->user_id);
|
2017-12-13 11:50:55 +08:00
|
|
|
$this->assertEquals($flight->id, $bid->flight_id);
|
2017-12-13 06:58:27 +08:00
|
|
|
$this->assertTrue($flight->has_bid);
|
|
|
|
|
|
|
|
# Refresh
|
2017-12-13 11:50:55 +08:00
|
|
|
$flight = Flight::find($flight->id);
|
2017-12-13 06:58:27 +08:00
|
|
|
$this->assertTrue($flight->has_bid);
|
|
|
|
|
|
|
|
# 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', self::$auth_headers);
|
|
|
|
$req->assertStatus(200);
|
|
|
|
$body = $req->json();
|
|
|
|
$this->assertEquals(1, sizeof($body['bids']));
|
2017-12-13 11:50:55 +08:00
|
|
|
$this->assertEquals($flight->id, $body['bids'][0]['flight_id']);
|
2017-12-13 06:58:27 +08:00
|
|
|
|
|
|
|
$req = $this->get('/api/users/1/bids', self::$auth_headers);
|
|
|
|
|
|
|
|
$body = $req->json();
|
|
|
|
$req->assertStatus(200);
|
2017-12-13 11:50:55 +08:00
|
|
|
$this->assertEquals($flight->id, $body[0]['id']);
|
2017-12-13 06:58:27 +08:00
|
|
|
|
|
|
|
# Now remove the flight and check API
|
|
|
|
|
|
|
|
$this->flightSvc->removeBid($flight, $user);
|
|
|
|
|
2017-12-13 11:50:55 +08:00
|
|
|
$flight = Flight::find($flight->id);
|
2017-12-13 06:58:27 +08:00
|
|
|
$this->assertFalse($flight->has_bid);
|
|
|
|
|
|
|
|
$user = User::find(1);
|
|
|
|
$bids = $user->bids()->get();
|
|
|
|
$this->assertTrue($bids->isEmpty());
|
|
|
|
|
|
|
|
$req = $this->get('/api/user', self::$auth_headers);
|
|
|
|
$req->assertStatus(200);
|
|
|
|
|
|
|
|
$body = $req->json();
|
|
|
|
$this->assertEquals(0, sizeof($body['bids']));
|
|
|
|
|
|
|
|
$req = $this->get('/api/users/1/bids', self::$auth_headers);
|
|
|
|
$req->assertStatus(200);
|
|
|
|
$body = $req->json();
|
|
|
|
|
|
|
|
$this->assertEquals(0, sizeof($body));
|
|
|
|
}
|
2017-12-13 07:26:27 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function testMultipleBidsSingleFlight()
|
|
|
|
{
|
|
|
|
setting('bids.disable_flight_on_bid', true);
|
|
|
|
|
|
|
|
$user1 = User::find(1);
|
|
|
|
$user2 = User::find(2);
|
|
|
|
|
2017-12-13 11:50:55 +08:00
|
|
|
$flight = $this->addFlight();
|
2017-12-13 07:26:27 +08:00
|
|
|
|
|
|
|
# Put bid on the flight to block it off
|
|
|
|
$bid = $this->flightSvc->addBid($flight, $user1);
|
|
|
|
|
|
|
|
$bidRepeat = $this->flightSvc->addBid($flight, $user2);
|
|
|
|
$this->assertNull($bidRepeat);
|
|
|
|
}
|
2017-06-20 00:30:39 +08:00
|
|
|
}
|