mirror of
https://github.com/Ne-Lexa/php-zip.git
synced 2025-08-08 00:16:28 +02:00
zip extra fields tests
This commit is contained in:
240
tests/Extra/Fields/WinZipAesExtraFieldTest.php
Normal file
240
tests/Extra/Fields/WinZipAesExtraFieldTest.php
Normal file
@@ -0,0 +1,240 @@
|
||||
<?php
|
||||
|
||||
namespace PhpZip\Tests\Extra\Fields;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use PhpZip\Constants\ZipCompressionMethod;
|
||||
use PhpZip\Constants\ZipEncryptionMethod;
|
||||
use PhpZip\Exception\InvalidArgumentException;
|
||||
use PhpZip\Exception\ZipException;
|
||||
use PhpZip\Exception\ZipUnsupportMethodException;
|
||||
use PhpZip\Model\Extra\Fields\WinZipAesExtraField;
|
||||
|
||||
/**
|
||||
* @internal
|
||||
*
|
||||
* @small
|
||||
*/
|
||||
final class WinZipAesExtraFieldTest extends TestCase
|
||||
{
|
||||
/**
|
||||
* @dataProvider provideExtraField
|
||||
*
|
||||
* @param int $vendorVersion
|
||||
* @param int $keyStrength
|
||||
* @param int $compressionMethod
|
||||
* @param int $saltSize
|
||||
* @param string $binaryData
|
||||
*
|
||||
* @throws ZipException
|
||||
* @throws ZipUnsupportMethodException
|
||||
*/
|
||||
public function testExtraField(
|
||||
$vendorVersion,
|
||||
$keyStrength,
|
||||
$compressionMethod,
|
||||
$saltSize,
|
||||
$binaryData
|
||||
) {
|
||||
$extraField = new WinZipAesExtraField($vendorVersion, $keyStrength, $compressionMethod);
|
||||
self::assertSame($extraField->getHeaderId(), WinZipAesExtraField::HEADER_ID);
|
||||
self::assertSame($extraField->getVendorVersion(), $vendorVersion);
|
||||
self::assertSame($extraField->getKeyStrength(), $keyStrength);
|
||||
self::assertSame($extraField->getCompressionMethod(), $compressionMethod);
|
||||
self::assertSame($extraField->getVendorId(), WinZipAesExtraField::VENDOR_ID);
|
||||
self::assertSame($extraField->getSaltSize(), $saltSize);
|
||||
|
||||
self::assertSame($binaryData, $extraField->packLocalFileData());
|
||||
self::assertSame($binaryData, $extraField->packCentralDirData());
|
||||
self::assertEquals(WinZipAesExtraField::unpackLocalFileData($binaryData), $extraField);
|
||||
self::assertEquals(WinZipAesExtraField::unpackCentralDirData($binaryData), $extraField);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return array
|
||||
*/
|
||||
public function provideExtraField()
|
||||
{
|
||||
return [
|
||||
[
|
||||
WinZipAesExtraField::VERSION_AE1,
|
||||
WinZipAesExtraField::KEY_STRENGTH_128BIT,
|
||||
ZipCompressionMethod::STORED,
|
||||
8,
|
||||
"\x01\x00AE\x01\x00\x00",
|
||||
],
|
||||
[
|
||||
WinZipAesExtraField::VERSION_AE1,
|
||||
WinZipAesExtraField::KEY_STRENGTH_192BIT,
|
||||
ZipCompressionMethod::DEFLATED,
|
||||
12,
|
||||
"\x01\x00AE\x02\x08\x00",
|
||||
],
|
||||
[
|
||||
WinZipAesExtraField::VERSION_AE2,
|
||||
WinZipAesExtraField::KEY_STRENGTH_128BIT,
|
||||
ZipCompressionMethod::DEFLATED,
|
||||
8,
|
||||
"\x02\x00AE\x01\x08\x00",
|
||||
],
|
||||
[
|
||||
WinZipAesExtraField::VERSION_AE2,
|
||||
WinZipAesExtraField::KEY_STRENGTH_256BIT,
|
||||
ZipCompressionMethod::STORED,
|
||||
16,
|
||||
"\x02\x00AE\x03\x00\x00",
|
||||
],
|
||||
[
|
||||
WinZipAesExtraField::VERSION_AE2,
|
||||
WinZipAesExtraField::KEY_STRENGTH_192BIT,
|
||||
ZipCompressionMethod::DEFLATED,
|
||||
12,
|
||||
"\x02\x00AE\x02\x08\x00",
|
||||
],
|
||||
[
|
||||
WinZipAesExtraField::VERSION_AE2,
|
||||
WinZipAesExtraField::KEY_STRENGTH_256BIT,
|
||||
ZipCompressionMethod::STORED,
|
||||
16,
|
||||
"\x02\x00AE\x03\x00\x00",
|
||||
],
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws ZipUnsupportMethodException
|
||||
*/
|
||||
public function testSetter()
|
||||
{
|
||||
$extraField = new WinZipAesExtraField(
|
||||
WinZipAesExtraField::VERSION_AE1,
|
||||
WinZipAesExtraField::KEY_STRENGTH_256BIT,
|
||||
ZipCompressionMethod::DEFLATED
|
||||
);
|
||||
|
||||
self::assertSame($extraField->getVendorVersion(), WinZipAesExtraField::VERSION_AE1);
|
||||
self::assertSame($extraField->getKeyStrength(), WinZipAesExtraField::KEY_STRENGTH_256BIT);
|
||||
self::assertSame($extraField->getCompressionMethod(), ZipCompressionMethod::DEFLATED);
|
||||
self::assertSame($extraField->getSaltSize(), 16);
|
||||
self::assertSame($extraField->getEncryptionStrength(), 256);
|
||||
self::assertSame($extraField->getEncryptionMethod(), ZipEncryptionMethod::WINZIP_AES_256);
|
||||
|
||||
$extraField->setVendorVersion(WinZipAesExtraField::VERSION_AE2);
|
||||
self::assertSame($extraField->getVendorVersion(), WinZipAesExtraField::VERSION_AE2);
|
||||
self::assertSame($extraField->getKeyStrength(), WinZipAesExtraField::KEY_STRENGTH_256BIT);
|
||||
self::assertSame($extraField->getCompressionMethod(), ZipCompressionMethod::DEFLATED);
|
||||
self::assertSame($extraField->getSaltSize(), 16);
|
||||
self::assertSame($extraField->getEncryptionStrength(), 256);
|
||||
self::assertSame($extraField->getEncryptionMethod(), ZipEncryptionMethod::WINZIP_AES_256);
|
||||
|
||||
$extraField->setKeyStrength(WinZipAesExtraField::KEY_STRENGTH_128BIT);
|
||||
self::assertSame($extraField->getVendorVersion(), WinZipAesExtraField::VERSION_AE2);
|
||||
self::assertSame($extraField->getKeyStrength(), WinZipAesExtraField::KEY_STRENGTH_128BIT);
|
||||
self::assertSame($extraField->getCompressionMethod(), ZipCompressionMethod::DEFLATED);
|
||||
self::assertSame($extraField->getSaltSize(), 8);
|
||||
self::assertSame($extraField->getEncryptionStrength(), 128);
|
||||
self::assertSame($extraField->getEncryptionMethod(), ZipEncryptionMethod::WINZIP_AES_128);
|
||||
|
||||
$extraField->setKeyStrength(WinZipAesExtraField::KEY_STRENGTH_192BIT);
|
||||
self::assertSame($extraField->getVendorVersion(), WinZipAesExtraField::VERSION_AE2);
|
||||
self::assertSame($extraField->getKeyStrength(), WinZipAesExtraField::KEY_STRENGTH_192BIT);
|
||||
self::assertSame($extraField->getCompressionMethod(), ZipCompressionMethod::DEFLATED);
|
||||
self::assertSame($extraField->getSaltSize(), 12);
|
||||
self::assertSame($extraField->getEncryptionStrength(), 192);
|
||||
self::assertSame($extraField->getEncryptionMethod(), ZipEncryptionMethod::WINZIP_AES_192);
|
||||
|
||||
$extraField->setCompressionMethod(ZipCompressionMethod::STORED);
|
||||
self::assertSame($extraField->getVendorVersion(), WinZipAesExtraField::VERSION_AE2);
|
||||
self::assertSame($extraField->getKeyStrength(), WinZipAesExtraField::KEY_STRENGTH_192BIT);
|
||||
self::assertSame($extraField->getCompressionMethod(), ZipCompressionMethod::STORED);
|
||||
self::assertSame($extraField->getSaltSize(), 12);
|
||||
self::assertSame($extraField->getEncryptionStrength(), 192);
|
||||
self::assertSame($extraField->getEncryptionMethod(), ZipEncryptionMethod::WINZIP_AES_192);
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws ZipUnsupportMethodException
|
||||
*/
|
||||
public function testConstructUnsupportVendorVersion()
|
||||
{
|
||||
$this->setExpectedException(InvalidArgumentException::class, 'Unsupport WinZip AES vendor version: 3');
|
||||
|
||||
new WinZipAesExtraField(
|
||||
3,
|
||||
WinZipAesExtraField::KEY_STRENGTH_192BIT,
|
||||
ZipCompressionMethod::STORED
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws ZipUnsupportMethodException
|
||||
*/
|
||||
public function testSetterUnsupportVendorVersion()
|
||||
{
|
||||
$this->setExpectedException(InvalidArgumentException::class, 'Unsupport WinZip AES vendor version: 3');
|
||||
|
||||
$extraField = new WinZipAesExtraField(
|
||||
WinZipAesExtraField::VERSION_AE1,
|
||||
WinZipAesExtraField::KEY_STRENGTH_192BIT,
|
||||
ZipCompressionMethod::STORED
|
||||
);
|
||||
$extraField->setVendorVersion(3);
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws ZipUnsupportMethodException
|
||||
*/
|
||||
public function testConstructUnsupportCompressionMethod()
|
||||
{
|
||||
$this->setExpectedException(ZipUnsupportMethodException::class, 'Compression method 3 (Reduced compression factor 2) is not supported.');
|
||||
|
||||
new WinZipAesExtraField(
|
||||
WinZipAesExtraField::VERSION_AE1,
|
||||
WinZipAesExtraField::KEY_STRENGTH_192BIT,
|
||||
3
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws ZipUnsupportMethodException
|
||||
*/
|
||||
public function testSetterUnsupportCompressionMethod()
|
||||
{
|
||||
$this->setExpectedException(ZipUnsupportMethodException::class, 'Compression method 3 (Reduced compression factor 2) is not supported.');
|
||||
|
||||
$extraField = new WinZipAesExtraField(
|
||||
WinZipAesExtraField::VERSION_AE1,
|
||||
WinZipAesExtraField::KEY_STRENGTH_192BIT,
|
||||
ZipCompressionMethod::STORED
|
||||
);
|
||||
$extraField->setCompressionMethod(3);
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws ZipUnsupportMethodException
|
||||
*/
|
||||
public function testConstructUnsupportKeyStrength()
|
||||
{
|
||||
$this->setExpectedException(InvalidArgumentException::class, 'Key strength 16 not support value. Allow values: 1, 2, 3');
|
||||
|
||||
new WinZipAesExtraField(
|
||||
WinZipAesExtraField::VERSION_AE1,
|
||||
0x10,
|
||||
ZipCompressionMethod::STORED
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws ZipUnsupportMethodException
|
||||
*/
|
||||
public function testSetterUnsupportKeyStrength()
|
||||
{
|
||||
$this->setExpectedException(InvalidArgumentException::class, 'Key strength 16 not support value. Allow values: 1, 2, 3');
|
||||
|
||||
new WinZipAesExtraField(
|
||||
WinZipAesExtraField::VERSION_AE1,
|
||||
0x10,
|
||||
ZipCompressionMethod::STORED
|
||||
);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user