markTestSkipped( 'The Phar extension is not available.' ); } } /** * @testdox Data can be tar gz packed and unpacked * @covers phpOMS\Utils\IO\Zip\TarGz * @group framework */ public function testTarGz() : void { self::assertTrue(TarGz::pack( [ __DIR__ . '/test a.txt' => 'test a.txt', __DIR__ . '/test b.md' => 'test b.md', __DIR__ . '/test' => 'test', ], __DIR__ . '/test.tar.gz' )); self::assertFileExists(__DIR__ . '/test.tar.gz'); $a = \file_get_contents(__DIR__ . '/test a.txt'); $b = \file_get_contents(__DIR__ . '/test b.md'); $c = \file_get_contents(__DIR__ . '/test/test c.txt'); $d = \file_get_contents(__DIR__ . '/test/test d.txt'); $e = \file_get_contents(__DIR__ . '/test/sub/test e.txt'); \unlink(__DIR__ . '/test a.txt'); \unlink(__DIR__ . '/test b.md'); \unlink(__DIR__ . '/test/test c.txt'); \unlink(__DIR__ . '/test/test d.txt'); \unlink(__DIR__ . '/test/sub/test e.txt'); \rmdir(__DIR__ . '/test/sub'); \rmdir(__DIR__ . '/test'); self::assertTrue(TarGz::unpack(__DIR__ . '/test.tar.gz', __DIR__)); self::assertFileExists(__DIR__ . '/test a.txt'); self::assertFileExists(__DIR__ . '/test b.md'); self::assertFileExists(__DIR__ . '/test/test c.txt'); self::assertFileExists(__DIR__ . '/test/test d.txt'); self::assertFileExists(__DIR__ . '/test/sub/test e.txt'); self::assertFileExists(__DIR__ . '/test/sub'); self::assertFileExists(__DIR__ . '/test'); self::assertEquals($a, \file_get_contents(__DIR__ . '/test a.txt')); self::assertEquals($b, \file_get_contents(__DIR__ . '/test b.md')); self::assertEquals($c, \file_get_contents(__DIR__ . '/test/test c.txt')); self::assertEquals($d, \file_get_contents(__DIR__ . '/test/test d.txt')); self::assertEquals($e, \file_get_contents(__DIR__ . '/test/sub/test e.txt')); \unlink(__DIR__ . '/test.tar.gz'); } /** * @testdox A tar gz archive cannot be overwritten by default * @covers phpOMS\Utils\IO\Zip\TarGz * @group framework */ public function testInvalidTarGz() : void { TarGz::pack( [ __DIR__ . '/test a.txt' => 'test a.txt', __DIR__ . '/test b.md' => 'test b.md', __DIR__ . '/test' => 'test', ], __DIR__ . '/test2.tar.gz' ); self::assertFalse(TarGz::pack( [ __DIR__ . '/test a.txt' => 'test a.txt', __DIR__ . '/test b.md' => 'test b.md', __DIR__ . '/test' => 'test', ], __DIR__ . '/test2.tar.gz' )); \unlink(__DIR__ . '/test2.tar.gz'); } /** * @testdox A none-existing source cannot be unpacked * @covers phpOMS\Utils\IO\Zip\TarGz * @group framework */ public function testInvalidUnpackSource() : void { self::assertFalse(TarGz::unpack(__DIR__ . '/test.tar.gz', __DIR__)); } /** * @testdox A destination cannot be overwritten * @covers phpOMS\Utils\IO\Zip\TarGz * @group framework */ public function testInvalidUnpackDestination() : void { self::assertTrue(TarGz::pack( [ __DIR__ . '/test a.txt' => 'test a.txt', __DIR__ . '/test b.md' => 'test b.md', __DIR__ . '/test' => 'test', ], __DIR__ . '/test3.tar.gz' )); TarGz::unpack(__DIR__ . '/abc/test3.tar.gz', __DIR__); self::assertFalse(TarGz::unpack(__DIR__ . '/abc/test3.tar.gz', __DIR__)); \unlink(__DIR__ . '/test3.tar.gz'); } }