mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-08 12:27:38 -08:00
f7dbda4ed3
* Work towards a functional travis. Step 1: Disable broken unit tests. * Fix functional tests This updates the login information and model factories to work with changes to source. * Importer name/full name fixes. Fix a bug where "name" was used ambigously and mapping "item name" to "name" would confuse the importer into thinking it should also be a user name. Now we default to "full name" for the users name, and "item name" for the item name. These are still both configurable through the custom mapping. Also update sample csvs and remove an outdated sample. * Max length of supplier notes is 191, not 255, as per default laravel string length. Might make sense to change this to a text field in the future to match other places. * Use sqlite/different db setup for unit tests. * Fix assets api test. * Fix Components API test. * increase travis memory limit for functional tests. * Use travis config for api tests as well. * Fix memory limit file. * Disable ApiComponentsAssetsCest until it's fixed.
99 lines
3.8 KiB
PHP
99 lines
3.8 KiB
PHP
<?php
|
|
|
|
use App\Models\User;
|
|
|
|
class UsersCest
|
|
{
|
|
public function _before(\FunctionalTester $I)
|
|
{
|
|
$I->amOnPage('/login');
|
|
$I->fillField('username', 'admin');
|
|
$I->fillField('password', 'password');
|
|
$I->click('Login');
|
|
}
|
|
// tests
|
|
public function tryToTest(\FunctionalTester $I)
|
|
{
|
|
$I->wantTo('ensure that the create users form loads without errors');
|
|
$I->lookForwardTo('seeing it load without errors');
|
|
$I->amOnPage(route('users.create'));
|
|
$I->dontSee('Create User', '.page-header');
|
|
$I->see('Create User', 'h1.pull-left');
|
|
}
|
|
|
|
public function failsEmptyValidation(FunctionalTester $I)
|
|
{
|
|
$I->wantTo("Test Validation Fails with blank elements");
|
|
$I->amOnPage(route('users.create'));
|
|
$I->click('Save');
|
|
$I->seeElement('.alert-danger');
|
|
$I->see('The first name field is required.', '.alert-msg');
|
|
$I->see('The username field is required unless ldap import is in 1.', '.alert-msg');
|
|
$I->see('The password field is required.', '.alert-msg');
|
|
}
|
|
|
|
public function failsShortValidation(FunctionalTester $I)
|
|
{
|
|
$I->wantTo("Test Validation Fails with short name");
|
|
$I->amOnPage(route('users.create'));
|
|
$I->fillField('first_name', 't2');
|
|
$I->fillField('last_name', 't2');
|
|
$I->fillField('username', 'a');
|
|
$I->fillField('password', '12345'); // Must be 6 chars
|
|
$I->click('Save');
|
|
$I->seeElement('.alert-danger');
|
|
$I->see('The password must be at least 10 characters', '.alert-msg');
|
|
$I->see('The password confirm field is required when password is present', '.alert-msg');
|
|
|
|
}
|
|
public function passesCorrectValidation(FunctionalTester $I)
|
|
{
|
|
$user = factory(App\Models\User::class)->make();
|
|
$submitValues = [
|
|
'first_name' => $user->first_name,
|
|
'last_name' => $user->last_name,
|
|
'username' => $user->username,
|
|
'password' => $user->password,
|
|
'password_confirm' => $user->password,
|
|
'email' => $user->email,
|
|
'company_id' => $user->company_id,
|
|
'locale' => $user->locale,
|
|
'employee_num' => $user->employee_num,
|
|
'jobtitle' => $user->jobtitle,
|
|
'manager_id' => $user->manager_id,
|
|
'location_id' => $user->location_id,
|
|
'phone' => $user->phone,
|
|
'activated' => true,
|
|
'notes' => $user->notes
|
|
];
|
|
$storedValues = [
|
|
'first_name' => $user->first_name,
|
|
'last_name' => $user->last_name,
|
|
'username' => $user->username,
|
|
'email' => $user->email,
|
|
'company_id' => $user->company_id,
|
|
'locale' => $user->locale,
|
|
'employee_num' => $user->employee_num,
|
|
'jobtitle' => $user->jobtitle,
|
|
'manager_id' => $user->manager_id,
|
|
'location_id' => $user->location_id,
|
|
'phone' => $user->phone,
|
|
'activated' => true,
|
|
'notes' => $user->notes
|
|
];
|
|
$I->amOnPage(route('users.create'));
|
|
$I->wantTo("Test Validation Succeeds");
|
|
$I->submitForm('form#userForm', $submitValues);
|
|
$I->seeRecord('users', $storedValues);
|
|
$I->seeElement('.alert-success');
|
|
}
|
|
|
|
public function allowsDelete(FunctionalTester $I)
|
|
{
|
|
$user = factory(App\Models\User::class)->create();
|
|
$I->wantTo('Ensure I can delete a user');
|
|
$I->sendDelete(route('users.destroy', $user->id), ['_token' => csrf_token()]);
|
|
$I->seeResponseCodeIs(200);
|
|
}
|
|
}
|