mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-23 11:43:47 -08:00
Merge pull request #14912 from bryanlopezinc/addIsWritableTest
Add storage path permissions test
This commit is contained in:
commit
6dfedac7a7
|
@ -25,6 +25,7 @@ use Illuminate\Support\Facades\Artisan;
|
|||
use Illuminate\Support\Facades\Auth;
|
||||
use Illuminate\Support\Facades\Crypt;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use Illuminate\Support\Facades\File;
|
||||
use Illuminate\Support\Facades\Http;
|
||||
use Illuminate\Support\Facades\Log;
|
||||
use Illuminate\Support\Facades\URL;
|
||||
|
@ -106,17 +107,7 @@ class SettingsController extends Controller
|
|||
$start_settings['owner_is_admin'] = false;
|
||||
}
|
||||
|
||||
if ((is_writable(storage_path()))
|
||||
&& (is_writable(storage_path().'/framework'))
|
||||
&& (is_writable(storage_path().'/framework/cache'))
|
||||
&& (is_writable(storage_path().'/framework/sessions'))
|
||||
&& (is_writable(storage_path().'/framework/views'))
|
||||
&& (is_writable(storage_path().'/logs'))
|
||||
) {
|
||||
$start_settings['writable'] = true;
|
||||
} else {
|
||||
$start_settings['writable'] = false;
|
||||
}
|
||||
$start_settings['writable'] = $this->storagePathIsWritable();
|
||||
|
||||
$start_settings['gd'] = extension_loaded('gd');
|
||||
|
||||
|
@ -145,6 +136,19 @@ class SettingsController extends Controller
|
|||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine if the app storage path is writable.
|
||||
*/
|
||||
protected function storagePathIsWritable(): bool
|
||||
{
|
||||
return File::isWritable(storage_path()) &&
|
||||
File::isWritable(storage_path('framework')) &&
|
||||
File::isWritable(storage_path('framework/cache')) &&
|
||||
File::isWritable(storage_path('framework/sessions')) &&
|
||||
File::isWritable(storage_path('framework/views')) &&
|
||||
File::isWritable(storage_path('logs'));
|
||||
}
|
||||
|
||||
/**
|
||||
* Save the first admin user from Setup.
|
||||
*
|
||||
|
|
|
@ -9,6 +9,7 @@ use Illuminate\Http\Client\Response;
|
|||
use Illuminate\Log\Events\MessageLogged;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use Illuminate\Support\Facades\Event;
|
||||
use Illuminate\Support\Facades\File;
|
||||
use Illuminate\Support\Facades\Http;
|
||||
use Illuminate\Support\Facades\Log;
|
||||
use Illuminate\Support\Facades\URL;
|
||||
|
@ -267,4 +268,37 @@ class ShowSetUpPageTest extends TestCase
|
|||
|
||||
$this->assertSeeAppUrlMisconfigurationErrorMessage();
|
||||
}
|
||||
|
||||
public function testWillSeeDirectoryPermissionErrorWhenStoragePathIsNotWritable(): void
|
||||
{
|
||||
File::shouldReceive('isWritable')->andReturn(false);
|
||||
|
||||
$this->getSetUpPageResponse()->assertOk();
|
||||
|
||||
$this->assertSeeDirectoryPermissionError();
|
||||
}
|
||||
|
||||
protected function assertSeeDirectoryPermissionError(bool $shouldSee = true): void
|
||||
{
|
||||
$storagePath = storage_path();
|
||||
|
||||
$errorMessage = "Uh-oh. Your <code>{$storagePath}</code> directory (or sub-directories within) are not writable by the web-server. Those directories need to be writable by the web server in order for the app to work.";
|
||||
$successMessage = 'Yippee! Your app storage directory seems writable';
|
||||
|
||||
if ($shouldSee) {
|
||||
self::$latestResponse->assertSee($errorMessage, false)->assertDontSee($successMessage, false);
|
||||
return;
|
||||
}
|
||||
|
||||
self::$latestResponse->assertSee($successMessage, false)->assertDontSee($errorMessage,false);
|
||||
}
|
||||
|
||||
public function testWillNotSeeDirectoryPermissionErrorWhenStoragePathIsWritable(): void
|
||||
{
|
||||
File::shouldReceive('isWritable')->andReturn(true);
|
||||
|
||||
$this->getSetUpPageResponse()->assertOk();
|
||||
|
||||
$this->assertSeeDirectoryPermissionError(false);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue