/api_tests: Completed tests for basic CRUD for Assets and Components (#3426)

* Refactored AssetsTransformer

Casted all ids to int, escaped all text values,

* Added warranty_expires attribute to Asset model

$asset->warranty_expires contains a Carbon object with the warranty
expiration date. Returns null when either purchase_date or
warranty_months are not set.

* Ignoring php-cs cache files

* Restored asset tests expectations

Work in progress - tests still fail

* API controller refactoring, fixed HTTP status codes in responses

* Restored $request->get - debugging

* Added further checks in ApiAssetsCest::updateAssetWithPatch

* /api_tests: Fixed bugs in update() method + code formatting

* /api_tests: Minor code formatting

* /api_tests: Mirrored test code for PATCH and PUT methods

* Removed repeated code

* Test cleanup

* Fixed issues with update() through PATCH and PUT methods

* Added API test suite to .travis.yml
This commit is contained in:
Andrea Bergamasco 2017-03-31 22:48:11 +02:00 committed by snipe
parent 99cc8293ef
commit 7ee172888d
5 changed files with 115 additions and 88 deletions

View file

@ -41,6 +41,7 @@ script:
# - ./vendor/bin/codecept run acceptance --env=testing-ci # - ./vendor/bin/codecept run acceptance --env=testing-ci
- ./vendor/bin/codecept run functional --env=functional-travis - ./vendor/bin/codecept run functional --env=functional-travis
#script: ./vendor/bin/codecept run #script: ./vendor/bin/codecept run
- ./vendor/bin/codecept run api --env=testing-ci
after_success: after_success:
- codecov - codecov

View file

@ -287,23 +287,36 @@ class AssetsController extends Controller
if ($asset = Asset::find($id)) { if ($asset = Asset::find($id)) {
($request->has('model_id')) ? ($request->has('model_id')) ?
$asset->model()->associate(AssetModel::find($request->get('model_id'))) : ''; $asset->model()->associate(AssetModel::find($request->get('model_id'))) : '';
($request->has('name')) ? $asset->name = $request->get('name') : ''; ($request->has('name')) ?
($request->has('serial')) ? $asset->serial = $request->get('serial') : ''; $asset->name = $request->get('name') : '';
($request->has('model_id')) ? $asset->model_id = $request->get('model_id') : ''; ($request->has('serial')) ?
($request->has('order_number')) ? $asset->order_number = $request->get('order_number') : ''; $asset->serial = $request->get('serial') : '';
($request->has('notes')) ? $asset->notes = $request->get('notes') : ''; ($request->has('model_id')) ?
($request->has('asset_tag')) ? $asset->asset_tag = $request->input('asset_tag') : ''; $asset->model_id = $request->get('model_id') : '';
($request->has('archived')) ? $asset->archived = $request->get('archived') : ''; ($request->has('order_number')) ?
($request->has('status_id')) ? $asset->status_id = $request->get('status_id') : ''; $asset->order_number = $request->get('order_number') : '';
($request->has('warranty_months')) ? $asset->warranty_months = $request->get('warranty_months') : ''; ($request->has('notes')) ?
$asset->notes = $request->get('notes') : '';
($request->has('asset_tag')) ?
$asset->asset_tag = $request->get('asset_tag') : '';
($request->has('archived')) ?
$asset->archived = $request->get('archived') : '';
($request->has('status_id')) ?
$asset->status_id = $request->get('status_id') : '';
($request->has('warranty_months')) ?
$asset->warranty_months = $request->get('warranty_months') : '';
($request->has('purchase_cost')) ? ($request->has('purchase_cost')) ?
$asset->purchase_cost = Helper::ParseFloat($request->get('purchase_cost')) : ''; $asset->purchase_cost = Helper::ParseFloat($request->get('purchase_cost')) : '';
($request->has('purchase_date')) ? $asset->purchase_date = $request->get('purchase_date') : ''; ($request->has('purchase_date')) ?
($request->has('assigned_to')) ? $asset->assigned_to = $request->get('assigned_to') : ''; $asset->purchase_date = $request->get('purchase_date') : '';
($request->has('supplier_id')) ? $asset->supplier_id = $request->get('supplier_id') : ''; ($request->has('assigned_to')) ?
($request->has('requestable')) ? $asset->name = $request->get('requestable') : ''; $asset->assigned_to = $request->get('assigned_to') : '';
($request->has('archived')) ? $asset->name = $request->get('archived') : ''; ($request->has('supplier_id')) ?
($request->has('rtd_location_id')) ? $asset->name = $request->get('rtd_location_id') : ''; $asset->supplier_id = $request->get('supplier_id') : '';
($request->has('requestable')) ?
$asset->requestable = $request->get('requestable') : '';
($request->has('rtd_location_id')) ?
$asset->rtd_location_id = $request->get('rtd_location_id') : '';
($request->has('company_id')) ? ($request->has('company_id')) ?
$asset->company_id = Company::getIdForCurrentUser($request->get('company_id')) : ''; $asset->company_id = Company::getIdForCurrentUser($request->get('company_id')) : '';
@ -335,8 +348,6 @@ class AssetsController extends Controller
} }
return response()->json(Helper::formatStandardApiResponse('error', null, $asset->getErrors()), 200); return response()->json(Helper::formatStandardApiResponse('error', null, $asset->getErrors()), 200);
} }
return response()->json(Helper::formatStandardApiResponse('error', null, trans('admin/hardware/message.does_not_exist')), 200); return response()->json(Helper::formatStandardApiResponse('error', null, trans('admin/hardware/message.does_not_exist')), 200);
} }

View file

@ -121,7 +121,7 @@ class ApiAssetsCest
// setup // setup
$data = [ $data = [
'asset_tag' => $temp_asset->tag, 'asset_tag' => $temp_asset->asset_tag,
'assigned_to' => $temp_asset->assigned_to, 'assigned_to' => $temp_asset->assigned_to,
'company_id' => $temp_asset->company->id, 'company_id' => $temp_asset->company->id,
'image' => $temp_asset->image, 'image' => $temp_asset->image,
@ -148,14 +148,14 @@ class ApiAssetsCest
{ {
$I->wantTo('Update an asset with PATCH'); $I->wantTo('Update an asset with PATCH');
// create and store an asset // create
$asset = factory(\App\Models\Asset::class, 'asset')->create(); $asset = factory(\App\Models\Asset::class, 'asset')->create();
$I->assertInstanceOf(\App\Models\Asset::class, $asset); $I->assertInstanceOf(\App\Models\Asset::class, $asset);
// create a temporary asset to grab new data
$temp_asset = factory(\App\Models\Asset::class, 'asset')->make(); $temp_asset = factory(\App\Models\Asset::class, 'asset')->make();
$data = [ $data = [
'asset_tag' => $temp_asset->tag, 'asset_tag' => $temp_asset->asset_tag,
'assigned_to' => $temp_asset->assigned_to, 'assigned_to' => $temp_asset->assigned_to,
'company_id' => $temp_asset->company->id, 'company_id' => $temp_asset->company->id,
'image' => $temp_asset->image, 'image' => $temp_asset->image,
@ -171,7 +171,6 @@ class ApiAssetsCest
'warranty_months' => $temp_asset->warranty_months, 'warranty_months' => $temp_asset->warranty_months,
]; ];
// the asset name should be different
$I->assertNotEquals($asset->name, $data['name']); $I->assertNotEquals($asset->name, $data['name']);
// update // update
@ -182,24 +181,19 @@ class ApiAssetsCest
$response = json_decode($I->grabResponse()); $response = json_decode($I->grabResponse());
$I->assertEquals('success', $response->status); $I->assertEquals('success', $response->status);
$I->assertEquals(trans('admin/hardware/message.update.success'), $response->messages); $I->assertEquals(trans('admin/hardware/message.update.success'), $response->messages);
$I->assertEquals($asset->id, $response->payload->id); // asset id does not change
$I->assertEquals($asset->id, $response->payload->id); $I->assertEquals($temp_asset->asset_tag, $response->payload->asset_tag); // asset tag updated
$I->assertEquals($data['name'], $response->payload->name); $I->assertEquals($temp_asset->name, $response->payload->name); // asset name updated
$I->assertEquals($data['asset_tag'], $response->payload->asset_tag); $I->assertEquals($temp_asset->rtd_location_id, $response->payload->rtd_location_id); // asset rtd_location_id updated
$I->assertEquals($data['model_id'], $response->payload->model_id);
// dd($response, $asset->getAttributes());
// verify // verify
// $scenario->incomplete('[BadMethodCallException] Call to undefined method Illuminate\Database\Query\Builder::detail() 🤔');
$I->sendGET('/hardware/' . $asset->id); $I->sendGET('/hardware/' . $asset->id);
$I->seeResponseIsJson(); $I->seeResponseIsJson();
$I->seeResponseCodeIs(200); $I->seeResponseCodeIs(200);
$I->seeResponseContainsJson([ $I->seeResponseContainsJson([
'id' => (int) $asset->id, 'id' => (int) $asset->id,
'name' => e($temp_asset->name), // TODO: name should change 'name' => e($temp_asset->name),
'asset_tag' => e($temp_asset->asset_tag), // TODO: asset_tag should change 'asset_tag' => e($temp_asset->asset_tag),
'serial' => e($temp_asset->serial), 'serial' => e($temp_asset->serial),
'model' => ($temp_asset->model) ? [ 'model' => ($temp_asset->model) ? [
'id' => (int) $temp_asset->model->id, 'id' => (int) $temp_asset->model->id,
@ -220,17 +214,17 @@ class ApiAssetsCest
] : null, ] : null,
'notes' => e($temp_asset->notes), 'notes' => e($temp_asset->notes),
'order_number' => e($asset->order_number), 'order_number' => e($asset->order_number),
'company' => ($temp_asset->company) ? [ 'company' => ($asset->company) ? [
'id' => (int) $temp_asset->company->id, 'id' => (int) $temp_asset->company->id,
'name'=> e($temp_asset->company->name) 'name'=> e($temp_asset->company->name)
] : null, ] : null,
'location' => ($asset->assetLoc) ? [ 'location' => ($temp_asset->assetLoc) ? [
'id' => (int) $asset->assetLoc->id, 'id' => (int) $temp_asset->assetLoc->id,
'name'=> e($asset->assetLoc->name) 'name'=> e($temp_asset->assetLoc->name)
] : null, ] : null,
'rtd_location' => ($asset->defaultLoc) ? [ 'rtd_location' => ($temp_asset->defaultLoc) ? [
'id' => (int) $asset->defaultLoc->id, 'id' => (int) $temp_asset->defaultLoc->id,
'name'=> e($asset->defaultLoc->name) 'name'=> e($temp_asset->defaultLoc->name)
] : null, ] : null,
'image' => ($asset->getImageUrl()) ? $asset->getImageUrl() : null, 'image' => ($asset->getImageUrl()) ? $asset->getImageUrl() : null,
'assigned_to' => ($temp_asset->assigneduser) ? [ 'assigned_to' => ($temp_asset->assigneduser) ? [
@ -284,11 +278,29 @@ class ApiAssetsCest
$asset = factory(\App\Models\Asset::class, 'asset')->create(); $asset = factory(\App\Models\Asset::class, 'asset')->create();
$I->assertInstanceOf(\App\Models\Asset::class, $asset); $I->assertInstanceOf(\App\Models\Asset::class, $asset);
$company = \App\Models\Company::inRandomOrder()->first(); $temp_asset_tag = $this->faker->uuid;
$temp_asset = factory(\App\Models\Asset::class, 'asset')->make([
'asset_tag' => $temp_asset_tag,
]);
$I->assertNotNull($temp_asset->asset_tag);
$I->assertEquals($temp_asset_tag, $temp_asset->asset_tag);
$data = [ $data = [
'name' => $this->faker->sentence(3), 'asset_tag' => $temp_asset->asset_tag,
'company_id' => $company->id, 'assigned_to' => $temp_asset->assigned_to,
'company_id' => $temp_asset->company->id,
'image' => $temp_asset->image,
'model_id' => $temp_asset->model_id,
'name' => $temp_asset->name,
'notes' => $temp_asset->notes,
'purchase_cost' => $temp_asset->purchase_cost,
'purchase_date' => $temp_asset->purchase_date->format('Y-m-d'),
'rtd_location_id' => $temp_asset->rtd_location_id,
'serial' => $temp_asset->serial,
'status_id' => $temp_asset->status_id,
'supplier_id' => $temp_asset->supplier_id,
'warranty_months' => $temp_asset->warranty_months,
]; ];
$I->assertNotEquals($asset->name, $data['name']); $I->assertNotEquals($asset->name, $data['name']);
@ -301,7 +313,10 @@ class ApiAssetsCest
$response = json_decode($I->grabResponse()); $response = json_decode($I->grabResponse());
$I->assertEquals('success', $response->status); $I->assertEquals('success', $response->status);
$I->assertEquals(trans('admin/hardware/message.update.success'), $response->messages); $I->assertEquals(trans('admin/hardware/message.update.success'), $response->messages);
$I->assertEquals($asset->id, $response->payload->id); $I->assertEquals($asset->id, $response->payload->id); // asset id does not change
$I->assertEquals($temp_asset->asset_tag, $response->payload->asset_tag); // asset tag updated
$I->assertEquals($temp_asset->name, $response->payload->name); // asset name updated
$I->assertEquals($temp_asset->rtd_location_id, $response->payload->rtd_location_id); // asset rtd_location_id updated
// verify // verify
$I->sendGET('/hardware/' . $asset->id); $I->sendGET('/hardware/' . $asset->id);
@ -309,46 +324,46 @@ class ApiAssetsCest
$I->seeResponseCodeIs(200); $I->seeResponseCodeIs(200);
$I->seeResponseContainsJson([ $I->seeResponseContainsJson([
'id' => (int) $asset->id, 'id' => (int) $asset->id,
'name' => e($data['name']), 'name' => e($temp_asset->name),
'asset_tag' => e($asset->asset_tag), 'asset_tag' => e($temp_asset->asset_tag),
'serial' => e($asset->serial), 'serial' => e($temp_asset->serial),
'model' => ($asset->model) ? [ 'model' => ($temp_asset->model) ? [
'id' => (int) $asset->model->id, 'id' => (int) $temp_asset->model->id,
'name'=> e($asset->model->name) 'name'=> e($temp_asset->model->name)
] : null, ] : null,
'model_number' => ($asset->model) ? e($asset->model->model_number) : null, 'model_number' => ($temp_asset->model) ? e($temp_asset->model->model_number) : null,
'status_label' => ($asset->assetstatus) ? [ 'status_label' => ($temp_asset->assetstatus) ? [
'id' => (int) $asset->assetstatus->id, 'id' => (int) $temp_asset->assetstatus->id,
'name'=> e($asset->assetstatus->name) 'name'=> e($temp_asset->assetstatus->name)
] : null, ] : null,
'category' => ($asset->model->category) ? [ 'category' => ($temp_asset->model->category) ? [
'id' => (int) $asset->model->category->id, 'id' => (int) $temp_asset->model->category->id,
'name'=> e($asset->model->category->name) 'name'=> e($temp_asset->model->category->name)
] : null, ] : null,
'manufacturer' => ($asset->model->manufacturer) ? [ 'manufacturer' => ($temp_asset->model->manufacturer) ? [
'id' => (int) $asset->model->manufacturer->id, 'id' => (int) $temp_asset->model->manufacturer->id,
'name'=> e($asset->model->manufacturer->name) 'name'=> e($temp_asset->model->manufacturer->name)
] : null, ] : null,
'notes' => e($asset->notes), 'notes' => e($temp_asset->notes),
'order_number' => e($asset->order_number), 'order_number' => e($asset->order_number),
'company' => ($asset->company) ? [ 'company' => ($asset->company) ? [
'id' => (int) $data['company_id'], 'id' => (int) $temp_asset->company->id,
'name'=> e($company->name) 'name'=> e($temp_asset->company->name)
] : null, ] : null,
'location' => ($asset->assetLoc) ? [ 'location' => ($temp_asset->assetLoc) ? [
'id' => (int) $asset->assetLoc->id, 'id' => (int) $temp_asset->assetLoc->id,
'name'=> e($asset->assetLoc->name) 'name'=> e($temp_asset->assetLoc->name)
] : null, ] : null,
'rtd_location' => ($asset->defaultLoc) ? [ 'rtd_location' => ($temp_asset->defaultLoc) ? [
'id' => (int) $asset->defaultLoc->id, 'id' => (int) $temp_asset->defaultLoc->id,
'name'=> e($asset->defaultLoc->name) 'name'=> e($temp_asset->defaultLoc->name)
] : null, ] : null,
'image' => ($asset->getImageUrl()) ? $asset->getImageUrl() : null, 'image' => ($asset->getImageUrl()) ? $asset->getImageUrl() : null,
'assigned_to' => ($asset->assigneduser) ? [ 'assigned_to' => ($temp_asset->assigneduser) ? [
'id' => (int) $asset->assigneduser->id, 'id' => (int) $temp_asset->assigneduser->id,
'name' => e($asset->assigneduser->getFullNameAttribute()), 'name' => e($temp_asset->assigneduser->getFullNameAttribute()),
'first_name'=> e($asset->assigneduser->first_name), 'first_name'=> e($temp_asset->assigneduser->first_name),
'last_name'=> e($asset->assigneduser->last_name) 'last_name'=> e($temp_asset->assigneduser->last_name)
] : null, ] : null,
'warranty' => ($asset->warranty_months > 0) ? e($asset->warranty_months . ' ' . trans('admin/hardware/form.months')) : null, 'warranty' => ($asset->warranty_months > 0) ? e($asset->warranty_months . ' ' . trans('admin/hardware/form.months')) : null,
'warranty_expires' => ($asset->warranty_months > 0) ? [ 'warranty_expires' => ($asset->warranty_months > 0) ? [
@ -376,7 +391,7 @@ class ApiAssetsCest
// 'formatted' => $asset->created_at->format('Y-m-d'), // 'formatted' => $asset->created_at->format('Y-m-d'),
// ] : null, // ] : null,
// 'purchase_cost' => (float) $asset->purchase_cost, // 'purchase_cost' => (float) $asset->purchase_cost,
'user_can_checkout' => (bool) $asset->availableForCheckout(), 'user_can_checkout' => (bool) $temp_asset->availableForCheckout(),
'available_actions' => [ 'available_actions' => [
'checkout' => (bool) Gate::allows('checkout', Asset::class), 'checkout' => (bool) Gate::allows('checkout', Asset::class),
'checkin' => (bool) Gate::allows('checkin', Asset::class), 'checkin' => (bool) Gate::allows('checkin', Asset::class),