forked from friendica/friendica-addons
58 lines
1.5 KiB
PHP
58 lines
1.5 KiB
PHP
|
<?php
|
||
|
/**
|
||
|
* Akeeba Engine
|
||
|
*
|
||
|
* @package akeebaengine
|
||
|
* @copyright Copyright (c)2006-2020 Nicholas K. Dionysopoulos / Akeeba Ltd
|
||
|
* @license GNU General Public License version 3, or later
|
||
|
*/
|
||
|
|
||
|
namespace Akeeba\MiniTest\Test;
|
||
|
|
||
|
|
||
|
use Akeeba\Engine\Postproc\Connector\S3v4\Connector;
|
||
|
use Akeeba\Engine\Postproc\Connector\S3v4\Input;
|
||
|
|
||
|
/**
|
||
|
* Upload, download and delete small files (under 1MB) using a string source
|
||
|
*
|
||
|
* @package Akeeba\MiniTest\Test
|
||
|
*/
|
||
|
class SmallInlineFiles extends SmallFiles
|
||
|
{
|
||
|
protected static function upload(Connector $s3, array $options, int $size, string $uri): bool
|
||
|
{
|
||
|
// Randomize the name. Required for archive buckets where you cannot overwrite data.
|
||
|
$dotPos = strrpos($uri, '.');
|
||
|
$uri = substr($uri, 0, $dotPos) . '.' . md5(microtime(false)) . substr($uri, $dotPos);
|
||
|
|
||
|
// Create some random data to upload
|
||
|
$sourceData = self::getRandomData($size);
|
||
|
|
||
|
// Upload the data. Throws exception if it fails.
|
||
|
$bucket = $options['bucket'];
|
||
|
$input = Input::createFromData($sourceData);
|
||
|
|
||
|
$s3->putObject($input, $bucket, $uri);
|
||
|
|
||
|
// Tentatively accept that this method succeeded.
|
||
|
$result = true;
|
||
|
|
||
|
// Should I download the file and compare its contents with my random data?
|
||
|
if (self::$downloadAfter)
|
||
|
{
|
||
|
$downloadedData = $s3->getObject($bucket, $uri);
|
||
|
|
||
|
$result = self::areStringsEqual($sourceData, $downloadedData);
|
||
|
}
|
||
|
|
||
|
// Should I delete the remotely stored file?
|
||
|
if (self::$deleteRemote)
|
||
|
{
|
||
|
// Delete the remote file. Throws exception if it fails.
|
||
|
$s3->deleteObject($bucket, $uri);
|
||
|
}
|
||
|
|
||
|
return $result;
|
||
|
}
|
||
|
}
|