Reenable Twitter/Media Post tests
This commit is contained in:
parent
f84c696925
commit
204b8b6e49
5 changed files with 135 additions and 117 deletions
|
@ -44,7 +44,7 @@ use HTMLPurifier_Config;
|
||||||
*/
|
*/
|
||||||
class Update extends BaseApi
|
class Update extends BaseApi
|
||||||
{
|
{
|
||||||
public function post(array $request = [], array $post = [])
|
public function post(array $request = [])
|
||||||
{
|
{
|
||||||
self::checkAllowedScope(self::SCOPE_WRITE);
|
self::checkAllowedScope(self::SCOPE_WRITE);
|
||||||
$uid = self::getCurrentUserID();
|
$uid = self::getCurrentUserID();
|
||||||
|
@ -101,10 +101,10 @@ class Update extends BaseApi
|
||||||
$item['coord'] = sprintf("%s %s", $request['lat'], $request['long']);
|
$item['coord'] = sprintf("%s %s", $request['lat'], $request['long']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$item['allow_cid'] = $owner['allow_cid'];
|
$item['allow_cid'] = $owner['allow_cid'] ?? '';
|
||||||
$item['allow_gid'] = $owner['allow_gid'];
|
$item['allow_gid'] = $owner['allow_gid'] ?? '';
|
||||||
$item['deny_cid'] = $owner['deny_cid'];
|
$item['deny_cid'] = $owner['deny_cid'] ?? '';
|
||||||
$item['deny_gid'] = $owner['deny_gid'];
|
$item['deny_gid'] = $owner['deny_gid'] ?? '';
|
||||||
|
|
||||||
if (!empty($item['allow_cid'] . $item['allow_gid'] . $item['deny_cid'] . $item['deny_gid'])) {
|
if (!empty($item['allow_cid'] . $item['allow_gid'] . $item['deny_cid'] . $item['deny_gid'])) {
|
||||||
$item['private'] = Item::PRIVATE;
|
$item['private'] = Item::PRIVATE;
|
||||||
|
@ -127,8 +127,8 @@ class Update extends BaseApi
|
||||||
$item['object-type'] = Activity\ObjectType::NOTE;
|
$item['object-type'] = Activity\ObjectType::NOTE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($_REQUEST['media_ids'])) {
|
if (!empty($request['media_ids'])) {
|
||||||
$ids = explode(',', $_REQUEST['media_ids']);
|
$ids = explode(',', $request['media_ids']);
|
||||||
} elseif (!empty($_FILES['media'])) {
|
} elseif (!empty($_FILES['media'])) {
|
||||||
// upload the image if we have one
|
// upload the image if we have one
|
||||||
$picture = Photo::upload($uid, $_FILES['media']);
|
$picture = Photo::upload($uid, $_FILES['media']);
|
||||||
|
|
|
@ -835,97 +835,6 @@ class ApiTest extends FixtureTest
|
||||||
// api_statuses_mediap('json');
|
// api_statuses_mediap('json');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Test the api_statuses_update() function.
|
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
public function testApiStatusesUpdate()
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
$_REQUEST['status'] = 'Status content #friendica';
|
|
||||||
$_REQUEST['in_reply_to_status_id'] = -1;
|
|
||||||
$_REQUEST['lat'] = 48;
|
|
||||||
$_REQUEST['long'] = 7;
|
|
||||||
$_FILES = [
|
|
||||||
'media' => [
|
|
||||||
'id' => 666,
|
|
||||||
'size' => 666,
|
|
||||||
'width' => 666,
|
|
||||||
'height' => 666,
|
|
||||||
'tmp_name' => $this->getTempImage(),
|
|
||||||
'name' => 'spacer.png',
|
|
||||||
'type' => 'image/png'
|
|
||||||
]
|
|
||||||
];
|
|
||||||
|
|
||||||
$result = api_statuses_update('json');
|
|
||||||
self::assertStatus($result['status']);
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Test the api_statuses_update() function with an HTML status.
|
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
public function testApiStatusesUpdateWithHtml()
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
$_REQUEST['htmlstatus'] = '<b>Status content</b>';
|
|
||||||
|
|
||||||
$result = api_statuses_update('json');
|
|
||||||
self::assertStatus($result['status']);
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Test the api_statuses_update() function without an authenticated user.
|
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
public function testApiStatusesUpdateWithoutAuthenticatedUser()
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
$this->expectException(\Friendica\Network\HTTPException\UnauthorizedException::class);
|
|
||||||
BasicAuth::setCurrentUserID();
|
|
||||||
$_SESSION['authenticated'] = false;
|
|
||||||
api_statuses_update('json');
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Test the api_statuses_update() function with a parent status.
|
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
public function testApiStatusesUpdateWithParent()
|
|
||||||
{
|
|
||||||
$this->markTestIncomplete('This triggers an exit() somewhere and kills PHPUnit.');
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Test the api_statuses_update() function with a media_ids parameter.
|
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
public function testApiStatusesUpdateWithMediaIds()
|
|
||||||
{
|
|
||||||
$this->markTestIncomplete();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Test the api_statuses_update() function with the throttle limit reached.
|
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
public function testApiStatusesUpdateWithDayThrottleReached()
|
|
||||||
{
|
|
||||||
$this->markTestIncomplete();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test the api_statuses_repeat() function.
|
* Test the api_statuses_repeat() function.
|
||||||
*
|
*
|
||||||
|
|
|
@ -126,6 +126,25 @@ abstract class ApiTest extends FixtureTest
|
||||||
// We could probably do more checks here.
|
// We could probably do more checks here.
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the path to a temporary empty PNG image.
|
||||||
|
*
|
||||||
|
* @return string Path
|
||||||
|
*/
|
||||||
|
protected function getTempImage()
|
||||||
|
{
|
||||||
|
$tmpFile = tempnam(sys_get_temp_dir(), 'tmp_file');
|
||||||
|
file_put_contents(
|
||||||
|
$tmpFile,
|
||||||
|
base64_decode(
|
||||||
|
// Empty 1x1 px PNG image
|
||||||
|
'iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVR42mP8/5+hHgAHggJ/PchI7wAAAABJRU5ErkJggg=='
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
return $tmpFile;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Transforms a response into a JSON class
|
* Transforms a response into a JSON class
|
||||||
*
|
*
|
||||||
|
|
|
@ -80,23 +80,4 @@ class UploadTest extends ApiTest
|
||||||
self::assertEquals(1, $media->image->h);
|
self::assertEquals(1, $media->image->h);
|
||||||
self::assertNotEmpty($media->image->friendica_preview_url);
|
self::assertNotEmpty($media->image->friendica_preview_url);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the path to a temporary empty PNG image.
|
|
||||||
*
|
|
||||||
* @return string Path
|
|
||||||
*/
|
|
||||||
private function getTempImage()
|
|
||||||
{
|
|
||||||
$tmpFile = tempnam(sys_get_temp_dir(), 'tmp_file');
|
|
||||||
file_put_contents(
|
|
||||||
$tmpFile,
|
|
||||||
base64_decode(
|
|
||||||
// Empty 1x1 px PNG image
|
|
||||||
'iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVR42mP8/5+hHgAHggJ/PchI7wAAAABJRU5ErkJggg=='
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
return $tmpFile;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
109
tests/src/Module/Api/Twitter/Statuses/UpdateTest.php
Normal file
109
tests/src/Module/Api/Twitter/Statuses/UpdateTest.php
Normal file
|
@ -0,0 +1,109 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Friendica\Test\src\Module\Api\Twitter\Statuses;
|
||||||
|
|
||||||
|
use Friendica\App\Router;
|
||||||
|
use Friendica\DI;
|
||||||
|
use Friendica\Module\Api\Twitter\Statuses\Update;
|
||||||
|
use Friendica\Test\src\Module\Api\ApiTest;
|
||||||
|
|
||||||
|
class UpdateTest extends ApiTest
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Test the api_statuses_update() function.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function testApiStatusesUpdate()
|
||||||
|
{
|
||||||
|
$_FILES = [
|
||||||
|
'media' => [
|
||||||
|
'id' => 666,
|
||||||
|
'size' => 666,
|
||||||
|
'width' => 666,
|
||||||
|
'height' => 666,
|
||||||
|
'tmp_name' => $this->getTempImage(),
|
||||||
|
'name' => 'spacer.png',
|
||||||
|
'type' => 'image/png'
|
||||||
|
]
|
||||||
|
];
|
||||||
|
|
||||||
|
$show = new Update(DI::app(), DI::l10n(), DI::baseUrl(), DI::args(), DI::logger(), DI::profiler(), DI::apiResponse(), ['REQUEST_METHOD' => Router::POST]);
|
||||||
|
$response = $show->run([
|
||||||
|
'status' => 'Status content #friendica',
|
||||||
|
'in_reply_to_status_id' => 0,
|
||||||
|
'lat' => 48,
|
||||||
|
'long' => 7,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$json = $this->toJson($response);
|
||||||
|
|
||||||
|
self::assertStatus($json);
|
||||||
|
self::assertContains('Status content #friendica', $json->text);
|
||||||
|
self::assertContains('Status content #', $json->statusnet_html);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the api_statuses_update() function with an HTML status.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function testApiStatusesUpdateWithHtml()
|
||||||
|
{
|
||||||
|
$show = new Update(DI::app(), DI::l10n(), DI::baseUrl(), DI::args(), DI::logger(), DI::profiler(), DI::apiResponse(), ['REQUEST_METHOD' => Router::POST]);
|
||||||
|
$response = $show->run([
|
||||||
|
'htmlstatus' => '<b>Status content</b>',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$json = $this->toJson($response);
|
||||||
|
|
||||||
|
self::assertStatus($json);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the api_statuses_update() function without an authenticated user.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function testApiStatusesUpdateWithoutAuthenticatedUser()
|
||||||
|
{
|
||||||
|
self::markTestIncomplete('Needs BasicAuth as dynamic method for overriding first');
|
||||||
|
|
||||||
|
/*
|
||||||
|
$this->expectException(\Friendica\Network\HTTPException\UnauthorizedException::class);
|
||||||
|
BasicAuth::setCurrentUserID();
|
||||||
|
$_SESSION['authenticated'] = false;
|
||||||
|
api_statuses_update('json');
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the api_statuses_update() function with a parent status.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function testApiStatusesUpdateWithParent()
|
||||||
|
{
|
||||||
|
$this->markTestIncomplete('This triggers an exit() somewhere and kills PHPUnit.');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the api_statuses_update() function with a media_ids parameter.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function testApiStatusesUpdateWithMediaIds()
|
||||||
|
{
|
||||||
|
$this->markTestIncomplete();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the api_statuses_update() function with the throttle limit reached.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function testApiStatusesUpdateWithDayThrottleReached()
|
||||||
|
{
|
||||||
|
$this->markTestIncomplete();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue