347 lines
12 KiB
PHP
347 lines
12 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace OSS\Tests;
|
||
|
|
||
|
use OSS\Core\OssException;
|
||
|
use OSS\OssClient;
|
||
|
|
||
|
|
||
|
class OssClientTest extends TestOssClientBase
|
||
|
{
|
||
|
public function testConstrunct()
|
||
|
{
|
||
|
try {
|
||
|
$ossClient = new OssClient('id', 'key', 'http://oss-cn-hangzhou.aliyuncs.com');
|
||
|
$this->assertFalse($ossClient->isUseSSL());
|
||
|
$ossClient->setUseSSL(true);
|
||
|
$this->assertTrue($ossClient->isUseSSL());
|
||
|
$this->assertTrue(true);
|
||
|
$this->assertEquals(3, $ossClient->getMaxRetries());
|
||
|
$ossClient->setMaxTries(4);
|
||
|
$this->assertEquals(4, $ossClient->getMaxRetries());
|
||
|
$ossClient->setTimeout(10);
|
||
|
$ossClient->setConnectTimeout(20);
|
||
|
} catch (OssException $e) {
|
||
|
assertFalse(true);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testConstrunct2()
|
||
|
{
|
||
|
try {
|
||
|
$ossClient = new OssClient('id', "", 'http://oss-cn-hangzhou.aliyuncs.com');
|
||
|
$this->assertFalse(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertEquals("access key secret is empty", $e->getMessage());
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testConstrunct3()
|
||
|
{
|
||
|
try {
|
||
|
$ossClient = new OssClient("", 'key', 'http://oss-cn-hangzhou.aliyuncs.com');
|
||
|
$this->assertFalse(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertEquals("access key id is empty", $e->getMessage());
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testConstrunct4()
|
||
|
{
|
||
|
try {
|
||
|
$ossClient = new OssClient('id', 'key', "");
|
||
|
$this->assertFalse(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertEquals('endpoint is empty', $e->getMessage());
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testConstrunct5()
|
||
|
{
|
||
|
try {
|
||
|
$ossClient = new OssClient('id', 'key', "123.123.123.1");
|
||
|
$this->assertTrue(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertTrue(false);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testConstrunct6()
|
||
|
{
|
||
|
try {
|
||
|
$ossClient = new OssClient('id', 'key', "https://123.123.123.1");
|
||
|
$this->assertTrue($ossClient->isUseSSL());
|
||
|
$this->assertTrue(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertTrue(false);
|
||
|
}
|
||
|
|
||
|
try {
|
||
|
$ossClient = new OssClient('id', 'key', "https://123.123.123.1:3128");
|
||
|
$this->assertTrue($ossClient->isUseSSL());
|
||
|
$this->assertTrue(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertTrue(false);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testConstrunct7()
|
||
|
{
|
||
|
try {
|
||
|
$ossClient = new OssClient('id', 'key', "http://123.123.123.1");
|
||
|
$this->assertFalse($ossClient->isUseSSL());
|
||
|
$this->assertTrue(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertTrue(false);
|
||
|
}
|
||
|
|
||
|
try {
|
||
|
$ossClient = new OssClient('id', 'key', "http://123.123.123.1:3128");
|
||
|
$this->assertFalse($ossClient->isUseSSL());
|
||
|
$this->assertTrue(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertTrue(false);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testConstrunct8()
|
||
|
{
|
||
|
try {
|
||
|
$ossClient = new OssClient('id', 'key', "http://123.123.123.1", true);
|
||
|
$ossClient->listBuckets();
|
||
|
$this->assertFalse(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertFalse(false);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testConstrunct9()
|
||
|
{
|
||
|
try {
|
||
|
$accessKeyId = ' ' . getenv('OSS_ACCESS_KEY_ID') . ' ';
|
||
|
$accessKeySecret = ' ' . getenv('OSS_ACCESS_KEY_SECRET') . ' ';
|
||
|
$endpoint = ' ' . getenv('OSS_ENDPOINT') . '/ ';
|
||
|
$ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint, false);
|
||
|
$ossClient->listBuckets();
|
||
|
$this->assertTrue(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertFalse(true);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testConstrunct10()
|
||
|
{
|
||
|
try {
|
||
|
$ossClient = new OssClient('id', 'key', "http://ABC-COM.TEST.123.cn", true);
|
||
|
$this->assertTrue(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertTrue(false);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testConstrunct11()
|
||
|
{
|
||
|
try {
|
||
|
$ossClient = new OssClient('id', 'key', "oss-test.com\\aliyuncs.com");
|
||
|
$this->assertFalse(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertEquals('endpoint is invalid:'."oss-test.com\\aliyuncs.com", $e->getMessage());
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testConstrunct12()
|
||
|
{
|
||
|
try {
|
||
|
$ossClient = new OssClient('id', 'key', "192.168.1.0:abc123");
|
||
|
$this->assertFalse(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertEquals('endpoint is invalid:'."192.168.1.0:abc123", $e->getMessage());
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testSupportPutEmptyObject()
|
||
|
{
|
||
|
try {
|
||
|
$accessKeyId = ' ' . getenv('OSS_ACCESS_KEY_ID') . ' ';
|
||
|
$accessKeySecret = ' ' . getenv('OSS_ACCESS_KEY_SECRET') . ' ';
|
||
|
$endpoint = ' ' . getenv('OSS_ENDPOINT') . '/ ';
|
||
|
$bucket = $this->bucket;
|
||
|
$ossClient = new OssClient($accessKeyId, $accessKeySecret , $endpoint, false);
|
||
|
$ossClient->putObject($bucket,'test_emptybody','');
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertFalse(true);
|
||
|
}
|
||
|
|
||
|
//use invalid sts-token, should fail.
|
||
|
try {
|
||
|
$accessKeyId = ' ' . getenv('OSS_ACCESS_KEY_ID') . ' ';
|
||
|
$accessKeySecret = ' ' . getenv('OSS_ACCESS_KEY_SECRET') . ' ';
|
||
|
$endpoint = ' ' . getenv('OSS_ENDPOINT') . '/ ';
|
||
|
$bucket = $this->bucket;
|
||
|
$ossClient = new OssClient($accessKeyId, $accessKeySecret , $endpoint, false, "invalid-sts-token");
|
||
|
$ossClient->putObject($bucket,'test_emptybody','');
|
||
|
$this->assertTrue(false);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertEquals('InvalidAccessKeyId', $e->getErrorCode());
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testCreateObjectDir()
|
||
|
{
|
||
|
$accessKeyId = ' ' . getenv('OSS_ACCESS_KEY_ID') . ' ';
|
||
|
$accessKeySecret = ' ' . getenv('OSS_ACCESS_KEY_SECRET') . ' ';
|
||
|
$endpoint = ' ' . getenv('OSS_ENDPOINT') . '/ ';
|
||
|
$bucket = $this->bucket;
|
||
|
$ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint, false);
|
||
|
|
||
|
try {
|
||
|
$object='test-dir';
|
||
|
$ossClient->createObjectDir($bucket,$object);
|
||
|
$this->assertTrue(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertFalse(true);
|
||
|
}
|
||
|
|
||
|
try {
|
||
|
$object='0';
|
||
|
$ossClient->createObjectDir($bucket,$object);
|
||
|
$ossClient->putObject($bucket,$object, '');
|
||
|
$this->assertTrue(true);
|
||
|
} catch (OssException $e) {
|
||
|
var_dump($e);
|
||
|
$this->assertFalse(true);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testGetBucketCors()
|
||
|
{
|
||
|
try {
|
||
|
$accessKeyId = ' ' . getenv('OSS_ACCESS_KEY_ID') . ' ';
|
||
|
$accessKeySecret = ' ' . getenv('OSS_ACCESS_KEY_SECRET') . ' ';
|
||
|
$endpoint = ' ' . getenv('OSS_ENDPOINT') . '/ ';
|
||
|
$bucket = getenv('OSS_BUCKET');
|
||
|
$ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint, false);
|
||
|
$ossClient->getBucketCors($bucket);
|
||
|
$this->assertTrue(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertFalse(true);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testGetBucketCname()
|
||
|
{
|
||
|
try {
|
||
|
$accessKeyId = ' ' . getenv('OSS_ACCESS_KEY_ID') . ' ';
|
||
|
$accessKeySecret = ' ' . getenv('OSS_ACCESS_KEY_SECRET') . ' ';
|
||
|
$endpoint = ' ' . getenv('OSS_ENDPOINT') . '/ ';
|
||
|
$bucket = $this->bucket;
|
||
|
$ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint, false);
|
||
|
$ossClient->getBucketCname($bucket);
|
||
|
$this->assertTrue(true);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertFalse(true);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testProxySupport()
|
||
|
{
|
||
|
$accessKeyId = ' ' . getenv('OSS_ACCESS_KEY_ID') . ' ';
|
||
|
$accessKeySecret = ' ' . getenv('OSS_ACCESS_KEY_SECRET') . ' ';
|
||
|
$endpoint = ' ' . getenv('OSS_ENDPOINT') . '/ ';
|
||
|
$bucket = getenv('OSS_BUCKET') . '-proxy';
|
||
|
$requestProxy = getenv('OSS_PROXY');
|
||
|
$key = 'test-proxy-srv-object';
|
||
|
$content = 'test-content';
|
||
|
$proxys = parse_url($requestProxy);
|
||
|
|
||
|
$ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint, false, null, $requestProxy);
|
||
|
|
||
|
$result = $ossClient->createBucket($bucket);
|
||
|
$this->checkProxy($result, $proxys);
|
||
|
|
||
|
$result = $ossClient->putObject($bucket, $key, $content);
|
||
|
$this->checkProxy($result, $proxys);
|
||
|
$result = $ossClient->getObject($bucket, $key);
|
||
|
$this->assertEquals($content, $result);
|
||
|
|
||
|
// list object
|
||
|
$objectListInfo = $ossClient->listObjects($bucket);
|
||
|
$objectList = $objectListInfo->getObjectList();
|
||
|
$this->assertNotNull($objectList);
|
||
|
$this->assertTrue(is_array($objectList));
|
||
|
$objects = array();
|
||
|
foreach ($objectList as $value) {
|
||
|
$objects[] = $value->getKey();
|
||
|
}
|
||
|
$this->assertEquals(1, count($objects));
|
||
|
$this->assertTrue(in_array($key, $objects));
|
||
|
|
||
|
$result = $ossClient->deleteObject($bucket, $key);
|
||
|
$this->checkProxy($result,$proxys);
|
||
|
|
||
|
$result = $ossClient->deleteBucket($bucket);
|
||
|
$this->checkProxy($result, $proxys);
|
||
|
}
|
||
|
|
||
|
private function checkProxy($result, $proxys)
|
||
|
{
|
||
|
$this->assertEquals($result['info']['primary_ip'], $proxys['host']);
|
||
|
$this->assertEquals($result['info']['primary_port'], $proxys['port']);
|
||
|
$this->assertTrue(array_key_exists('via', $result));
|
||
|
}
|
||
|
|
||
|
public function testIpEndpoint()
|
||
|
{
|
||
|
try {
|
||
|
$accessKeyId = 'sk' . getenv('OSS_ACCESS_KEY_ID') . ' ';
|
||
|
$accessKeySecret = ' ' . getenv('OSS_ACCESS_KEY_SECRET') . ' ';
|
||
|
$endpoint = '192.168.1.1';
|
||
|
$bucket = getenv('OSS_BUCKET');
|
||
|
$ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint, false);
|
||
|
$object = "a.file";
|
||
|
$timeout = 3600;
|
||
|
$options = array('Content-Type' => 'txt');
|
||
|
$signedUrl = $ossClient->signUrl($bucket, $object, $timeout, "PUT", $options);
|
||
|
$this->assertTrue(strpos($signedUrl, '192.168.1.1/skyranch-php-test/a.file?') != false);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertFalse(true);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testCnameEndpoint()
|
||
|
{
|
||
|
try {
|
||
|
$accessKeyId = 'sk' . getenv('OSS_ACCESS_KEY_ID') . ' ';
|
||
|
$accessKeySecret = ' ' . getenv('OSS_ACCESS_KEY_SECRET') . ' ';
|
||
|
$endpoint = 'cname.endpoint';
|
||
|
$bucket = getenv('OSS_BUCKET');
|
||
|
$ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint, true);
|
||
|
$object = "a.file";
|
||
|
$timeout = 3600;
|
||
|
$options = array('Content-Type' => 'txt');
|
||
|
$signedUrl = $ossClient->signUrl($bucket, $object, $timeout, "PUT", $options);
|
||
|
$this->assertTrue(strpos($signedUrl, 'cname.endpoint/a.file?') != false);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertFalse(true);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testStsToken()
|
||
|
{
|
||
|
try {
|
||
|
$accessKeyId = 'sk' . getenv('OSS_ACCESS_KEY_ID') . ' ';
|
||
|
$accessKeySecret = ' ' . getenv('OSS_ACCESS_KEY_SECRET') . ' ';
|
||
|
$endpoint = ' ' . getenv('OSS_ENDPOINT') . '/ ';
|
||
|
$bucket = getenv('OSS_BUCKET');
|
||
|
$ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint, false, "test-token");
|
||
|
$object = "a.file";
|
||
|
$timeout = 3600;
|
||
|
$options = array('Content-Type' => 'txt');
|
||
|
$signedUrl = $ossClient->signUrl($bucket, $object, $timeout, "PUT", $options);
|
||
|
$this->assertTrue(strpos($signedUrl, 'security-token=test-token') != false);
|
||
|
} catch (OssException $e) {
|
||
|
$this->assertFalse(true);
|
||
|
}
|
||
|
}
|
||
|
}
|