mirror of
https://github.com/roundcube/roundcubemail.git
synced 2026-03-20 23:07:01 +01:00
* Check plugins composer.json using CI * Add "require-dev" and "config.allow-plugins" to plugins * fix composer.json format - rm invalid email * fix composer.json format - fix ext require * fix composer.json format - fix plugin name * tmp * Revert "tmp" * fix ext in ext install * disable plugin in plugin install until Roundcube is fully autoloadable * fix composer.json format - fix non-canonical license name * Revert "Add "require-dev" and "config.allow-plugins" to plugins" * no composer install for plugins needed * Revert "fix ext in ext install" * add standard "Test" suffix to phpunit files * rm unneeded "suffix" in phpunit config * simplify phpunit config * fix default "xhtml" doctype in unit testing * fix test_format_date test to not rely on other tests * even more phpunit config simplify * stricter/unify phpunit params for E2E tests * run E2E tests on maximal php version too with lowest deps * "repositories" in bundled plugins are useless as for root package only * add/unify missing plugin test
81 lines
2.9 KiB
PHP
81 lines
2.9 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Test class to test rcmail_action_mail_attachment_upload
|
|
*/
|
|
class Actions_Mail_AttachmentUpload extends ActionTestCase
|
|
{
|
|
/**
|
|
* Test file upload
|
|
*/
|
|
public function test_run()
|
|
{
|
|
$action = new rcmail_action_mail_attachment_upload();
|
|
$output = $this->initOutput(rcmail_action::MODE_AJAX, 'mail', 'upload');
|
|
|
|
$this->assertInstanceOf('rcmail_action', $action);
|
|
$this->assertTrue($action->checks());
|
|
|
|
$_SERVER['REQUEST_METHOD'] = 'POST';
|
|
$_GET = [
|
|
'_id' => '123',
|
|
'_uploadid' => 'upload123',
|
|
];
|
|
|
|
$_SESSION = ['compose_data_123' => ['test' => 'test']];
|
|
|
|
// No files uploaded case
|
|
$this->runAndAssert($action, OutputJsonMock::E_EXIT);
|
|
|
|
$result = $output->getOutput();
|
|
|
|
$this->assertSame(['Content-Type: application/json; charset=UTF-8'], $output->headers);
|
|
$this->assertSame('upload', $result['action']);
|
|
$this->assertTrue(strpos($result['exec'], 'this.remove_from_attachment_list("upload123");') !== false);
|
|
$this->assertTrue(strpos($result['exec'], 'this.auto_save_start(false);') !== false);
|
|
|
|
// Upload a file
|
|
$_SESSION = ['compose_data_123' => ['test' => 'test']];
|
|
|
|
$file = $this->fakeUpload('_attachments');
|
|
|
|
$this->runAndAssert($action, OutputJsonMock::E_EXIT);
|
|
|
|
$result = $output->getOutput();
|
|
|
|
$this->assertSame(['Content-Type: application/json; charset=UTF-8'], $output->headers);
|
|
$this->assertSame('upload', $result['action']);
|
|
$this->assertTrue(strpos($result['exec'], 'this.add2attachment_list("rcmfile' . $file['id'] . '"') !== false);
|
|
$this->assertTrue(strpos($result['exec'], 'this.auto_save_start(false);') !== false);
|
|
|
|
$upload = rcmail::get_instance()->get_uploaded_file($file['id']);
|
|
$this->assertSame($file['name'], $upload['name']);
|
|
$this->assertSame($file['type'], $upload['mimetype']);
|
|
$this->assertSame($file['size'], $upload['size']);
|
|
$this->assertSame($_GET['_id'], $upload['group']);
|
|
|
|
// Upload error case
|
|
$_SESSION = ['compose_data_123' => ['test' => 'test']];
|
|
$file = $this->fakeUpload('_attachments', true, \UPLOAD_ERR_INI_SIZE);
|
|
|
|
$this->runAndAssert($action, OutputJsonMock::E_EXIT);
|
|
|
|
$result = $output->getOutput();
|
|
|
|
$this->assertSame(['Content-Type: application/json; charset=UTF-8'], $output->headers);
|
|
$this->assertSame('upload', $result['action']);
|
|
$this->assertTrue(strpos($result['exec'], 'this.display_message("The uploaded file exceeds the maximum size') !== false);
|
|
$this->assertTrue(strpos($result['exec'], 'this.auto_save_start(false);') !== false);
|
|
|
|
// TODO: Test max_message_size handling
|
|
}
|
|
|
|
/**
|
|
* Test file upload via URI
|
|
*/
|
|
public function test_uri()
|
|
{
|
|
$this->markTestIncomplete();
|
|
}
|
|
}
|