phpOMS/tests/System/File/Ftp/FileTest.php
2024-03-17 21:33:48 +00:00

1064 lines
31 KiB
PHP
Executable File

<?php
/**
* Jingga
*
* PHP Version 8.1
*
* @package tests
* @copyright Dennis Eichhorn
* @license OMS License 2.0
* @version 1.0.0
* @link https://jingga.app
*/
declare(strict_types=1);
namespace phpOMS\tests\System\File\Ftp;
use phpOMS\System\File\ContentPutMode;
use phpOMS\System\File\Ftp\Directory;
use phpOMS\System\File\Ftp\File;
use phpOMS\Uri\HttpUri;
/**
* @testdox phpOMS\tests\System\File\Ftp\FileTest: File handler for a ftp server
*
* @internal
*/
final class FileTest extends \PHPUnit\Framework\TestCase
{
public const BASE = 'ftp://test:123456@127.0.0.1:21';
private static $con = null;
public static function setUpBeforeClass() : void
{
self::$con = File::ftpConnect(new HttpUri(self::BASE));
if (self::$con === false) {
self::$con = null;
return;
}
try {
$mkdir = \ftp_mkdir(self::$con, __DIR__ . '/0xFF');
\ftp_rmdir(self::$con, __DIR__ . '/0xFF');
$f = \fopen('php://memory', 'r+');
\fwrite($f, __DIR__ . '/0x00');
\rewind($f);
$put = \ftp_fput(self::$con, __DIR__ . '/0x00', $f);
\fclose($f);
\ftp_delete(self::$con, __DIR__ . '/0x00');
if (!$mkdir || !$put) {
self::$con = null;
throw new \Exception();
}
} catch (\Throwable $_) {
self::$con = null;
}
}
/**
* {@inheritdoc}
*/
protected function setUp() : void
{
if (self::$con === null) {
$this->markTestSkipped(
'The ftp connection is not available.'
);
}
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testConnection() : void
{
self::assertNotFalse(File::ftpConnect(new HttpUri(self::BASE . '/test')));
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidConnection() : void
{
self::assertNull(File::ftpConnect(new HttpUri('ftp://karaka.app:21')));
}
/**
* @testdox A file without content can be created
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticCreate() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertTrue(File::create(self::$con, $testFile));
self::assertTrue(\is_file($testFile));
self::assertEquals('', \file_get_contents($testFile));
File::delete(self::$con, $testFile);
}
/**
* @testdox A file cannot be created if it already exists
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidStaticCreate() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertTrue(File::create(self::$con, $testFile));
self::assertFalse(File::create(self::$con, $testFile));
self::assertTrue(\is_file($testFile));
File::delete(self::$con, $testFile);
}
/**
* @testdox A file with content can be created
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticPut() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertTrue(File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE));
self::assertTrue(\is_file($testFile));
self::assertEquals('test', \file_get_contents($testFile));
File::delete(self::$con, $testFile);
}
/**
* @testdox A file cannot be replaced if it doesn't exists
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidStaticCreateReplace() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertFalse(File::put(self::$con, $testFile, 'test', ContentPutMode::REPLACE));
self::assertfalse(\is_file($testFile));
}
/**
* @testdox A file cannot be appended if it doesn't exists
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidStaticCreateAppend() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertFalse(File::put(self::$con, $testFile, 'test', ContentPutMode::APPEND));
self::assertfalse(\is_file($testFile));
}
/**
* @testdox A file cannot be prepended if it doesn't exists
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidStaticCreatePrepend() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertFalse(File::put(self::$con, $testFile, 'test', ContentPutMode::PREPEND));
self::assertfalse(\is_file($testFile));
}
/**
* @testdox A file can be checked for existence
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticExists() : void
{
self::assertTrue(File::exists(self::$con, __DIR__ . '/FileTest.php'));
self::assertFalse(File::exists(self::$con, __DIR__ . '/invalid/file.txt'));
}
/**
* @testdox A file can be replaced with a new one
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticReplace() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertTrue(File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE));
self::assertTrue(File::put(self::$con, $testFile, 'test2', ContentPutMode::REPLACE));
self::assertEquals('test2', \file_get_contents($testFile));
File::delete(self::$con, $testFile);
}
/**
* @testdox The set alias works like the replace flag
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticSetAlias() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertTrue(File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE));
self::assertTrue(File::set(self::$con, $testFile, 'test2'));
self::assertEquals('test2', \file_get_contents($testFile));
File::delete(self::$con, $testFile);
}
/**
* @testdox A file can be appended with additional content
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticAppend() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertTrue(File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE));
self::assertTrue(File::put(self::$con, $testFile, 'test2', ContentPutMode::APPEND));
self::assertEquals('testtest2', \file_get_contents($testFile));
File::delete(self::$con, $testFile);
}
/**
* @testdox The append alias works like the append flag
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticAppendAlias() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertTrue(File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE));
self::assertTrue(File::append(self::$con, $testFile, 'test2'));
self::assertEquals('testtest2', \file_get_contents($testFile));
File::delete(self::$con, $testFile);
}
/**
* @testdox A file can be prepended with additional content
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticPrepend() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertTrue(File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE));
self::assertTrue(File::put(self::$con, $testFile, 'test2', ContentPutMode::PREPEND));
self::assertEquals('test2test', \file_get_contents($testFile));
File::delete(self::$con, $testFile);
}
/**
* @testdox The prepend alias works like the prepend flag
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticPrependAlias() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertTrue(File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE));
self::assertTrue(File::prepend(self::$con, $testFile, 'test2'));
self::assertEquals('test2test', \file_get_contents($testFile));
File::delete(self::$con, $testFile);
}
/**
* @testdox The content of a file can be read
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticGet() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertTrue(File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE));
self::assertEquals('test', File::get(self::$con, $testFile));
File::delete(self::$con, $testFile);
}
/**
* @testdox The parent directory of a file can be returned
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticParent() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertEquals(\strtr(\realpath(__DIR__ . '/../'), '\\', '/'), File::parent($testFile));
}
/**
* @testdox The extension of a file can be returned
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticExtension() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertEquals('txt', File::extension($testFile));
}
/**
* @testdox The name of a file can be returned
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticName() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertEquals('test', File::name($testFile));
}
/**
* @testdox The basename of a file can be returned
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticBaseName() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertEquals('test.txt', File::basename($testFile));
}
/**
* @testdox The file name of a file can be returned
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticDirname() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertEquals(\basename(\realpath(__DIR__)), File::dirname($testFile));
}
/**
* @testdox The file path of a file can be returned
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticDirectoryPath() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertEquals(\realpath(__DIR__), File::dirpath($testFile));
}
/**
* @testdox The count of a file is always 1
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticCount() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertEquals(1, File::count(self::$con, $testFile));
}
/**
* @testdox The directories creation date can be returned
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticCreatedAt() : void
{
$testFile = __DIR__ . '/test.txt';
File::delete(self::$con, $testFile);
self::assertTrue(File::create(self::$con, $testFile));
$now = new \DateTime('now');
self::assertEquals($now->format('Y-m-d'), File::created(self::$con, $testFile)->format('Y-m-d'));
File::delete(self::$con, $testFile);
}
/**
* @testdox The directories last change date can be returned
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticChangedAt() : void
{
$testFile = __DIR__ . '/test.txt';
File::delete(self::$con, $testFile);
self::assertTrue(File::create(self::$con, $testFile));
$now = new \DateTime('now');
self::assertEquals($now->format('Y-m-d'), File::changed(self::$con, $testFile)->format('Y-m-d'));
File::delete(self::$con, $testFile);
}
/**
* @testdox A file can be deleted
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticDelete() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertTrue(File::create(self::$con, $testFile));
self::assertTrue(File::delete(self::$con, $testFile));
self::assertFalse(File::exists(self::$con, $testFile));
}
/**
* @testdox A none-existing file cannot be deleted
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidStaticDelete() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertFalse(File::delete(self::$con, $testFile));
}
/**
* @testdox The size of a file can be returned
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticSize() : void
{
$testFile = __DIR__ . '/test.txt';
File::delete(self::$con, $testFile);
File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE);
self::assertGreaterThan(0, File::size(self::$con, $testFile));
File::delete(self::$con, $testFile);
}
/**
* @testdox The permission of a file can be returned
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticPermission() : void
{
$testFile = __DIR__ . '/test.txt';
File::delete(self::$con, $testFile);
File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE);
self::assertGreaterThan(0, File::permission(self::$con, $testFile));
File::delete(self::$con, $testFile);
}
/**
* @testdox The permission of a none-existing file is negative
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidStaticPermission() : void
{
$testFile = __DIR__ . '/test.txt';
self::assertEquals(-1, File::permission(self::$con, $testFile));
}
/**
* @testdox A file can be copied to a different location
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticCopy() : void
{
$testFile = __DIR__ . '/test.txt';
$newPath = __DIR__ . '/sub/path/testing.txt';
File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE);
self::assertTrue(File::copy(self::$con, $testFile, $newPath));
self::assertTrue(File::exists(self::$con, $newPath));
self::assertEquals('test', File::get(self::$con, $newPath));
File::delete(self::$con, $newPath);
Directory::delete(self::$con, __DIR__ . '/sub/path/');
Directory::delete(self::$con, __DIR__ . '/sub/');
File::delete(self::$con, $testFile);
}
/**
* @testdox A file cannot be copied to a different location if the destination already exists
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidStaticCopy() : void
{
$testFile = __DIR__ . '/test.txt';
$newPath = __DIR__ . '/test2.txt';
File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE);
File::put(self::$con, $newPath, 'test2', ContentPutMode::CREATE);
self::assertFalse(File::copy(self::$con, $testFile, $newPath));
self::assertEquals('test2', File::get(self::$con, $newPath));
File::delete(self::$con, $newPath);
File::delete(self::$con, $testFile);
}
/**
* @testdox A file can be forced to be copied to a different location even if the destination already exists
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticCopyOverwrite() : void
{
$testFile = __DIR__ . '/test.txt';
$newPath = __DIR__ . '/test2.txt';
File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE);
File::put(self::$con, $newPath, 'test2', ContentPutMode::CREATE);
self::assertTrue(File::copy(self::$con, $testFile, $newPath, true));
self::assertEquals('test', File::get(self::$con, $newPath));
File::delete(self::$con, $newPath);
File::delete(self::$con, $testFile);
}
/**
* @testdox A file can be moved to a different location
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticMove() : void
{
$testFile = __DIR__ . '/test.txt';
$newPath = __DIR__ . '/sub/path/testing.txt';
File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE);
self::assertTrue(File::move(self::$con, $testFile, $newPath));
self::assertFalse(File::exists(self::$con, $testFile));
self::assertTrue(File::exists(self::$con, $newPath));
self::assertEquals('test', File::get(self::$con, $newPath));
Directory::delete(self::$con, __DIR__ . '/sub');
}
/**
* @testdox A file cannot be moved to a different location if the destination already exists
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidStaticMove() : void
{
$testFile = __DIR__ . '/test.txt';
$newPath = __DIR__ . '/test2.txt';
File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE);
File::put(self::$con, $newPath, 'test2', ContentPutMode::CREATE);
self::assertFalse(File::move(self::$con, $testFile, $newPath));
self::assertTrue(File::exists(self::$con, $testFile));
self::assertEquals('test2', File::get(self::$con, $newPath));
File::delete(self::$con, $newPath);
File::delete(self::$con, $testFile);
}
/**
* @testdox A file can be forced to be moved to a different location even if the destination already exists
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticMoveOverwrite() : void
{
$testFile = __DIR__ . '/test.txt';
$newPath = __DIR__ . '/test2.txt';
File::put(self::$con, $testFile, 'test', ContentPutMode::CREATE);
File::put(self::$con, $newPath, 'test2', ContentPutMode::CREATE);
self::assertTrue(File::move(self::$con, $testFile, $newPath, true));
self::assertFalse(File::exists(self::$con, $testFile));
self::assertEquals('test', File::get(self::$con, $newPath));
File::delete(self::$con, $newPath);
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testStaticOwner() : void
{
$dirTestPath = __DIR__ . '/dirtest/test.txt';
self::assertTrue(!empty(File::owner(self::$con, $dirTestPath)));
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testFileNameSanitizing() : void
{
self::assertEquals('/some/test/[path.txt', File::sanitize(':#&^$/some%/test/[path!.txt'));
}
/**
* @testdox The size of a none-existing file is negative
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidSizePath() : void
{
self::assertEquals(-1, File::size(self::$con, __DIR__ . '/invalid.txt'));
}
/**
* @testdox A none-existing file cannot be copied
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidCopyPath() : void
{
self::assertFalse(File::copy(self::$con, __DIR__ . '/invalid.txt', __DIR__ . '/invalid2.txt'));
}
/**
* @testdox A none-existing file cannot be moved
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidMovePath() : void
{
self::assertFalse(File::move(self::$con, __DIR__ . '/invalid.txt', __DIR__ . '/invalid2.txt'));
}
/**
* @testdox Reading the content of a none-existing file returns an empty string
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidGetPath() : void
{
self::assertEquals('', File::get(self::$con, __DIR__ . '/invalid.txt'));
}
/**
* @testdox Reading the created date of a none-existing file throws a PathException
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidCreatedPath() : void
{
$this->expectException(\phpOMS\System\File\PathException::class);
File::created(self::$con, __DIR__ . '/invalid.txt');
}
/**
* @testdox Reading the last change date of a none-existing file throws a PathException
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidChangedPath() : void
{
$this->expectException(\phpOMS\System\File\PathException::class);
File::changed(self::$con, __DIR__ . '/invalid.txt');
}
/**
* @testdox Reading the owner of a none-existing file throws a PathException
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testInvalidOwnerPath() : void
{
$this->expectException(\phpOMS\System\File\PathException::class);
File::owner(self::$con, __DIR__ . '/invalid.txt');
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodeInputOutput() : void
{
$testFile = __DIR__ . '/test.txt';
if (\is_file($testFile)) {
\unlink($testFile);
}
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
self::assertTrue($file->setContent('test'));
self::assertEquals('test', $file->getContent());
if (\is_file($testFile)) {
\unlink($testFile);
}
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodeReplace() : void
{
$testFile = __DIR__ . '/test.txt';
if (\is_file($testFile)) {
\unlink($testFile);
}
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
self::assertTrue($file->setContent('test'));
self::assertTrue($file->setContent('test2'));
self::assertEquals('test2', $file->getContent());
if (\is_file($testFile)) {
\unlink($testFile);
}
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodeAppend() : void
{
$testFile = __DIR__ . '/test.txt';
if (\is_file($testFile)) {
\unlink($testFile);
}
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
self::assertTrue($file->setContent('test'));
self::assertTrue($file->appendContent('2'));
self::assertEquals('test2', $file->getContent());
if (\is_file($testFile)) {
\unlink($testFile);
}
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodePrepend() : void
{
$testFile = __DIR__ . '/test.txt';
if (\is_file($testFile)) {
\unlink($testFile);
}
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
self::assertTrue($file->setContent('test'));
self::assertTrue($file->prependContent('2'));
self::assertEquals('2test', $file->getContent());
if (\is_file($testFile)) {
\unlink($testFile);
}
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodeExtension() : void
{
$testFile = __DIR__ . '/test.txt';
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
self::assertEquals('txt', $file->getExtension());
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodeCreatedAt() : void
{
$testFile = __DIR__ . '/test.txt';
if (\is_file($testFile)) {
\unlink($testFile);
}
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
$file->createNode();
$now = new \DateTime('now');
self::assertEquals($now->format('Y-m-d'), $file->getCreatedAt()->format('Y-m-d'));
if (\is_file($testFile)) {
\unlink($testFile);
}
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodeChangedAt() : void
{
$testFile = __DIR__ . '/test.txt';
if (\is_file($testFile)) {
\unlink($testFile);
}
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
$file->createNode();
$now = new \DateTime('now');
self::assertEquals($now->format('Y-m-d'), $file->getChangedAt()->format('Y-m-d'));
if (\is_file($testFile)) {
\unlink($testFile);
}
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodeOwner() : void
{
$testFile = __DIR__ . '/dirtest/test.txt';
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
self::assertTrue(!empty($file->getOwner()));
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodePermission() : void
{
$testFile = __DIR__ . '/dirtest/test.txt';
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
self::assertGreaterThan(0, $file->getPermission());
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testDirname() : void
{
$testFile = __DIR__ . '/dirtest/test.txt';
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
self::assertEquals('dirtest', $file->getDirname());
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testName() : void
{
$testFile = __DIR__ . '/dirtest/test.txt';
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
self::assertEquals('test', $file->getName());
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testBaseame() : void
{
$testFile = __DIR__ . '/dirtest/test.txt';
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
self::assertEquals('test.txt', $file->getBasename());
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testDirpath() : void
{
$testFile = __DIR__ . '/dirtest/test.txt';
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
self::assertEquals(__DIR__ . '/dirtest', $file->getDirPath());
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testParentOutput() : void
{
$testFile = __DIR__ . '/dirtest/test.txt';
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
self::assertEquals(__DIR__ . '/dirtest', $file->getDirPath());
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodeCreate() : void
{
$testFile = __DIR__ . '/test.txt';
if (\is_file($testFile)) {
\unlink($testFile);
}
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
$file->createNode();
self::assertTrue(\is_file($testFile));
if (\is_file($testFile)) {
\unlink($testFile);
}
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodeDelete() : void
{
$testFile = __DIR__ . '/test.txt';
if (\is_file($testFile)) {
\unlink($testFile);
}
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
$file->createNode();
self::assertTrue(\is_file($testFile));
self::assertTrue($file->deleteNode());
\clearstatcache();
self::assertFalse(\is_file($testFile));
if (\is_file($testFile)) {
\unlink($testFile);
}
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodeCopy() : void
{
$testFile = __DIR__ . '/test.txt';
if (\is_file($testFile)) {
\unlink($testFile);
}
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
$file->createNode();
self::assertTrue($file->copyNode(__DIR__ . '/test2.txt'));
self::assertTrue(\is_file($testFile));
self::assertTrue(\is_file(__DIR__ . '/test2.txt'));
if (\is_file($testFile)) {
\unlink($testFile);
}
if (\is_file(__DIR__ . '/test2.txt')) {
\unlink(__DIR__ . '/test2.txt');
}
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodeMove() : void
{
$testFile = __DIR__ . '/test.txt';
if (\is_file($testFile)) {
\unlink($testFile);
}
$file = new File(new HttpUri(self::BASE . $testFile), self::$con);
$file->createNode();
self::assertTrue($file->moveNode(__DIR__ . '/test2.txt'));
self::assertFalse(\is_file($testFile));
self::assertTrue(\is_file(__DIR__ . '/test2.txt'));
if (\is_file(__DIR__ . '/test2.txt')) {
\unlink(__DIR__ . '/test2.txt');
}
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodeExists() : void
{
$file = new File(new HttpUri(self::BASE . __DIR__ . '/dirtest/test.txt'), self::$con);
$file2 = new File(new HttpUri(self::BASE . __DIR__ . '/invalid.txt'), self::$con);
self::assertTrue($file->isExisting());
self::assertFalse($file2->isExisting());
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodeParent() : void
{
$file = new File(new HttpUri(self::BASE . __DIR__ . '/dirtest/test.txt'), self::$con);
self::assertEquals('Ftp', $file->getParent()->getName());
}
/**
* @covers phpOMS\System\File\Ftp\File<extended>
* @group framework
*/
public function testNodeDirectory() : void
{
$file = new File(new HttpUri(self::BASE . __DIR__ . '/dirtest/test.txt'), self::$con);
self::assertEquals('dirtest', $file->getDirectory()->getName());
}
}