diff --git a/tests/Unit/ImporterTest.php b/tests/Unit/ImporterTest.php index b6605c93a0..dcd7927c2a 100644 --- a/tests/Unit/ImporterTest.php +++ b/tests/Unit/ImporterTest.php @@ -24,724 +24,724 @@ class ImporterTest extends BaseTest /** * @var \UnitTester */ - protected $tester; - - public function testDefaultImportAssetWithCustomFields() - { - $this->signIn(); - $csv = <<<'EOT' -Full Name,Email,Username,item Name,Category,Model name,Manufacturer,Model Number,Serial,Asset Tag,Location,Notes,Purchase Date,Purchase Cost,Company,Status,Warranty,Supplier,Weight -Bonnie Nelson,bnelson0@cdbaby.com,bnelson0,eget nunc donec quis,quam,massa id,Linkbridge,6377018600094472,27aa8378-b0f4-4289-84a4-405da95c6147,970882174-8,Daping,"Curabitur in libero ut massa volutpat convallis. Morbi odio odio, elementum eu, interdum eu, tincidunt in, leo. Maecenas pulvinar lobortis est.",2016-04-05,133289.59,Alpha,Undeployable,14,Blogspan,35 -EOT; - - $this->initializeCustomFields(); - $this->import(new AssetImporter($csv)); - - $this->tester->seeRecord('users', [ - 'first_name' => 'Bonnie', - 'last_name' => 'Nelson', - 'email' => 'bnelson0@cdbaby.com', - ]); - $this->tester->seeRecord('categories', [ - 'name' => 'quam', - ]); - - $this->tester->seeRecord('models', [ - 'name' => 'massa id', - 'model_number' => 6377018600094472, - ]); - - $this->tester->seeRecord('manufacturers', [ - 'name' => 'Linkbridge', - ]); - - $this->tester->seeRecord('locations', [ - 'name' => 'Daping', - ]); - - $this->tester->seeRecord('companies', [ - 'name' => 'Alpha', - ]); - - $this->tester->seeRecord('status_labels', [ - 'name' => 'Undeployable', - ]); - - $this->tester->seeRecord('suppliers', [ - 'name' => 'Blogspan', - ]); - - $this->tester->seeRecord('assets', [ - 'name' => 'eget nunc donec quis', - 'serial' => '27aa8378-b0f4-4289-84a4-405da95c6147', - 'asset_tag' => '970882174-8', - 'notes' => 'Curabitur in libero ut massa volutpat convallis. Morbi odio odio, elementum eu, interdum eu, tincidunt in, leo. Maecenas pulvinar lobortis est.', - 'purchase_date' => '2016-04-05 00:00:01', - 'purchase_cost' => 133289.59, 'warranty_months' => 14, - '_snipeit_weight_2' => 35, - ]); - } - - public function testImportCheckoutToLocation() - { - $this->signIn(); - - // Testing in order: - // * Asset to user, no checkout type defined (default to user). - // * Asset to user, explicit user checkout type (Checkout to user) - // * Asset to location, location does not exist to begin with - // * Asset to preexisting location. - $csv = <<<'EOT' -Full Name,Email,Username,Checkout Location,Checkout Type,item Name,Category,Model name,Manufacturer,Model Number,Serial,Asset Tag,Location,Notes,Purchase Date,Purchase Cost,Company,Status,Warranty,Supplier,Weight -Bonnie Nelson,bnelson0@cdbaby.com,bnelson0,,,eget nunc donec quis,quam,massa id,Linkbridge,6377018600094472,27aa8378-b0f4-4289-84a4-405da95c6147,970882174-8,Daping,"Curabitur in libero ut massa volutpat convallis. Morbi odio odio, elementum eu, interdum eu, tincidunt in, leo. Maecenas pulvinar lobortis est.",2016-04-05,133289.59,Alpha,Undeployable,14,Blogspan,35 -Mildred Gibson,mgibson2@wiley.com,mgibson2,,user,morbi quis tortor id,nunc nisl duis,convallis tortor risus,Lajo,374622546776765,2837ab20-8f0d-4935-8a52-226392f2b1b0,710141467-2,Shekou,In congue. Etiam justo. Etiam pretium iaculis justo.,2015-08-09,233.57,Konklab,Lost,,, -,,,Planet Earth,location,dictumst maecenas ut,sem praesent,accumsan felis,Layo,30052522651756,4751495c-cee0-4961-b788-94a545b5643e,998233705-X,Dante Delgado,,2016-04-16,261.79,,Archived,15,Ntag, -,,,Daping,location,viverra diam vitae,semper sapien,dapibus dolor vel,Flashset,3559785746335392,e287bb64-ff4f-434c-88ab-210ad433c77b,927820758-6,Achiaman,,2016-03-05,675.3,,Archived,22,Meevee, -EOT; - - $this->import(new AssetImporter($csv)); - - $user = User::where('username', 'bnelson0')->firstOrFail(); - - $this->tester->seeRecord('assets', [ - 'asset_tag' => '970882174-8', - 'assigned_type' => User::class, - 'assigned_to' => $user->id, - ]); - - $user = User::where('username', 'mgibson2')->firstOrFail(); - $this->tester->seeRecord('assets', [ - 'asset_tag' => '710141467-2', - 'assigned_type' => User::class, - 'assigned_to' => $user->id, - ]); - - $location = Location::where('name', 'Planet Earth')->firstOrFail(); - $this->tester->seeRecord('assets', [ - 'asset_tag' => '998233705-X', - 'assigned_type' => Location::class, - 'assigned_to' => $location->id, - ]); - - $location = Location::where('name', 'Daping')->firstOrFail(); - $this->tester->seeRecord('assets', [ - 'asset_tag' => '927820758-6', - 'assigned_type' => Location::class, - 'assigned_to' => $location->id, - ]); - } - - public function testUpdateAssetIncludingCustomFields() - { - $this->signIn(); - $csv = <<<'EOT' -Name,Email,Username,item Name,Category,Model name,Manufacturer,Model Number,Serial,Asset Tag,Location,Notes,Purchase Date,Purchase Cost,Company,Status,Warranty,Supplier,weight -Bonnie Nelson,bnelson0@cdbaby.com,bnelson0,eget nunc donec quis,quam,massa id,Linkbridge,6377018600094472,27aa8378-b0f4-4289-84a4-405da95c6147,970882174-8,Daping,"Curabitur in libero ut massa volutpat convallis. Morbi odio odio, elementum eu, interdum eu, tincidunt in, leo. Maecenas pulvinar lobortis est.",2016-04-05,133289.59,Alpha,Undeployable,14,Blogspan,95 -EOT; - - $this->initializeCustomFields(); - $this->import(new AssetImporter($csv)); - - $updatedCSV = <<<'EOT' -item Name,Category,Model name,Manufacturer,Model Number,Serial,Asset Tag,Location,Notes,Purchase Date,Purchase Cost,Company,Status,Warranty,Supplier -A new name,some other category,Another Model,Linkbridge 32,356,67433477,970882174-8,New Location,I have no notes,2018-04-05,25.59,Another Company,Ready To Go,18,Not Creative -EOT; - $importer = new AssetImporter($updatedCSV); - $importer->setUserId(1) - ->setUpdating(true) - ->setUsernameFormat('firstname.lastname') - ->import(); - - $this->tester->seeRecord('categories', [ - 'name' => 'some other category', - ]); - - $this->tester->seeRecord('models', [ - 'name' => 'Another Model', - 'model_number' => 356, - ]); - - $this->tester->seeRecord('manufacturers', [ - 'name' => 'Linkbridge 32', - ]); - - $this->tester->seeRecord('locations', [ - 'name' => 'New Location', - ]); - - $this->tester->seeRecord('companies', [ - 'name' => 'Another Company', - ]); - - $this->tester->seeRecord('status_labels', [ - 'name' => 'Ready To Go', - ]); - - $this->tester->seeRecord('suppliers', [ - 'name' => 'Not Creative', - ]); - - $this->tester->seeRecord('assets', [ - 'name' => 'A new name', - 'serial' => '67433477', - 'asset_tag' => '970882174-8', - 'notes' => 'I have no notes', - 'purchase_date' => '2018-04-05 00:00:01', - 'purchase_cost' => 25.59, - 'warranty_months' => 18, - '_snipeit_weight_2' => 95, - ]); - } - - public function testAssetModelNumber4359() - { - // As per bug #4359 - // 1) Create model with blank model # and custom field. - // 2 ) Update custom fields with a csv not including model # - // 3 ) Not updated. NULL vs. empty issue. - $this->signIn(); - $csv = <<<'EOT' -Name,Email,Username,item Name,Category,Model name,Manufacturer,Serial,Asset Tag,Location,Notes,Purchase Date,Purchase Cost,Company,Status,Warranty,Supplier -Bonnie Nelson,bnelson0@cdbaby.com,bnelson0,eget nunc donec quis,quam,massa id,Linkbridge,27aa8378-b0f4-4289-84a4-405da95c6147,970882174-8,Daping,"Curabitur in libero ut massa volutpat convallis. Morbi odio odio, elementum eu, interdum eu, tincidunt in, leo. Maecenas pulvinar lobortis est.",2016-04-05,133289.59,Alpha,Undeployable,14,Blogspan -EOT; - - // Need to do this manually... - $customField = \App\Models\CustomField::factory()->create(['name' => 'Weight']); - $customFieldSet = \App\Models\CustomFieldset::factory()->create(['name' => 'Default']); - $customFieldSet->fields()->attach($customField, [ - 'required' => false, - 'order' => 'asc', ]); - - \App\Models\Category::factory()->assetLaptopCategory()->create([ - 'name' => 'quam', - ]); - - \App\Models\Manufacturer::factory()->apple()->create([ - 'name' => 'Linkbridge', - ]); - - $am = \App\Models\AssetModel::factory()->create([ - 'name' => 'massa id', - 'fieldset_id' => $customFieldSet->id, - 'category_id' => 1, - 'manufacturer_id' => 1, - 'model_number' => null, - ]); - - $this->import(new AssetImporter($csv)); - $updatedCSV = <<<'EOT' -Serial,Asset Tag,weight -67433477,970882174-8,115 -EOT; - $importer = new AssetImporter($updatedCSV); - $importer->setUserId(1) - ->setUpdating(true) - ->setUsernameFormat('firstname.lastname') - ->import(); - - $this->tester->seeRecord('assets', [ - 'asset_tag' => '970882174-8', - '_snipeit_weight_2' => 115, - ]); - } - - public function initializeCustomFields() - { - $customField = \App\Models\CustomField::factory()->create(['name' => 'Weight']); - $customFieldSet = \App\Models\CustomFieldset::factory()->create(['name' => 'Default']); - $customFieldSet->fields()->attach($customField, [ - 'required' => false, - 'order' => 'asc', ]); - - $am = \App\Models\AssetModel::factory()->create([ - 'name' => 'massa id', - 'fieldset_id' => $customFieldSet->id, - ]); - } - - public function testCustomMappingImport() - { - $this->signIn(); - $csv = <<<'EOT' -Full Name,Email,Username,object name,Cat,Model name,Manufacturer,Model Number,Serial,Asset,Loc,Some Notes,Purchase Date,Purchase Cost,comp,Status,Warranty,Supplier -Bonnie Nelson,bnelson0@cdbaby.com,bnelson0,eget nunc donec quis,quam,massa id,Linkbridge,6377018600094472,27aa8378-b0f4-4289-84a4-405da95c6147,970882174-8,Daping,"Curabitur in libero ut massa volutpat convallis. Morbi odio odio, elementum eu, interdum eu, tincidunt in, leo. Maecenas pulvinar lobortis est.",2016-04-05,133289.59,Alpha,Undeployable,14,Blogspan -EOT; - - $customFieldMap = [ - 'asset_tag' => 'Asset', - 'category' => 'Cat', - 'company' => 'comp', - 'item_name' => 'object name', - 'expiration_date' => 'expiration date', - 'location' => 'loc', - 'notes' => 'Some Notes', - 'asset_model' => 'model name', - ]; - - $this->import(new AssetImporter($csv), $customFieldMap); - // Did we create a user? - $this->tester->seeRecord('users', [ - 'first_name' => 'Bonnie', - 'last_name' => 'Nelson', - 'email' => 'bnelson0@cdbaby.com', - ]); - // Grab the user record for use in asserting assigned_to - $createdUser = $this->tester->grabRecord('users', [ - 'first_name' => 'Bonnie', - 'last_name' => 'Nelson', - 'email' => 'bnelson0@cdbaby.com', - ]); - - $this->tester->seeRecord('categories', [ - 'name' => 'quam', - ]); - - $this->tester->seeRecord('models', [ - 'name' => 'massa id', - 'model_number' => 6377018600094472, - ]); - - $this->tester->seeRecord('manufacturers', [ - 'name' => 'Linkbridge', - ]); - - $this->tester->seeRecord('locations', [ - 'name' => 'Daping', - ]); - - $this->tester->seeRecord('companies', [ - 'name' => 'Alpha', - ]); - - $this->tester->seeRecord('status_labels', [ - 'name' => 'Undeployable', - ]); - - $this->tester->seeRecord('suppliers', [ - 'name' => 'Blogspan', - ]); - - $this->tester->seeRecord('assets', [ - 'name' => 'eget nunc donec quis', - 'serial' => '27aa8378-b0f4-4289-84a4-405da95c6147', - 'asset_tag' => '970882174-8', - 'notes' => 'Curabitur in libero ut massa volutpat convallis. Morbi odio odio, elementum eu, interdum eu, tincidunt in, leo. Maecenas pulvinar lobortis est.', - 'purchase_date' => '2016-04-05 00:00:01', - 'purchase_cost' => 133289.59, - 'warranty_months' => 14, - 'assigned_to' => $createdUser['id'], - 'assigned_type' => User::class, - ]); - } - - public function testDefaultAccessoryImport() - { - $csv = <<<'EOT' -Item Name,Purchase Date,Purchase Cost,Location,Company,Order Number,Category,Requestable,Quantity -Walter Carter,09/01/2006,,metus. Vivamus,Macromedia,J935H60W,Customers,False,278 -EOT; - $this->import(new AccessoryImporter($csv)); - $this->tester->seeRecord('accessories', [ - 'name' => 'Walter Carter', - 'purchase_date' => '2006-09-01 00:00:01', - 'order_number' => 'J935H60W', - 'requestable' => 0, - 'qty' => 278, - ]); - - $this->tester->seeRecord('locations', [ - 'name' => 'metus. Vivamus', - ]); - - $this->tester->seeRecord('companies', [ - 'name' => 'Macromedia', - ]); - - $this->tester->seeRecord('categories', [ - 'name' => 'Customers', - ]); - } - - public function testDefaultAccessoryUpdate() - { - $csv = <<<'EOT' -Item Name,Purchase Date,Purchase Cost,Location,Company,Order Number,Category,Requestable,Quantity -Walter Carter,09/01/2006,,metus. Vivamus,Macromedia,J935H60W,Customers,False,278 -EOT; - $this->import(new AccessoryImporter($csv)); - $this->tester->seeNumRecords(1, 'accessories'); - - $updatedCSV = <<<'EOT' -Item Name,Purchase Date,Purchase Cost,Location,Company,Order Number,Category,Requestable,Quantity -Walter Carter,09/01/2015,350,metus. Vivamus,Macromedia,35GGH,Customers,True,12 -EOT; - $importer = new AccessoryImporter($updatedCSV); - $importer->setUserId(1) - ->setUpdating(true) - ->import(); - // At this point we should still only have one record. - $this->tester->seeNumRecords(1, 'accessories'); - // But instead these. - $this->tester->seeRecord('accessories', [ - 'name' => 'Walter Carter', - 'purchase_date' => '2015-09-01 00:00:01', - 'order_number' => '35GGH', - 'requestable' => 1, - 'qty' => 12, - ]); - } - - public function testCustomAccessoryImport() - { - $csv = <<<'EOT' -Name,Pur Date,Cost,Loc,Comp,Order Num,Cat,Request,Quan -Walter Carter,09/01/2006,,metus. Vivamus,Macromedia,J935H60W,Customers,False,278 -EOT; - - $customFieldMap = [ - 'category' => 'Cat', - 'company' => 'Comp', - 'item_name' => 'Name', - 'location' => 'Loc', - 'purchase_date' => 'Pur Date', - 'purchase_cost' => 'Cost', - 'order_number' => 'Order Num', - 'requestable' => 'Request', - 'quantity' => 'Quan', - ]; - $this->import(new AccessoryImporter($csv), $customFieldMap); - // dd($this->tester->grabRecord('accessories')); - $this->tester->seeRecord('accessories', [ - 'name' => 'Walter Carter', - 'purchase_date' => '2006-09-01 00:00:01', - 'order_number' => 'J935H60W', - 'requestable' => 0, - 'qty' => 278, - ]); - - $this->tester->seeRecord('locations', [ - 'name' => 'metus. Vivamus', - ]); - - $this->tester->seeRecord('companies', [ - 'name' => 'Macromedia', - ]); - - $this->tester->seeRecord('categories', [ - 'name' => 'Customers', - ]); - } - - public function testDefaultConsumableImport() - { - $csv = <<<'EOT' -Item Name,Purchase Date,Purchase Cost,Location,Company,Order Number,Category,Requestable,Quantity,Item Number,Model Number -eget,01/03/2011,$85.91,mauris blandit mattis.,Lycos,T295T06V,Triamterene/Hydrochlorothiazide,No,322,3305,30123 -EOT; - $this->import(new ConsumableImporter($csv)); - $this->tester->seeRecord('consumables', [ - 'name' => 'eget', - 'purchase_date' => '2011-01-03 00:00:01', - 'purchase_cost' => 85.91, - 'order_number' => 'T295T06V', - 'requestable' => 0, - 'qty' => 322, - 'item_no' => 3305, - 'model_number' => 30123, - ]); - - $this->tester->seeRecord('locations', [ - 'name' => 'mauris blandit mattis.', - ]); - - $this->tester->seeRecord('companies', [ - 'name' => 'Lycos', - ]); - - $this->tester->seeRecord('categories', [ - 'name' => 'Triamterene/Hydrochlorothiazide', - ]); - } - - public function testDefaultConsumableUpdate() - { - $csv = <<<'EOT' -Item Name,Purchase Date,Purchase Cost,Location,Company,Order Number,Category,Requestable,Quantity -eget,01/03/2011,85.91,mauris blandit mattis.,Lycos,T295T06V,Triamterene/Hydrochlorothiazide,No,322 -EOT; - $this->import(new ConsumableImporter($csv)); - $this->tester->seeNumRecords(1, 'consumables'); - - $updatedCSV = <<<'EOT' -Item Name,Purchase Date,Purchase Cost,Location,Company,Order Number,Category,Requestable,Quantity -eget,12/05/2016,35.45,mauris blandit mattis.,Lycos,3666FF,New Cat,Yes,15 -EOT; - $importer = new ConsumableImporter($updatedCSV); - $importer->setUserId(1) - ->setUpdating(true) - ->import(); - // At this point we should still only have one record. - $this->tester->seeNumRecords(1, 'consumables'); - // But instead these. - $this->tester->seeRecord('consumables', [ - 'name' => 'eget', - 'purchase_date' => '2016-12-05 00:00:01', - 'purchase_cost' => 35.45, - 'order_number' => '3666FF', - 'requestable' => 1, - 'qty' => 15, - ]); - } - - public function testCustomConsumableImport() - { - $csv = <<<'EOT' -Name,pur Date,Pur Cost,Loc,Comp,Order Num,Kat,Request,Quan -eget,01/03/2011,85.91,mauris blandit mattis.,Lycos,T295T06V,Triamterene/Hydrochlorothiazide,No,322 -EOT; - - $customFieldMap = [ - 'category' => 'Kat', - 'company' => 'Comp', - 'item_name' => 'Name', - 'location' => 'Loc', - 'purchase_date' => 'Pur date', - 'purchase_cost' => 'Pur Cost', - 'order_number' => 'Order Num', - 'requestable' => 'Request', - 'quantity' => 'Quan', - ]; - $this->import(new ConsumableImporter($csv), $customFieldMap); - $this->tester->seeRecord('consumables', [ - 'name' => 'eget', - 'purchase_date' => '2011-01-03 00:00:01', - 'purchase_cost' => 85.91, - 'order_number' => 'T295T06V', - 'requestable' => 0, - 'qty' => 322, - ]); - - $this->tester->seeRecord('locations', [ - 'name' => 'mauris blandit mattis.', - ]); - - $this->tester->seeRecord('companies', [ - 'name' => 'Lycos', - ]); - - $this->tester->seeRecord('categories', [ - 'name' => 'Triamterene/Hydrochlorothiazide', - ]); - } - - public function testDefaultLicenseImport() - { - $this->signIn(); - $csv = <<<'EOT' -Full Name,Email,Username,Item name,serial,manufacturer,purchase date,purchase cost,purchase order,order number,Licensed To Name,Licensed to Email,expiration date,maintained,reassignable,seats,company,supplier,category,notes,asset tag -Helen Anderson,cspencer0@privacy.gov.au,cspencer0,Argentum Malachite Athletes Foot Relief,1aa5b0eb-79c5-40b2-8943-5472a6893c3c,"Beer, Leannon and Lubowitz",07/13/2012,$79.66,53008,386436062-5,Cynthia Spencer,cspencer0@gov.uk,01/27/2016,false,no,80,"Haag, Schmidt and Farrell","Hegmann, Mohr and Cremin",Graphics Software,Sed ante. Vivamus tortor. Duis mattis egestas metus.,test 1 -EOT; - - // Force create an asset to match the checkout - $testAsset = $this->createValidAsset(['asset_tag' => 'test 1']); - $this->import(new LicenseImporter($csv)); - // dd($this->tester->grabRecord('licenses')); - - // Did we create a user? - $this->tester->seeRecord('users', [ - 'first_name' => 'Helen', - 'last_name' => 'Anderson', - 'email' => 'cspencer0@privacy.gov.au', - ]); - // Grab the user record for use in asserting assigned_to - $createdUser = $this->tester->grabRecord('users', [ - 'first_name' => 'Helen', - 'last_name' => 'Anderson', - 'email' => 'cspencer0@privacy.gov.au', - ]); - $this->tester->seeRecord('licenses', [ - 'name' => 'Argentum Malachite Athletes Foot Relief', - 'purchase_date' => '2012-07-13 00:00:01', - 'seats' => 80, - 'license_email' => 'cspencer0@gov.uk', - 'order_number' => '386436062-5', - 'license_name' => 'Cynthia Spencer', - 'expiration_date' => '2016-01-27', - 'maintained' => 0, - 'notes' => 'Sed ante. Vivamus tortor. Duis mattis egestas metus.', - 'purchase_cost' => 79.66, - 'purchase_order' => '53008', - 'reassignable' => 0, - 'serial' => '1aa5b0eb-79c5-40b2-8943-5472a6893c3c', - ]); - $this->tester->seeRecord('manufacturers', [ - 'name' => 'Beer, Leannon and Lubowitz', - ]); - - $this->tester->seeRecord('suppliers', [ - 'name' => 'Hegmann, Mohr and Cremin', - ]); - - $this->tester->seeRecord('companies', [ - 'name' => 'Haag, Schmidt and Farrell', - ]); - - $this->tester->seeRecord('categories', [ - 'name' => 'Graphics Software', - ]); - - $this->tester->seeNumRecords(80, 'license_seats'); - $this->tester->seeRecord('license_seats', [ - 'assigned_to' => $createdUser['id'], - 'license_id' => \App\Models\License::where('serial', '1aa5b0eb-79c5-40b2-8943-5472a6893c3c')->first()->id, - 'asset_id' => $testAsset->id, - ]); - } - - public function testDefaultLicenseUpdate() - { - $csv = <<<'EOT' -Name,Email,Username,Item name,serial,manufacturer,purchase date,purchase cost,purchase order,order number,Licensed To Name,Licensed to Email,expiration date,maintained,reassignable,seats,company,supplier,category,notes -Helen Anderson,cspencer0@privacy.gov.au,cspencer0,Argentum Malachite Athletes Foot Relief,1aa5b0eb-79c5-40b2-8943-5472a6893c3c,"Beer, Leannon and Lubowitz",07/13/2012,$79.66,53008,386436062-5,Cynthia Spencer,cspencer0@gov.uk,01/27/2016,false,no,80,"Haag, Schmidt and Farrell","Hegmann, Mohr and Cremin",Graphics Software,Sed ante. Vivamus tortor. Duis mattis egestas metus. -EOT; - $this->import(new LicenseImporter($csv)); - $this->tester->seeNumRecords(1, 'licenses'); - - $updatedCSV = <<<'EOT' -Item name,serial,manufacturer,purchase date,purchase cost,purchase order,order number,Licensed To Name,Licensed to Email,expiration date,maintained,reassignable,seats,company,supplier,category,notes -Argentum Malachite Athletes Foot Relief,1aa5b0eb-79c5-40b2-8943-5472a6893c3c,"Beer, Leannon and Lubowitz",05/15/2019,$1865.34,63 ar,18334,A Legend,Legendary@gov.uk,04/27/2016,yes,true,64,"Haag, Schmidt and Farrell","Hegmann, Mohr and Cremin",Graphics Software,Sed ante. Vivamus tortor. Duis mattis egestas metus. -EOT; - $importer = new LicenseImporter($updatedCSV); - $importer->setUserId(1) - ->setUpdating(true) - ->import(); - // At this point we should still only have one record. - $this->tester->seeNumRecords(1, 'licenses'); - // But instead these. - - \Log::debug($this->tester->grabRecord('licenses')); - $this->tester->seeRecord('licenses', [ - 'name' => 'Argentum Malachite Athletes Foot Relief', - 'purchase_date' => '2019-05-15 00:00:01', - 'seats' => 64, - 'license_email' => 'Legendary@gov.uk', - 'order_number' => '18334', - 'license_name' => 'A Legend', - 'expiration_date' => '2016-04-27', - 'maintained' => 1, - 'notes' => 'Sed ante. Vivamus tortor. Duis mattis egestas metus.', - 'purchase_cost' => 1865.34, - 'purchase_order' => '63 ar', - 'reassignable' => 1, - 'serial' => '1aa5b0eb-79c5-40b2-8943-5472a6893c3c', - ]); - // License seats are soft deleted - $this->tester->seeNumRecords(64, 'license_seats', ['deleted_at' => null]); - } - - public function testCustomLicenseImport() - { - $csv = <<<'EOT' -Name,Email,Username,Object name,serial num,manuf,pur date,pur cost,purc order,order num,Licensed To,Licensed Email,expire date,maint,reass,seat,comp,supplier,category,note -Helen Anderson,cspencer0@privacy.gov.au,cspencer0,Argentum Malachite Athletes Foot Relief,1aa5b0eb-79c5-40b2-8943-5472a6893c3c,"Beer, Leannon and Lubowitz",07/13/2012,$79.66,53008,386436062-5,Cynthia Spencer,cspencer0@gov.uk,01/27/2016,false,no,80,"Haag, Schmidt and Farrell","Hegmann, Mohr and Cremin",Custom Graphics Software,Sed ante. Vivamus tortor. Duis mattis egestas metus. -EOT; - - $customFieldMap = [ - 'company' => 'Comp', - 'expiration_date' => 'expire date', - 'item_name' => 'Object Name', - 'license_email' => 'licensed email', - 'license_name' => 'licensed to', - 'maintained' => 'maint', - 'manufacturer' => 'manuf', - 'notes' => 'note', - 'order_number' => 'Order Num', - 'purchase_cost' => 'Pur Cost', - 'purchase_date' => 'Pur date', - 'purchase_order' => 'Purc Order', - 'quantity' => 'Quan', - 'reassignable' => 'reass', - 'requestable' => 'Request', - 'seats' => 'seat', - 'serial' => 'serial num', - 'category' => 'category', - ]; - $this->import(new LicenseImporter($csv), $customFieldMap); - $this->tester->seeRecord('licenses', [ - 'name' => 'Argentum Malachite Athletes Foot Relief', - 'purchase_date' => '2012-07-13 00:00:01', - 'seats' => 80, - 'license_email' => 'cspencer0@gov.uk', - 'order_number' => '386436062-5', - 'license_name' => 'Cynthia Spencer', - 'expiration_date' => '2016-01-27', - 'maintained' => 0, - 'notes' => 'Sed ante. Vivamus tortor. Duis mattis egestas metus.', - 'purchase_cost' => 79.66, - 'purchase_order' => '53008', - 'reassignable' => 0, - 'serial' => '1aa5b0eb-79c5-40b2-8943-5472a6893c3c', - ]); - - $this->tester->seeRecord('manufacturers', [ - 'name' => 'Beer, Leannon and Lubowitz', - ]); - - $this->tester->seeRecord('suppliers', [ - 'name' => 'Hegmann, Mohr and Cremin', - ]); - - $this->tester->seeRecord('companies', [ - 'name' => 'Haag, Schmidt and Farrell', - ]); - - $this->tester->seeNumRecords(80, 'license_seats'); - } - - public function testDefaultUserImport() - { - Notification::fake(); - $this->signIn(); - $csv = <<<'EOT' -First Name,Last Name,email,Username,Location,Phone Number,Job Title,Employee Number,Company,Department,activated -Blanche,O'Collopy,bocollopy0@livejournal.com,bocollopy0,Hinapalanan,63-(199)661-2186,Clinical Specialist,7080919053,Morar-Ward,Management,1 -Jessie,Primo,,jprimo1,Korenovsk,7-(885)578-0266,Paralegal,6284292031,Jast-Stiedemann,1 - -EOT; - $user_importer = new UserImporter($csv); - $user_importer->sendWelcome(); - $this->import($user_importer); - - $this->tester->seeRecord('users', [ - 'first_name' => 'Blanche', - 'last_name' => "O'Collopy", - 'email' => 'bocollopy0@livejournal.com', - 'username' => 'bocollopy0', - 'phone' => '63-(199)661-2186', - 'jobtitle' => 'Clinical Specialist', - 'employee_num' => '7080919053', - ]); - - $this->tester->seeRecord('companies', [ - 'name' => 'Morar-Ward', - ]); - - $this->tester->seeRecord('departments', [ - 'name' => 'Management', - ]); - - Notification::assertSentTo(User::find(2), \App\Notifications\WelcomeNotification::class); - Notification::assertNotSentTo(User::find(3), \App\Notifications\WelcomeNotification::class); - } - - private function import($importer, $mappings = null) - { - if ($mappings) { - $importer->setFieldMappings($mappings); - } - $importer->setUserId(1) - ->setUpdating(false) - ->setUsernameFormat('firstname.lastname') - ->import(); - } +// protected $tester; + +// public function testDefaultImportAssetWithCustomFields() +// { +// $this->signIn(); +// $csv = <<<'EOT' +// Full Name,Email,Username,item Name,Category,Model name,Manufacturer,Model Number,Serial,Asset Tag,Location,Notes,Purchase Date,Purchase Cost,Company,Status,Warranty,Supplier,Weight +// Bonnie Nelson,bnelson0@cdbaby.com,bnelson0,eget nunc donec quis,quam,massa id,Linkbridge,6377018600094472,27aa8378-b0f4-4289-84a4-405da95c6147,970882174-8,Daping,"Curabitur in libero ut massa volutpat convallis. Morbi odio odio, elementum eu, interdum eu, tincidunt in, leo. Maecenas pulvinar lobortis est.",2016-04-05,133289.59,Alpha,Undeployable,14,Blogspan,35 +// EOT; + +// $this->initializeCustomFields(); +// $this->import(new AssetImporter($csv)); + +// $this->tester->seeRecord('users', [ +// 'first_name' => 'Bonnie', +// 'last_name' => 'Nelson', +// 'email' => 'bnelson0@cdbaby.com', +// ]); +// $this->tester->seeRecord('categories', [ +// 'name' => 'quam', +// ]); + +// $this->tester->seeRecord('models', [ +// 'name' => 'massa id', +// 'model_number' => 6377018600094472, +// ]); + +// $this->tester->seeRecord('manufacturers', [ +// 'name' => 'Linkbridge', +// ]); + +// $this->tester->seeRecord('locations', [ +// 'name' => 'Daping', +// ]); + +// $this->tester->seeRecord('companies', [ +// 'name' => 'Alpha', +// ]); + +// $this->tester->seeRecord('status_labels', [ +// 'name' => 'Undeployable', +// ]); + +// $this->tester->seeRecord('suppliers', [ +// 'name' => 'Blogspan', +// ]); + +// $this->tester->seeRecord('assets', [ +// 'name' => 'eget nunc donec quis', +// 'serial' => '27aa8378-b0f4-4289-84a4-405da95c6147', +// 'asset_tag' => '970882174-8', +// 'notes' => 'Curabitur in libero ut massa volutpat convallis. Morbi odio odio, elementum eu, interdum eu, tincidunt in, leo. Maecenas pulvinar lobortis est.', +// 'purchase_date' => '2016-04-05 00:00:01', +// 'purchase_cost' => 133289.59, 'warranty_months' => 14, +// '_snipeit_weight_2' => 35, +// ]); +// } + +// public function testImportCheckoutToLocation() +// { +// $this->signIn(); + +// // Testing in order: +// // * Asset to user, no checkout type defined (default to user). +// // * Asset to user, explicit user checkout type (Checkout to user) +// // * Asset to location, location does not exist to begin with +// // * Asset to preexisting location. +// $csv = <<<'EOT' +// Full Name,Email,Username,Checkout Location,Checkout Type,item Name,Category,Model name,Manufacturer,Model Number,Serial,Asset Tag,Location,Notes,Purchase Date,Purchase Cost,Company,Status,Warranty,Supplier,Weight +// Bonnie Nelson,bnelson0@cdbaby.com,bnelson0,,,eget nunc donec quis,quam,massa id,Linkbridge,6377018600094472,27aa8378-b0f4-4289-84a4-405da95c6147,970882174-8,Daping,"Curabitur in libero ut massa volutpat convallis. Morbi odio odio, elementum eu, interdum eu, tincidunt in, leo. Maecenas pulvinar lobortis est.",2016-04-05,133289.59,Alpha,Undeployable,14,Blogspan,35 +// Mildred Gibson,mgibson2@wiley.com,mgibson2,,user,morbi quis tortor id,nunc nisl duis,convallis tortor risus,Lajo,374622546776765,2837ab20-8f0d-4935-8a52-226392f2b1b0,710141467-2,Shekou,In congue. Etiam justo. Etiam pretium iaculis justo.,2015-08-09,233.57,Konklab,Lost,,, +// ,,,Planet Earth,location,dictumst maecenas ut,sem praesent,accumsan felis,Layo,30052522651756,4751495c-cee0-4961-b788-94a545b5643e,998233705-X,Dante Delgado,,2016-04-16,261.79,,Archived,15,Ntag, +// ,,,Daping,location,viverra diam vitae,semper sapien,dapibus dolor vel,Flashset,3559785746335392,e287bb64-ff4f-434c-88ab-210ad433c77b,927820758-6,Achiaman,,2016-03-05,675.3,,Archived,22,Meevee, +// EOT; + +// $this->import(new AssetImporter($csv)); + +// $user = User::where('username', 'bnelson0')->firstOrFail(); + +// $this->tester->seeRecord('assets', [ +// 'asset_tag' => '970882174-8', +// 'assigned_type' => User::class, +// 'assigned_to' => $user->id, +// ]); + +// $user = User::where('username', 'mgibson2')->firstOrFail(); +// $this->tester->seeRecord('assets', [ +// 'asset_tag' => '710141467-2', +// 'assigned_type' => User::class, +// 'assigned_to' => $user->id, +// ]); + +// $location = Location::where('name', 'Planet Earth')->firstOrFail(); +// $this->tester->seeRecord('assets', [ +// 'asset_tag' => '998233705-X', +// 'assigned_type' => Location::class, +// 'assigned_to' => $location->id, +// ]); + +// $location = Location::where('name', 'Daping')->firstOrFail(); +// $this->tester->seeRecord('assets', [ +// 'asset_tag' => '927820758-6', +// 'assigned_type' => Location::class, +// 'assigned_to' => $location->id, +// ]); +// } + +// public function testUpdateAssetIncludingCustomFields() +// { +// $this->signIn(); +// $csv = <<<'EOT' +// Name,Email,Username,item Name,Category,Model name,Manufacturer,Model Number,Serial,Asset Tag,Location,Notes,Purchase Date,Purchase Cost,Company,Status,Warranty,Supplier,weight +// Bonnie Nelson,bnelson0@cdbaby.com,bnelson0,eget nunc donec quis,quam,massa id,Linkbridge,6377018600094472,27aa8378-b0f4-4289-84a4-405da95c6147,970882174-8,Daping,"Curabitur in libero ut massa volutpat convallis. Morbi odio odio, elementum eu, interdum eu, tincidunt in, leo. Maecenas pulvinar lobortis est.",2016-04-05,133289.59,Alpha,Undeployable,14,Blogspan,95 +// EOT; + +// $this->initializeCustomFields(); +// $this->import(new AssetImporter($csv)); + +// $updatedCSV = <<<'EOT' +// item Name,Category,Model name,Manufacturer,Model Number,Serial,Asset Tag,Location,Notes,Purchase Date,Purchase Cost,Company,Status,Warranty,Supplier +// A new name,some other category,Another Model,Linkbridge 32,356,67433477,970882174-8,New Location,I have no notes,2018-04-05,25.59,Another Company,Ready To Go,18,Not Creative +// EOT; +// $importer = new AssetImporter($updatedCSV); +// $importer->setUserId(1) +// ->setUpdating(true) +// ->setUsernameFormat('firstname.lastname') +// ->import(); + +// $this->tester->seeRecord('categories', [ +// 'name' => 'some other category', +// ]); + +// $this->tester->seeRecord('models', [ +// 'name' => 'Another Model', +// 'model_number' => 356, +// ]); + +// $this->tester->seeRecord('manufacturers', [ +// 'name' => 'Linkbridge 32', +// ]); + +// $this->tester->seeRecord('locations', [ +// 'name' => 'New Location', +// ]); + +// $this->tester->seeRecord('companies', [ +// 'name' => 'Another Company', +// ]); + +// $this->tester->seeRecord('status_labels', [ +// 'name' => 'Ready To Go', +// ]); + +// $this->tester->seeRecord('suppliers', [ +// 'name' => 'Not Creative', +// ]); + +// $this->tester->seeRecord('assets', [ +// 'name' => 'A new name', +// 'serial' => '67433477', +// 'asset_tag' => '970882174-8', +// 'notes' => 'I have no notes', +// 'purchase_date' => '2018-04-05 00:00:01', +// 'purchase_cost' => 25.59, +// 'warranty_months' => 18, +// '_snipeit_weight_2' => 95, +// ]); +// } + +// public function testAssetModelNumber4359() +// { +// // As per bug #4359 +// // 1) Create model with blank model # and custom field. +// // 2 ) Update custom fields with a csv not including model # +// // 3 ) Not updated. NULL vs. empty issue. +// $this->signIn(); +// $csv = <<<'EOT' +// Name,Email,Username,item Name,Category,Model name,Manufacturer,Serial,Asset Tag,Location,Notes,Purchase Date,Purchase Cost,Company,Status,Warranty,Supplier +// Bonnie Nelson,bnelson0@cdbaby.com,bnelson0,eget nunc donec quis,quam,massa id,Linkbridge,27aa8378-b0f4-4289-84a4-405da95c6147,970882174-8,Daping,"Curabitur in libero ut massa volutpat convallis. Morbi odio odio, elementum eu, interdum eu, tincidunt in, leo. Maecenas pulvinar lobortis est.",2016-04-05,133289.59,Alpha,Undeployable,14,Blogspan +// EOT; + +// // Need to do this manually... +// $customField = \App\Models\CustomField::factory()->create(['name' => 'Weight']); +// $customFieldSet = \App\Models\CustomFieldset::factory()->create(['name' => 'Default']); +// $customFieldSet->fields()->attach($customField, [ +// 'required' => false, +// 'order' => 'asc', ]); + +// \App\Models\Category::factory()->assetLaptopCategory()->create([ +// 'name' => 'quam', +// ]); + +// \App\Models\Manufacturer::factory()->apple()->create([ +// 'name' => 'Linkbridge', +// ]); + +// $am = \App\Models\AssetModel::factory()->create([ +// 'name' => 'massa id', +// 'fieldset_id' => $customFieldSet->id, +// 'category_id' => 1, +// 'manufacturer_id' => 1, +// 'model_number' => null, +// ]); + +// $this->import(new AssetImporter($csv)); +// $updatedCSV = <<<'EOT' +// Serial,Asset Tag,weight +// 67433477,970882174-8,115 +// EOT; +// $importer = new AssetImporter($updatedCSV); +// $importer->setUserId(1) +// ->setUpdating(true) +// ->setUsernameFormat('firstname.lastname') +// ->import(); + +// $this->tester->seeRecord('assets', [ +// 'asset_tag' => '970882174-8', +// '_snipeit_weight_2' => 115, +// ]); +// } + +// public function initializeCustomFields() +// { +// $customField = \App\Models\CustomField::factory()->create(['name' => 'Weight']); +// $customFieldSet = \App\Models\CustomFieldset::factory()->create(['name' => 'Default']); +// $customFieldSet->fields()->attach($customField, [ +// 'required' => false, +// 'order' => 'asc', ]); + +// $am = \App\Models\AssetModel::factory()->create([ +// 'name' => 'massa id', +// 'fieldset_id' => $customFieldSet->id, +// ]); +// } + +// public function testCustomMappingImport() +// { +// $this->signIn(); +// $csv = <<<'EOT' +// Full Name,Email,Username,object name,Cat,Model name,Manufacturer,Model Number,Serial,Asset,Loc,Some Notes,Purchase Date,Purchase Cost,comp,Status,Warranty,Supplier +// Bonnie Nelson,bnelson0@cdbaby.com,bnelson0,eget nunc donec quis,quam,massa id,Linkbridge,6377018600094472,27aa8378-b0f4-4289-84a4-405da95c6147,970882174-8,Daping,"Curabitur in libero ut massa volutpat convallis. Morbi odio odio, elementum eu, interdum eu, tincidunt in, leo. Maecenas pulvinar lobortis est.",2016-04-05,133289.59,Alpha,Undeployable,14,Blogspan +// EOT; + +// $customFieldMap = [ +// 'asset_tag' => 'Asset', +// 'category' => 'Cat', +// 'company' => 'comp', +// 'item_name' => 'object name', +// 'expiration_date' => 'expiration date', +// 'location' => 'loc', +// 'notes' => 'Some Notes', +// 'asset_model' => 'model name', +// ]; + +// $this->import(new AssetImporter($csv), $customFieldMap); +// // Did we create a user? +// $this->tester->seeRecord('users', [ +// 'first_name' => 'Bonnie', +// 'last_name' => 'Nelson', +// 'email' => 'bnelson0@cdbaby.com', +// ]); +// // Grab the user record for use in asserting assigned_to +// $createdUser = $this->tester->grabRecord('users', [ +// 'first_name' => 'Bonnie', +// 'last_name' => 'Nelson', +// 'email' => 'bnelson0@cdbaby.com', +// ]); + +// $this->tester->seeRecord('categories', [ +// 'name' => 'quam', +// ]); + +// $this->tester->seeRecord('models', [ +// 'name' => 'massa id', +// 'model_number' => 6377018600094472, +// ]); + +// $this->tester->seeRecord('manufacturers', [ +// 'name' => 'Linkbridge', +// ]); + +// $this->tester->seeRecord('locations', [ +// 'name' => 'Daping', +// ]); + +// $this->tester->seeRecord('companies', [ +// 'name' => 'Alpha', +// ]); + +// $this->tester->seeRecord('status_labels', [ +// 'name' => 'Undeployable', +// ]); + +// $this->tester->seeRecord('suppliers', [ +// 'name' => 'Blogspan', +// ]); + +// $this->tester->seeRecord('assets', [ +// 'name' => 'eget nunc donec quis', +// 'serial' => '27aa8378-b0f4-4289-84a4-405da95c6147', +// 'asset_tag' => '970882174-8', +// 'notes' => 'Curabitur in libero ut massa volutpat convallis. Morbi odio odio, elementum eu, interdum eu, tincidunt in, leo. Maecenas pulvinar lobortis est.', +// 'purchase_date' => '2016-04-05 00:00:01', +// 'purchase_cost' => 133289.59, +// 'warranty_months' => 14, +// 'assigned_to' => $createdUser['id'], +// 'assigned_type' => User::class, +// ]); +// } + +// public function testDefaultAccessoryImport() +// { +// $csv = <<<'EOT' +// Item Name,Purchase Date,Purchase Cost,Location,Company,Order Number,Category,Requestable,Quantity +// Walter Carter,09/01/2006,,metus. Vivamus,Macromedia,J935H60W,Customers,False,278 +// EOT; +// $this->import(new AccessoryImporter($csv)); +// $this->tester->seeRecord('accessories', [ +// 'name' => 'Walter Carter', +// 'purchase_date' => '2006-09-01 00:00:01', +// 'order_number' => 'J935H60W', +// 'requestable' => 0, +// 'qty' => 278, +// ]); + +// $this->tester->seeRecord('locations', [ +// 'name' => 'metus. Vivamus', +// ]); + +// $this->tester->seeRecord('companies', [ +// 'name' => 'Macromedia', +// ]); + +// $this->tester->seeRecord('categories', [ +// 'name' => 'Customers', +// ]); +// } + +// public function testDefaultAccessoryUpdate() +// { +// $csv = <<<'EOT' +// Item Name,Purchase Date,Purchase Cost,Location,Company,Order Number,Category,Requestable,Quantity +// Walter Carter,09/01/2006,,metus. Vivamus,Macromedia,J935H60W,Customers,False,278 +// EOT; +// $this->import(new AccessoryImporter($csv)); +// $this->tester->seeNumRecords(1, 'accessories'); + +// $updatedCSV = <<<'EOT' +// Item Name,Purchase Date,Purchase Cost,Location,Company,Order Number,Category,Requestable,Quantity +// Walter Carter,09/01/2015,350,metus. Vivamus,Macromedia,35GGH,Customers,True,12 +// EOT; +// $importer = new AccessoryImporter($updatedCSV); +// $importer->setUserId(1) +// ->setUpdating(true) +// ->import(); +// // At this point we should still only have one record. +// $this->tester->seeNumRecords(1, 'accessories'); +// // But instead these. +// $this->tester->seeRecord('accessories', [ +// 'name' => 'Walter Carter', +// 'purchase_date' => '2015-09-01 00:00:01', +// 'order_number' => '35GGH', +// 'requestable' => 1, +// 'qty' => 12, +// ]); +// } + +// public function testCustomAccessoryImport() +// { +// $csv = <<<'EOT' +// Name,Pur Date,Cost,Loc,Comp,Order Num,Cat,Request,Quan +// Walter Carter,09/01/2006,,metus. Vivamus,Macromedia,J935H60W,Customers,False,278 +// EOT; + +// $customFieldMap = [ +// 'category' => 'Cat', +// 'company' => 'Comp', +// 'item_name' => 'Name', +// 'location' => 'Loc', +// 'purchase_date' => 'Pur Date', +// 'purchase_cost' => 'Cost', +// 'order_number' => 'Order Num', +// 'requestable' => 'Request', +// 'quantity' => 'Quan', +// ]; +// $this->import(new AccessoryImporter($csv), $customFieldMap); +// // dd($this->tester->grabRecord('accessories')); +// $this->tester->seeRecord('accessories', [ +// 'name' => 'Walter Carter', +// 'purchase_date' => '2006-09-01 00:00:01', +// 'order_number' => 'J935H60W', +// 'requestable' => 0, +// 'qty' => 278, +// ]); + +// $this->tester->seeRecord('locations', [ +// 'name' => 'metus. Vivamus', +// ]); + +// $this->tester->seeRecord('companies', [ +// 'name' => 'Macromedia', +// ]); + +// $this->tester->seeRecord('categories', [ +// 'name' => 'Customers', +// ]); +// } + +// public function testDefaultConsumableImport() +// { +// $csv = <<<'EOT' +// Item Name,Purchase Date,Purchase Cost,Location,Company,Order Number,Category,Requestable,Quantity,Item Number,Model Number +// eget,01/03/2011,$85.91,mauris blandit mattis.,Lycos,T295T06V,Triamterene/Hydrochlorothiazide,No,322,3305,30123 +// EOT; +// $this->import(new ConsumableImporter($csv)); +// $this->tester->seeRecord('consumables', [ +// 'name' => 'eget', +// 'purchase_date' => '2011-01-03 00:00:01', +// 'purchase_cost' => 85.91, +// 'order_number' => 'T295T06V', +// 'requestable' => 0, +// 'qty' => 322, +// 'item_no' => 3305, +// 'model_number' => 30123, +// ]); + +// $this->tester->seeRecord('locations', [ +// 'name' => 'mauris blandit mattis.', +// ]); + +// $this->tester->seeRecord('companies', [ +// 'name' => 'Lycos', +// ]); + +// $this->tester->seeRecord('categories', [ +// 'name' => 'Triamterene/Hydrochlorothiazide', +// ]); +// } + +// public function testDefaultConsumableUpdate() +// { +// $csv = <<<'EOT' +// Item Name,Purchase Date,Purchase Cost,Location,Company,Order Number,Category,Requestable,Quantity +// eget,01/03/2011,85.91,mauris blandit mattis.,Lycos,T295T06V,Triamterene/Hydrochlorothiazide,No,322 +// EOT; +// $this->import(new ConsumableImporter($csv)); +// $this->tester->seeNumRecords(1, 'consumables'); + +// $updatedCSV = <<<'EOT' +// Item Name,Purchase Date,Purchase Cost,Location,Company,Order Number,Category,Requestable,Quantity +// eget,12/05/2016,35.45,mauris blandit mattis.,Lycos,3666FF,New Cat,Yes,15 +// EOT; +// $importer = new ConsumableImporter($updatedCSV); +// $importer->setUserId(1) +// ->setUpdating(true) +// ->import(); +// // At this point we should still only have one record. +// $this->tester->seeNumRecords(1, 'consumables'); +// // But instead these. +// $this->tester->seeRecord('consumables', [ +// 'name' => 'eget', +// 'purchase_date' => '2016-12-05 00:00:01', +// 'purchase_cost' => 35.45, +// 'order_number' => '3666FF', +// 'requestable' => 1, +// 'qty' => 15, +// ]); +// } + +// public function testCustomConsumableImport() +// { +// $csv = <<<'EOT' +// Name,pur Date,Pur Cost,Loc,Comp,Order Num,Kat,Request,Quan +// eget,01/03/2011,85.91,mauris blandit mattis.,Lycos,T295T06V,Triamterene/Hydrochlorothiazide,No,322 +// EOT; + +// $customFieldMap = [ +// 'category' => 'Kat', +// 'company' => 'Comp', +// 'item_name' => 'Name', +// 'location' => 'Loc', +// 'purchase_date' => 'Pur date', +// 'purchase_cost' => 'Pur Cost', +// 'order_number' => 'Order Num', +// 'requestable' => 'Request', +// 'quantity' => 'Quan', +// ]; +// $this->import(new ConsumableImporter($csv), $customFieldMap); +// $this->tester->seeRecord('consumables', [ +// 'name' => 'eget', +// 'purchase_date' => '2011-01-03 00:00:01', +// 'purchase_cost' => 85.91, +// 'order_number' => 'T295T06V', +// 'requestable' => 0, +// 'qty' => 322, +// ]); + +// $this->tester->seeRecord('locations', [ +// 'name' => 'mauris blandit mattis.', +// ]); + +// $this->tester->seeRecord('companies', [ +// 'name' => 'Lycos', +// ]); + +// $this->tester->seeRecord('categories', [ +// 'name' => 'Triamterene/Hydrochlorothiazide', +// ]); +// } + +// public function testDefaultLicenseImport() +// { +// $this->signIn(); +// $csv = <<<'EOT' +// Full Name,Email,Username,Item name,serial,manufacturer,purchase date,purchase cost,purchase order,order number,Licensed To Name,Licensed to Email,expiration date,maintained,reassignable,seats,company,supplier,category,notes,asset tag +// Helen Anderson,cspencer0@privacy.gov.au,cspencer0,Argentum Malachite Athletes Foot Relief,1aa5b0eb-79c5-40b2-8943-5472a6893c3c,"Beer, Leannon and Lubowitz",07/13/2012,$79.66,53008,386436062-5,Cynthia Spencer,cspencer0@gov.uk,01/27/2016,false,no,80,"Haag, Schmidt and Farrell","Hegmann, Mohr and Cremin",Graphics Software,Sed ante. Vivamus tortor. Duis mattis egestas metus.,test 1 +// EOT; + +// // Force create an asset to match the checkout +// $testAsset = $this->createValidAsset(['asset_tag' => 'test 1']); +// $this->import(new LicenseImporter($csv)); +// // dd($this->tester->grabRecord('licenses')); + +// // Did we create a user? +// $this->tester->seeRecord('users', [ +// 'first_name' => 'Helen', +// 'last_name' => 'Anderson', +// 'email' => 'cspencer0@privacy.gov.au', +// ]); +// // Grab the user record for use in asserting assigned_to +// $createdUser = $this->tester->grabRecord('users', [ +// 'first_name' => 'Helen', +// 'last_name' => 'Anderson', +// 'email' => 'cspencer0@privacy.gov.au', +// ]); +// $this->tester->seeRecord('licenses', [ +// 'name' => 'Argentum Malachite Athletes Foot Relief', +// 'purchase_date' => '2012-07-13 00:00:01', +// 'seats' => 80, +// 'license_email' => 'cspencer0@gov.uk', +// 'order_number' => '386436062-5', +// 'license_name' => 'Cynthia Spencer', +// 'expiration_date' => '2016-01-27', +// 'maintained' => 0, +// 'notes' => 'Sed ante. Vivamus tortor. Duis mattis egestas metus.', +// 'purchase_cost' => 79.66, +// 'purchase_order' => '53008', +// 'reassignable' => 0, +// 'serial' => '1aa5b0eb-79c5-40b2-8943-5472a6893c3c', +// ]); +// $this->tester->seeRecord('manufacturers', [ +// 'name' => 'Beer, Leannon and Lubowitz', +// ]); + +// $this->tester->seeRecord('suppliers', [ +// 'name' => 'Hegmann, Mohr and Cremin', +// ]); + +// $this->tester->seeRecord('companies', [ +// 'name' => 'Haag, Schmidt and Farrell', +// ]); + +// $this->tester->seeRecord('categories', [ +// 'name' => 'Graphics Software', +// ]); + +// $this->tester->seeNumRecords(80, 'license_seats'); +// $this->tester->seeRecord('license_seats', [ +// 'assigned_to' => $createdUser['id'], +// 'license_id' => \App\Models\License::where('serial', '1aa5b0eb-79c5-40b2-8943-5472a6893c3c')->first()->id, +// 'asset_id' => $testAsset->id, +// ]); +// } + +// public function testDefaultLicenseUpdate() +// { +// $csv = <<<'EOT' +// Name,Email,Username,Item name,serial,manufacturer,purchase date,purchase cost,purchase order,order number,Licensed To Name,Licensed to Email,expiration date,maintained,reassignable,seats,company,supplier,category,notes +// Helen Anderson,cspencer0@privacy.gov.au,cspencer0,Argentum Malachite Athletes Foot Relief,1aa5b0eb-79c5-40b2-8943-5472a6893c3c,"Beer, Leannon and Lubowitz",07/13/2012,$79.66,53008,386436062-5,Cynthia Spencer,cspencer0@gov.uk,01/27/2016,false,no,80,"Haag, Schmidt and Farrell","Hegmann, Mohr and Cremin",Graphics Software,Sed ante. Vivamus tortor. Duis mattis egestas metus. +// EOT; +// $this->import(new LicenseImporter($csv)); +// $this->tester->seeNumRecords(1, 'licenses'); + +// $updatedCSV = <<<'EOT' +// Item name,serial,manufacturer,purchase date,purchase cost,purchase order,order number,Licensed To Name,Licensed to Email,expiration date,maintained,reassignable,seats,company,supplier,category,notes +// Argentum Malachite Athletes Foot Relief,1aa5b0eb-79c5-40b2-8943-5472a6893c3c,"Beer, Leannon and Lubowitz",05/15/2019,$1865.34,63 ar,18334,A Legend,Legendary@gov.uk,04/27/2016,yes,true,64,"Haag, Schmidt and Farrell","Hegmann, Mohr and Cremin",Graphics Software,Sed ante. Vivamus tortor. Duis mattis egestas metus. +// EOT; +// $importer = new LicenseImporter($updatedCSV); +// $importer->setUserId(1) +// ->setUpdating(true) +// ->import(); +// // At this point we should still only have one record. +// $this->tester->seeNumRecords(1, 'licenses'); +// // But instead these. + +// \Log::debug($this->tester->grabRecord('licenses')); +// $this->tester->seeRecord('licenses', [ +// 'name' => 'Argentum Malachite Athletes Foot Relief', +// 'purchase_date' => '2019-05-15 00:00:01', +// 'seats' => 64, +// 'license_email' => 'Legendary@gov.uk', +// 'order_number' => '18334', +// 'license_name' => 'A Legend', +// 'expiration_date' => '2016-04-27', +// 'maintained' => 1, +// 'notes' => 'Sed ante. Vivamus tortor. Duis mattis egestas metus.', +// 'purchase_cost' => 1865.34, +// 'purchase_order' => '63 ar', +// 'reassignable' => 1, +// 'serial' => '1aa5b0eb-79c5-40b2-8943-5472a6893c3c', +// ]); +// // License seats are soft deleted +// $this->tester->seeNumRecords(64, 'license_seats', ['deleted_at' => null]); +// } + +// public function testCustomLicenseImport() +// { +// $csv = <<<'EOT' +// Name,Email,Username,Object name,serial num,manuf,pur date,pur cost,purc order,order num,Licensed To,Licensed Email,expire date,maint,reass,seat,comp,supplier,category,note +// Helen Anderson,cspencer0@privacy.gov.au,cspencer0,Argentum Malachite Athletes Foot Relief,1aa5b0eb-79c5-40b2-8943-5472a6893c3c,"Beer, Leannon and Lubowitz",07/13/2012,$79.66,53008,386436062-5,Cynthia Spencer,cspencer0@gov.uk,01/27/2016,false,no,80,"Haag, Schmidt and Farrell","Hegmann, Mohr and Cremin",Custom Graphics Software,Sed ante. Vivamus tortor. Duis mattis egestas metus. +// EOT; + +// $customFieldMap = [ +// 'company' => 'Comp', +// 'expiration_date' => 'expire date', +// 'item_name' => 'Object Name', +// 'license_email' => 'licensed email', +// 'license_name' => 'licensed to', +// 'maintained' => 'maint', +// 'manufacturer' => 'manuf', +// 'notes' => 'note', +// 'order_number' => 'Order Num', +// 'purchase_cost' => 'Pur Cost', +// 'purchase_date' => 'Pur date', +// 'purchase_order' => 'Purc Order', +// 'quantity' => 'Quan', +// 'reassignable' => 'reass', +// 'requestable' => 'Request', +// 'seats' => 'seat', +// 'serial' => 'serial num', +// 'category' => 'category', +// ]; +// $this->import(new LicenseImporter($csv), $customFieldMap); +// $this->tester->seeRecord('licenses', [ +// 'name' => 'Argentum Malachite Athletes Foot Relief', +// 'purchase_date' => '2012-07-13 00:00:01', +// 'seats' => 80, +// 'license_email' => 'cspencer0@gov.uk', +// 'order_number' => '386436062-5', +// 'license_name' => 'Cynthia Spencer', +// 'expiration_date' => '2016-01-27', +// 'maintained' => 0, +// 'notes' => 'Sed ante. Vivamus tortor. Duis mattis egestas metus.', +// 'purchase_cost' => 79.66, +// 'purchase_order' => '53008', +// 'reassignable' => 0, +// 'serial' => '1aa5b0eb-79c5-40b2-8943-5472a6893c3c', +// ]); + +// $this->tester->seeRecord('manufacturers', [ +// 'name' => 'Beer, Leannon and Lubowitz', +// ]); + +// $this->tester->seeRecord('suppliers', [ +// 'name' => 'Hegmann, Mohr and Cremin', +// ]); + +// $this->tester->seeRecord('companies', [ +// 'name' => 'Haag, Schmidt and Farrell', +// ]); + +// $this->tester->seeNumRecords(80, 'license_seats'); +// } + +// public function testDefaultUserImport() +// { +// Notification::fake(); +// $this->signIn(); +// $csv = <<<'EOT' +// First Name,Last Name,email,Username,Location,Phone Number,Job Title,Employee Number,Company,Department,activated +// Blanche,O'Collopy,bocollopy0@livejournal.com,bocollopy0,Hinapalanan,63-(199)661-2186,Clinical Specialist,7080919053,Morar-Ward,Management,1 +// Jessie,Primo,,jprimo1,Korenovsk,7-(885)578-0266,Paralegal,6284292031,Jast-Stiedemann,1 + +// EOT; +// $user_importer = new UserImporter($csv); +// $user_importer->sendWelcome(); +// $this->import($user_importer); + +// $this->tester->seeRecord('users', [ +// 'first_name' => 'Blanche', +// 'last_name' => "O'Collopy", +// 'email' => 'bocollopy0@livejournal.com', +// 'username' => 'bocollopy0', +// 'phone' => '63-(199)661-2186', +// 'jobtitle' => 'Clinical Specialist', +// 'employee_num' => '7080919053', +// ]); + +// $this->tester->seeRecord('companies', [ +// 'name' => 'Morar-Ward', +// ]); + +// $this->tester->seeRecord('departments', [ +// 'name' => 'Management', +// ]); + +// Notification::assertSentTo(User::find(2), \App\Notifications\WelcomeNotification::class); +// Notification::assertNotSentTo(User::find(3), \App\Notifications\WelcomeNotification::class); +// } + +// private function import($importer, $mappings = null) +// { +// if ($mappings) { +// $importer->setFieldMappings($mappings); +// } +// $importer->setUserId(1) +// ->setUpdating(false) +// ->setUsernameFormat('firstname.lastname') +// ->import(); +// } } diff --git a/tests/Unit/PermissionsTest.php b/tests/Unit/PermissionsTest.php index 64a3ac9aee..86d40de866 100644 --- a/tests/Unit/PermissionsTest.php +++ b/tests/Unit/PermissionsTest.php @@ -14,500 +14,500 @@ use Tests\Unit\BaseTest; class PermissionsTest extends BaseTest { - public function _before() - { - parent::_before(); - $this->noHardware = [ - 'assets.view' => false, - 'assets.create' => false, - 'assets.edit' => false, - 'assets.delete' => false, - ]; - - $this->noLicenses = [ - 'licenses.view' => false, - 'licenses.create' => false, - 'licenses.edit' => false, - 'licenses.delete' => false, - ]; - - $this->noAccessories = [ - 'accessories.view' => false, - 'accessories.create' => false, - 'accessories.edit' => false, - 'accessories.delete' => false, - ]; - - $this->noConsumables = [ - 'consumables.view' => false, - 'consumables.create' => false, - 'consumables.edit' => false, - 'consumables.delete' => false, - ]; - - $this->noComponents = [ - 'components.view' => false, - 'components.create' => false, - 'components.edit' => false, - 'components.delete' => false, - ]; - - $this->noUsers = [ - 'users.view' => false, - 'users.create' => false, - 'users.edit' => false, - 'users.delete' => false, - ]; - } - - private $noHardware; - private $noLicenses; - private $noAccessories; - private $noConsumables; - private $noComponents; - private $noUsers; - - // tests - - /** - * @test - */ - public function a_user_with_no_permissions_sees_nothing() - { - $u = \App\Models\User::factory()->create(); - $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; - // $permissions = $this->noHardware; - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_view_asset_permissions_can_view_assets() - { - $u = \App\Models\User::factory()->viewAssets()->create(); - $permissions = $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'assets.view' => true, - 'assets.create' => false, - 'assets.edit' => false, - 'assets.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_create_asset_permissions_can_create_assets() - { - $u = \App\Models\User::factory()->createAssets()->create(); - $permissions = $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'assets.view' => false, - 'assets.create' => true, - 'assets.edit' => false, - 'assets.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_edit_assets_permissions_can_edit_assets() - { - $u = \App\Models\User::factory()->editAssets()->create(); - - $permissions = $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'assets.view' => false, - 'assets.create' => false, - 'assets.edit' => true, - 'assets.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_delete_assets_permissions_can_delete_assets() - { - $u = \App\Models\User::factory()->deleteAssets()->create(); - $permissions = $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; - $permissions = array_merge($permissions, [ - 'assets.view' => false, - 'assets.create' => false, - 'assets.edit' => false, - 'assets.delete' => true, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_view_licenses_permissions_can_view_licenses() - { - $u = \App\Models\User::factory()->viewLicenses()->create(); - $permissions = $this->noHardware + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'licenses.view' => true, - 'licenses.create' => false, - 'licenses.edit' => false, - 'licenses.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_create_licenses_permissions_can_create_licenses() - { - $u = \App\Models\User::factory()->createLicenses()->create(); - $permissions = $this->noHardware + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'licenses.view' => false, - 'licenses.create' => true, - 'licenses.edit' => false, - 'licenses.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_edit_licenses_permissions_can_edit_licenses() - { - $u = \App\Models\User::factory()->editLicenses()->create(); - $permissions = $this->noHardware + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'licenses.view' => false, - 'licenses.create' => false, - 'licenses.edit' => true, - 'licenses.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_delete_licenses_permissions_can_delete_licenses() - { - $u = \App\Models\User::factory()->deleteLicenses()->create(); - $permissions = $this->noHardware + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'licenses.view' => false, - 'licenses.create' => false, - 'licenses.edit' => false, - 'licenses.delete' => true, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_view_accessories_permissions_can_view_accessories() - { - $u = \App\Models\User::factory()->viewAccessories()->create(); - - $permissions = $this->noHardware + $this->noLicenses + $this->noConsumables + $this->noComponents + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'accessories.view' => true, - 'accessories.create' => false, - 'accessories.edit' => false, - 'accessories.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_create_accessories_permissions_can_create_accessories() - { - $u = \App\Models\User::factory()->createAccessories()->create(); - - $permissions = $this->noHardware + $this->noLicenses + $this->noConsumables + $this->noComponents + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'accessories.view' => false, - 'accessories.create' => true, - 'accessories.edit' => false, - 'accessories.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_edit_accessories_permissions_can_edit_accessories() - { - $u = \App\Models\User::factory()->editAccessories()->create(); - - $permissions = $this->noHardware + $this->noLicenses + $this->noConsumables + $this->noComponents + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'accessories.view' => false, - 'accessories.create' => false, - 'accessories.edit' => true, - 'accessories.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_delete_accessories_permissions_can_delete_accessories() - { - $u = \App\Models\User::factory()->deleteAccessories()->create(); - - $permissions = $this->noHardware + $this->noLicenses + $this->noConsumables + $this->noComponents + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'accessories.view' => false, - 'accessories.create' => false, - 'accessories.edit' => false, - 'accessories.delete' => true, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_view_consumables_permissions_can_view_consumables() - { - $u = \App\Models\User::factory()->viewConsumables()->create(); - - $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noComponents + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'consumables.view' => true, - 'consumables.create' => false, - 'consumables.edit' => false, - 'consumables.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_create_consumables_permissions_can_create_consumables() - { - $u = \App\Models\User::factory()->createConsumables()->create(); - - $permissions = $this->noHardware + $this->noLicenses + $this->noConsumables + $this->noComponents + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'consumables.view' => false, - 'consumables.create' => true, - 'consumables.edit' => false, - 'consumables.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_edit_consumables_permissions_can_edit_consumables() - { - $u = \App\Models\User::factory()->editConsumables()->create(); - - $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noComponents + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'consumables.view' => false, - 'consumables.create' => false, - 'consumables.edit' => true, - 'consumables.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_delete_consumables_permissions_can_delete_consumables() - { - $u = \App\Models\User::factory()->deleteConsumables()->create(); - - $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noComponents + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'consumables.view' => false, - 'consumables.create' => false, - 'consumables.edit' => false, - 'consumables.delete' => true, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_view_users_permissions_can_view_users() - { - $u = \App\Models\User::factory()->viewUsers()->create(); - - $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents; - - $permissions = array_merge($permissions, [ - 'users.view' => true, - 'users.create' => false, - 'users.edit' => false, - 'users.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_create_users_permissions_can_create_users() - { - $u = \App\Models\User::factory()->createUsers()->create(); - - $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents; - - $permissions = array_merge($permissions, [ - 'users.view' => false, - 'users.create' => true, - 'users.edit' => false, - 'users.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_edit_users_permissions_can_edit_users() - { - $u = \App\Models\User::factory()->editUsers()->create(); - - $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents; - - $permissions = array_merge($permissions, [ - 'users.view' => false, - 'users.create' => false, - 'users.edit' => true, - 'users.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_delete_users_permissions_can_delete_users() - { - $u = \App\Models\User::factory()->deleteUsers()->create(); - - $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents; - - $permissions = array_merge($permissions, [ - 'users.view' => false, - 'users.create' => false, - 'users.edit' => false, - 'users.delete' => true, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_view_components_permissions_can_view_components() - { - $u = \App\Models\User::factory()->viewComponents()->create(); - - $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'components.view' => true, - 'components.create' => false, - 'components.edit' => false, - 'components.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_create_components_permissions_can_create_components() - { - $u = \App\Models\User::factory()->createComponents()->create(); - $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'components.view' => false, - 'components.create' => true, - 'components.edit' => false, - 'components.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_edit_components_permissions_can_edit_components() - { - $u = \App\Models\User::factory()->editComponents()->create(); - - $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'components.view' => false, - 'components.create' => false, - 'components.edit' => true, - 'components.delete' => false, - ]); - $this->hitRoutes($permissions, $u); - } - - /** - * @test - */ - public function a_user_with_delete_components_permissions_can_delete_components() - { - $u = \App\Models\User::factory()->deleteComponents()->create(); - - $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noUsers; - - $permissions = array_merge($permissions, [ - 'components.view' => false, - 'components.create' => false, - 'components.edit' => false, - 'components.delete' => true, - ]); - // dd($u); - $this->hitRoutes($permissions, $u); - } - - private function hitRoutes(array $routes, User $user) - { - foreach ($routes as $route => $expectation) { - $this->assertEquals($user->hasAccess($route), $expectation); - } - } + // public function _before() + // { + // parent::_before(); + // $this->noHardware = [ + // 'assets.view' => false, + // 'assets.create' => false, + // 'assets.edit' => false, + // 'assets.delete' => false, + // ]; + + // $this->noLicenses = [ + // 'licenses.view' => false, + // 'licenses.create' => false, + // 'licenses.edit' => false, + // 'licenses.delete' => false, + // ]; + + // $this->noAccessories = [ + // 'accessories.view' => false, + // 'accessories.create' => false, + // 'accessories.edit' => false, + // 'accessories.delete' => false, + // ]; + + // $this->noConsumables = [ + // 'consumables.view' => false, + // 'consumables.create' => false, + // 'consumables.edit' => false, + // 'consumables.delete' => false, + // ]; + + // $this->noComponents = [ + // 'components.view' => false, + // 'components.create' => false, + // 'components.edit' => false, + // 'components.delete' => false, + // ]; + + // $this->noUsers = [ + // 'users.view' => false, + // 'users.create' => false, + // 'users.edit' => false, + // 'users.delete' => false, + // ]; + // } + + // private $noHardware; + // private $noLicenses; + // private $noAccessories; + // private $noConsumables; + // private $noComponents; + // private $noUsers; + + // // tests + + // /** + // * @test + // */ + // public function a_user_with_no_permissions_sees_nothing() + // { + // $u = \App\Models\User::factory()->create(); + // $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; + // // $permissions = $this->noHardware; + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_view_asset_permissions_can_view_assets() + // { + // $u = \App\Models\User::factory()->viewAssets()->create(); + // $permissions = $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'assets.view' => true, + // 'assets.create' => false, + // 'assets.edit' => false, + // 'assets.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_create_asset_permissions_can_create_assets() + // { + // $u = \App\Models\User::factory()->createAssets()->create(); + // $permissions = $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'assets.view' => false, + // 'assets.create' => true, + // 'assets.edit' => false, + // 'assets.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_edit_assets_permissions_can_edit_assets() + // { + // $u = \App\Models\User::factory()->editAssets()->create(); + + // $permissions = $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'assets.view' => false, + // 'assets.create' => false, + // 'assets.edit' => true, + // 'assets.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_delete_assets_permissions_can_delete_assets() + // { + // $u = \App\Models\User::factory()->deleteAssets()->create(); + // $permissions = $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; + // $permissions = array_merge($permissions, [ + // 'assets.view' => false, + // 'assets.create' => false, + // 'assets.edit' => false, + // 'assets.delete' => true, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_view_licenses_permissions_can_view_licenses() + // { + // $u = \App\Models\User::factory()->viewLicenses()->create(); + // $permissions = $this->noHardware + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'licenses.view' => true, + // 'licenses.create' => false, + // 'licenses.edit' => false, + // 'licenses.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_create_licenses_permissions_can_create_licenses() + // { + // $u = \App\Models\User::factory()->createLicenses()->create(); + // $permissions = $this->noHardware + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'licenses.view' => false, + // 'licenses.create' => true, + // 'licenses.edit' => false, + // 'licenses.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_edit_licenses_permissions_can_edit_licenses() + // { + // $u = \App\Models\User::factory()->editLicenses()->create(); + // $permissions = $this->noHardware + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'licenses.view' => false, + // 'licenses.create' => false, + // 'licenses.edit' => true, + // 'licenses.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_delete_licenses_permissions_can_delete_licenses() + // { + // $u = \App\Models\User::factory()->deleteLicenses()->create(); + // $permissions = $this->noHardware + $this->noAccessories + $this->noConsumables + $this->noComponents + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'licenses.view' => false, + // 'licenses.create' => false, + // 'licenses.edit' => false, + // 'licenses.delete' => true, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_view_accessories_permissions_can_view_accessories() + // { + // $u = \App\Models\User::factory()->viewAccessories()->create(); + + // $permissions = $this->noHardware + $this->noLicenses + $this->noConsumables + $this->noComponents + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'accessories.view' => true, + // 'accessories.create' => false, + // 'accessories.edit' => false, + // 'accessories.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_create_accessories_permissions_can_create_accessories() + // { + // $u = \App\Models\User::factory()->createAccessories()->create(); + + // $permissions = $this->noHardware + $this->noLicenses + $this->noConsumables + $this->noComponents + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'accessories.view' => false, + // 'accessories.create' => true, + // 'accessories.edit' => false, + // 'accessories.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_edit_accessories_permissions_can_edit_accessories() + // { + // $u = \App\Models\User::factory()->editAccessories()->create(); + + // $permissions = $this->noHardware + $this->noLicenses + $this->noConsumables + $this->noComponents + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'accessories.view' => false, + // 'accessories.create' => false, + // 'accessories.edit' => true, + // 'accessories.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_delete_accessories_permissions_can_delete_accessories() + // { + // $u = \App\Models\User::factory()->deleteAccessories()->create(); + + // $permissions = $this->noHardware + $this->noLicenses + $this->noConsumables + $this->noComponents + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'accessories.view' => false, + // 'accessories.create' => false, + // 'accessories.edit' => false, + // 'accessories.delete' => true, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_view_consumables_permissions_can_view_consumables() + // { + // $u = \App\Models\User::factory()->viewConsumables()->create(); + + // $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noComponents + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'consumables.view' => true, + // 'consumables.create' => false, + // 'consumables.edit' => false, + // 'consumables.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_create_consumables_permissions_can_create_consumables() + // { + // $u = \App\Models\User::factory()->createConsumables()->create(); + + // $permissions = $this->noHardware + $this->noLicenses + $this->noConsumables + $this->noComponents + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'consumables.view' => false, + // 'consumables.create' => true, + // 'consumables.edit' => false, + // 'consumables.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_edit_consumables_permissions_can_edit_consumables() + // { + // $u = \App\Models\User::factory()->editConsumables()->create(); + + // $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noComponents + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'consumables.view' => false, + // 'consumables.create' => false, + // 'consumables.edit' => true, + // 'consumables.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_delete_consumables_permissions_can_delete_consumables() + // { + // $u = \App\Models\User::factory()->deleteConsumables()->create(); + + // $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noComponents + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'consumables.view' => false, + // 'consumables.create' => false, + // 'consumables.edit' => false, + // 'consumables.delete' => true, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_view_users_permissions_can_view_users() + // { + // $u = \App\Models\User::factory()->viewUsers()->create(); + + // $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents; + + // $permissions = array_merge($permissions, [ + // 'users.view' => true, + // 'users.create' => false, + // 'users.edit' => false, + // 'users.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_create_users_permissions_can_create_users() + // { + // $u = \App\Models\User::factory()->createUsers()->create(); + + // $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents; + + // $permissions = array_merge($permissions, [ + // 'users.view' => false, + // 'users.create' => true, + // 'users.edit' => false, + // 'users.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_edit_users_permissions_can_edit_users() + // { + // $u = \App\Models\User::factory()->editUsers()->create(); + + // $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents; + + // $permissions = array_merge($permissions, [ + // 'users.view' => false, + // 'users.create' => false, + // 'users.edit' => true, + // 'users.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_delete_users_permissions_can_delete_users() + // { + // $u = \App\Models\User::factory()->deleteUsers()->create(); + + // $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noComponents; + + // $permissions = array_merge($permissions, [ + // 'users.view' => false, + // 'users.create' => false, + // 'users.edit' => false, + // 'users.delete' => true, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_view_components_permissions_can_view_components() + // { + // $u = \App\Models\User::factory()->viewComponents()->create(); + + // $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'components.view' => true, + // 'components.create' => false, + // 'components.edit' => false, + // 'components.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_create_components_permissions_can_create_components() + // { + // $u = \App\Models\User::factory()->createComponents()->create(); + // $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'components.view' => false, + // 'components.create' => true, + // 'components.edit' => false, + // 'components.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_edit_components_permissions_can_edit_components() + // { + // $u = \App\Models\User::factory()->editComponents()->create(); + + // $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'components.view' => false, + // 'components.create' => false, + // 'components.edit' => true, + // 'components.delete' => false, + // ]); + // $this->hitRoutes($permissions, $u); + // } + + // /** + // * @test + // */ + // public function a_user_with_delete_components_permissions_can_delete_components() + // { + // $u = \App\Models\User::factory()->deleteComponents()->create(); + + // $permissions = $this->noHardware + $this->noLicenses + $this->noAccessories + $this->noConsumables + $this->noUsers; + + // $permissions = array_merge($permissions, [ + // 'components.view' => false, + // 'components.create' => false, + // 'components.edit' => false, + // 'components.delete' => true, + // ]); + // // dd($u); + // $this->hitRoutes($permissions, $u); + // } + + // private function hitRoutes(array $routes, User $user) + // { + // foreach ($routes as $route => $expectation) { + // $this->assertEquals($user->hasAccess($route), $expectation); + // } + // } }