mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-13 06:47:46 -08:00
Continuing to refactor tests
Signed-off-by: snipe <snipe@snipe.net>
This commit is contained in:
parent
c2709be4a1
commit
35ba28bff9
|
@ -5,7 +5,10 @@ namespace Database\Factories;
|
||||||
use App\Models\Asset;
|
use App\Models\Asset;
|
||||||
use App\Models\AssetModel;
|
use App\Models\AssetModel;
|
||||||
use App\Models\Category;
|
use App\Models\Category;
|
||||||
|
use App\Models\Location;
|
||||||
|
use App\Models\Supplier;
|
||||||
use Illuminate\Database\Eloquent\Factories\Factory;
|
use Illuminate\Database\Eloquent\Factories\Factory;
|
||||||
|
use App\Models\StatusLabel;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -36,14 +39,16 @@ class AssetFactory extends Factory
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
'name' => null,
|
'name' => null,
|
||||||
|
'rtd_location_id' => Location::factory()->create(),
|
||||||
'serial' => $this->faker->uuid,
|
'serial' => $this->faker->uuid,
|
||||||
'status_id' => 1,
|
'status_id' => StatusLabel::factory()->create(),
|
||||||
'user_id' => 1,
|
'user_id' => 1,
|
||||||
'asset_tag' => $this->faker->unixTime('now'),
|
'asset_tag' => $this->faker->unixTime('now'),
|
||||||
'notes' => 'Created by DB seeder',
|
'notes' => 'Created by DB seeder',
|
||||||
'purchase_date' => $this->faker->dateTimeBetween('-1 years', 'now', date_default_timezone_get()),
|
'purchase_date' => $this->faker->dateTimeBetween('-1 years', 'now', date_default_timezone_get()),
|
||||||
'purchase_cost' => $this->faker->randomFloat(2, '299.99', '2999.99'),
|
'purchase_cost' => $this->faker->randomFloat(2, '299.99', '2999.99'),
|
||||||
'order_number' => $this->faker->numberBetween(1000000, 50000000),
|
'order_number' => $this->faker->numberBetween(1000000, 50000000),
|
||||||
|
'supplier_id' => Supplier::factory()->create(),
|
||||||
'requestable' => $this->faker->boolean(),
|
'requestable' => $this->faker->boolean(),
|
||||||
'assigned_to' => null,
|
'assigned_to' => null,
|
||||||
'assigned_type' => null,
|
'assigned_type' => null,
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
namespace Database\Factories;
|
namespace Database\Factories;
|
||||||
|
|
||||||
use Illuminate\Database\Eloquent\Factories\Factory;
|
use Illuminate\Database\Eloquent\Factories\Factory;
|
||||||
|
use App\Models\Category;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -81,6 +82,7 @@ class AssetModelFactory extends Factory
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
'user_id' => 1,
|
'user_id' => 1,
|
||||||
|
'name' => $this->faker->catchPhrase(),
|
||||||
'model_number' => $this->faker->creditCardNumber(),
|
'model_number' => $this->faker->creditCardNumber(),
|
||||||
'notes' => 'Created by demo seeder',
|
'notes' => 'Created by demo seeder',
|
||||||
|
|
||||||
|
|
|
@ -31,6 +31,7 @@ class CategoryFactory extends Factory
|
||||||
public function definition()
|
public function definition()
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
'name' => $this->faker->catchPhrase(),
|
||||||
'checkin_email' => $this->faker->boolean(),
|
'checkin_email' => $this->faker->boolean(),
|
||||||
'eula_text' => $this->faker->paragraph(),
|
'eula_text' => $this->faker->paragraph(),
|
||||||
'require_acceptance' => false,
|
'require_acceptance' => false,
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
namespace Tests\Unit;
|
namespace Tests\Unit;
|
||||||
|
|
||||||
use App\Models\Asset;
|
use App\Models\Asset;
|
||||||
|
use App\Models\Category;
|
||||||
use App\Models\AssetModel;
|
use App\Models\AssetModel;
|
||||||
use Illuminate\Foundation\Testing\DatabaseMigrations;
|
use Illuminate\Foundation\Testing\DatabaseMigrations;
|
||||||
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
||||||
|
@ -15,22 +16,6 @@ class AssetModelTest extends BaseTest
|
||||||
*/
|
*/
|
||||||
protected $tester;
|
protected $tester;
|
||||||
|
|
||||||
public function testAnAssetModelRequiresAttributes()
|
|
||||||
{
|
|
||||||
// An Asset Model requires a name, a category_id, and a manufacturer_id.
|
|
||||||
$a = AssetModel::create();
|
|
||||||
$this->assertFalse($a->isValid());
|
|
||||||
$fields = [
|
|
||||||
'name' => 'name',
|
|
||||||
'manufacturer_id' => 'manufacturer id',
|
|
||||||
'category_id' => 'category id',
|
|
||||||
];
|
|
||||||
$errors = $a->getErrors();
|
|
||||||
foreach ($fields as $field => $fieldTitle) {
|
|
||||||
$this->assertEquals($errors->get($field)[0], "The ${fieldTitle} field is required.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testAnAssetModelZerosOutBlankEols()
|
public function testAnAssetModelZerosOutBlankEols()
|
||||||
{
|
{
|
||||||
$am = new AssetModel;
|
$am = new AssetModel;
|
||||||
|
@ -42,28 +27,21 @@ class AssetModelTest extends BaseTest
|
||||||
|
|
||||||
public function testAnAssetModelContainsAssets()
|
public function testAnAssetModelContainsAssets()
|
||||||
{
|
{
|
||||||
$assetModel = $this->createValidAssetModel();
|
$category = Category::factory()->create(
|
||||||
$this->createValidAsset([
|
['category_type' => 'asset']
|
||||||
'model_id' => $assetModel->id,
|
);
|
||||||
|
$model = AssetModel::factory()->create([
|
||||||
|
'category_id' => $category->id,
|
||||||
]);
|
]);
|
||||||
$this->assertEquals(1, $assetModel->assets()->count());
|
|
||||||
|
$asset = Asset::factory()
|
||||||
|
->create(
|
||||||
|
[
|
||||||
|
'model_id' => $model->id
|
||||||
|
]
|
||||||
|
);
|
||||||
|
$this->assertEquals(1, $model->assets()->count());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testAnAssetModelHasACategory()
|
|
||||||
{
|
|
||||||
$assetmodel = $this->createValidAssetModel();
|
|
||||||
$this->assertInstanceOf(App\Models\Category::class, $assetmodel->category);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testAnAssetModelHasADepreciation()
|
|
||||||
{
|
|
||||||
$assetmodel = $this->createValidAssetModel();
|
|
||||||
$this->assertInstanceOf(App\Models\Depreciation::class, $assetmodel->depreciation);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testAnAssetModelHasAManufacturer()
|
|
||||||
{
|
|
||||||
$assetmodel = $this->createValidAssetModel();
|
|
||||||
$this->assertInstanceOf(App\Models\Manufacturer::class, $assetmodel->manufacturer);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,6 +11,9 @@ use Carbon\Carbon;
|
||||||
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
||||||
use Illuminate\Foundation\Testing\WithoutMiddleware;
|
use Illuminate\Foundation\Testing\WithoutMiddleware;
|
||||||
use Tests\Unit\BaseTest;
|
use Tests\Unit\BaseTest;
|
||||||
|
use App\Models\Component;
|
||||||
|
use App\Models\ActionLog;
|
||||||
|
|
||||||
|
|
||||||
class AssetTest extends BaseTest
|
class AssetTest extends BaseTest
|
||||||
{
|
{
|
||||||
|
@ -178,7 +181,7 @@ class AssetTest extends BaseTest
|
||||||
{
|
{
|
||||||
$asset = $this->createValidAsset();
|
$asset = $this->createValidAsset();
|
||||||
|
|
||||||
$components = \App\Models\Component::factory()->count(5)->ramCrucial4()->create([
|
$components = Component::factory()->count(5)->ramCrucial4()->create([
|
||||||
'category_id' => $this->createValidCategory('component-hdd-category')->id,
|
'category_id' => $this->createValidCategory('component-hdd-category')->id,
|
||||||
]);
|
]);
|
||||||
|
|
||||||
|
@ -187,7 +190,7 @@ class AssetTest extends BaseTest
|
||||||
'asset_id'=>$asset->id,
|
'asset_id'=>$asset->id,
|
||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
$this->assertInstanceOf(App\Models\Component::class, $asset->components()->first());
|
$this->assertInstanceOf(Component::class, $asset->components()->first());
|
||||||
$this->assertCount(5, $asset->components);
|
$this->assertCount(5, $asset->components);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -197,7 +200,10 @@ class AssetTest extends BaseTest
|
||||||
'supplier_id' => $this->createValidSupplier()->id,
|
'supplier_id' => $this->createValidSupplier()->id,
|
||||||
]);
|
]);
|
||||||
$this->assertCount(0, $asset->uploads);
|
$this->assertCount(0, $asset->uploads);
|
||||||
\App\Models\Actionlog::factory()->count('asset-upload')->create(['item_id' => $asset->id]);
|
// This is wrong
|
||||||
|
Actionlog::factory()->count('asset-upload')->create(
|
||||||
|
['item_id' => $asset->id]
|
||||||
|
);
|
||||||
$this->assertCount(1, $asset->fresh()->uploads);
|
$this->assertCount(1, $asset->fresh()->uploads);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -222,13 +228,13 @@ class AssetTest extends BaseTest
|
||||||
$asset = $this->createValidAsset();
|
$asset = $this->createValidAsset();
|
||||||
$adminUser = $this->signIn();
|
$adminUser = $this->signIn();
|
||||||
|
|
||||||
$target = \App\Models\User::factory()->create([
|
$target = User::factory()->create([
|
||||||
'location_id' => \App\Models\Location::factory()->create(),
|
'location_id' => Location::factory()->create(),
|
||||||
]);
|
]);
|
||||||
// An Asset Can be checked out to a user, and this should be logged.
|
// An Asset Can be checked out to a user, and this should be logged.
|
||||||
$asset->checkOut($target, $adminUser);
|
$asset->checkOut($target, $adminUser);
|
||||||
$asset->save();
|
$asset->save();
|
||||||
$this->assertInstanceOf(App\Models\User::class, $asset->assignedTo);
|
$this->assertInstanceOf(User::class, $asset->assignedTo);
|
||||||
|
|
||||||
$this->assertEquals($asset->location->id, $target->userLoc->id);
|
$this->assertEquals($asset->location->id, $target->userLoc->id);
|
||||||
$this->assertEquals('user', $asset->assignedType());
|
$this->assertEquals('user', $asset->assignedType());
|
||||||
|
|
|
@ -9,6 +9,7 @@ use Tests\Unit\BaseTest;
|
||||||
use App\Models\Component;
|
use App\Models\Component;
|
||||||
use App\Models\Asset;
|
use App\Models\Asset;
|
||||||
use App\Models\Consumable;
|
use App\Models\Consumable;
|
||||||
|
use App\Models\User;
|
||||||
|
|
||||||
class CompanyTest extends BaseTest
|
class CompanyTest extends BaseTest
|
||||||
{
|
{
|
||||||
|
@ -17,74 +18,17 @@ class CompanyTest extends BaseTest
|
||||||
*/
|
*/
|
||||||
protected $tester;
|
protected $tester;
|
||||||
|
|
||||||
public function testFailsEmptyValidation()
|
|
||||||
{
|
|
||||||
// An Company requires a name, a qty, and a category_id.
|
|
||||||
$company = Company::factory()->assetDesktopCategory()->create();
|
|
||||||
$this->assertFalse($company->isValid());
|
|
||||||
|
|
||||||
$fields = [
|
|
||||||
'name' => 'name',
|
|
||||||
];
|
|
||||||
$errors = $company->getErrors();
|
|
||||||
foreach ($fields as $field => $fieldTitle) {
|
|
||||||
$this->assertEquals($errors->get($field)[0], "The ${fieldTitle} field is required.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testACompanyCanHaveUsers()
|
public function testACompanyCanHaveUsers()
|
||||||
{
|
{
|
||||||
$company = Company::factory()->assetDesktopCategory()->create();
|
$company = Company::factory()->create();
|
||||||
$user = $this->createValidUser(['company_id'=>$company->id]);
|
User::factory()
|
||||||
|
->create(
|
||||||
|
[
|
||||||
|
'company_id'=>$company->id
|
||||||
|
]
|
||||||
|
);
|
||||||
|
|
||||||
$this->assertCount(1, $company->users);
|
$this->assertCount(1, $company->users);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testACompanyCanHaveAssets()
|
|
||||||
{
|
|
||||||
$company = Company::factory()->assetDesktopCategory()->create();
|
|
||||||
$this->createValidAsset(['company_id' => $company->id]);
|
|
||||||
$this->assertCount(1, $company->assets);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testACompanyCanHaveLicenses()
|
|
||||||
{
|
|
||||||
$company = Company::factory()->assetDesktopCategory()->create();
|
|
||||||
\App\Models\License::factory()->count(1)->acrobat()->create([
|
|
||||||
'company_id'=>$company->id,
|
|
||||||
'manufacturer_id' => \App\Models\Manufacturer::factory()->adobe()->create()->id,
|
|
||||||
'category_id' => \App\Models\Category::factory()->licenseOfficeCategory()->create()->id,
|
|
||||||
]);
|
|
||||||
$this->assertCount(1, $company->licenses);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testACompanyCanHaveAccessories()
|
|
||||||
{
|
|
||||||
$company = Company::factory()->assetDesktopCategory()->create();
|
|
||||||
$a = \App\Models\Accessory::factory()->appleBtKeyboard()->create([
|
|
||||||
'category_id' => \App\Models\Category::factory()->accessoryKeyboardCategory()->create()->id,
|
|
||||||
'company_id' => $company->id,
|
|
||||||
]);
|
|
||||||
|
|
||||||
$this->assertCount(1, $company->accessories);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testACompanyCanHaveConsumables()
|
|
||||||
{
|
|
||||||
$company = Company::factory()->assetDesktopCategory()->create();
|
|
||||||
\App\Models\Consumable::factory()->count(1)->cardstock()->create([
|
|
||||||
'company_id' => $company->id,
|
|
||||||
'category_id' => \App\Models\Category::factory()->consumablePaperCategory()->create()->id,
|
|
||||||
]);
|
|
||||||
$this->assertCount(1, $company->consumables);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testACompanyCanHaveComponents()
|
|
||||||
{
|
|
||||||
$company = Company::factory()->assetDesktopCategory()->create();
|
|
||||||
Component::factory()->count(1)->ramCrucial4()->create([
|
|
||||||
'company_id'=>$company->id,
|
|
||||||
'category_id' => \App\Models\Category::factory()->componentRamCategory()->create()->id,
|
|
||||||
]);
|
|
||||||
$this->assertCount(1, $company->components);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue