mirror of
https://github.com/roundcube/roundcubemail.git
synced 2026-03-06 16:16:48 +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
72 lines
2.6 KiB
PHP
72 lines
2.6 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Test class to test rcmail_action_utils_modcss
|
|
*/
|
|
class Actions_Utils_Modcss extends ActionTestCase
|
|
{
|
|
/**
|
|
* Test for run()
|
|
*/
|
|
public function test_run()
|
|
{
|
|
$action = new rcmail_action_utils_modcss();
|
|
$output = $this->initOutput(rcmail_action::MODE_HTTP, 'utils', 'modcss');
|
|
|
|
$this->assertInstanceOf('rcmail_action', $action);
|
|
$this->assertTrue($action->checks());
|
|
|
|
// No input parameters
|
|
$this->runAndAssert($action, OutputHtmlMock::E_EXIT);
|
|
|
|
$this->assertSame(403, $output->getProperty('errorCode'));
|
|
$this->assertSame('Unauthorized request', $output->getProperty('errorMessage'));
|
|
$this->assertNull($output->getOutput());
|
|
|
|
// Invalid url
|
|
$_GET['_u'] = '****';
|
|
$this->runAndAssert($action, OutputHtmlMock::E_EXIT);
|
|
|
|
$this->assertSame(403, $output->getProperty('errorCode'));
|
|
$this->assertSame('Unauthorized request', $output->getProperty('errorMessage'));
|
|
$this->assertNull($output->getOutput());
|
|
|
|
// Valid url but not "registered"
|
|
$url = 'https://raw.githubusercontent.com/roundcube/roundcubemail/master/aaaaaaaaaa';
|
|
$key = 'tmp-123.css';
|
|
$_GET['_u'] = $key;
|
|
|
|
$this->runAndAssert($action, OutputHtmlMock::E_EXIT);
|
|
|
|
$this->assertSame(403, $output->getProperty('errorCode'));
|
|
$this->assertSame('Unauthorized request', $output->getProperty('errorMessage'));
|
|
$this->assertNull($output->getOutput());
|
|
|
|
// Valid url pointing to non-existing resource
|
|
$_SESSION['modcssurls'][$key] = $url;
|
|
|
|
setHttpClientMock([
|
|
['code' => 404],
|
|
['code' => 200, 'headers' => ['Content-Type' => 'text/css'], 'response' => 'div.pre { display: none; }'],
|
|
]);
|
|
|
|
$this->runAndAssert($action, OutputHtmlMock::E_EXIT);
|
|
|
|
$this->assertSame(404, $output->getProperty('errorCode'));
|
|
$this->assertSame('Invalid response returned by server', $output->getProperty('errorMessage'));
|
|
$this->assertNull($output->getOutput());
|
|
|
|
// Valid url pointing to an existing resource
|
|
$url = 'https://raw.githubusercontent.com/roundcube/roundcubemail/master/program/resources/tinymce/content.css';
|
|
$_SESSION['modcssurls'][$key] = $url;
|
|
$_GET['_p'] = 'prefix';
|
|
$_GET['_c'] = 'cid';
|
|
|
|
$this->runAndAssert($action, OutputHtmlMock::E_EXIT);
|
|
|
|
$this->assertNull($output->getProperty('errorCode'));
|
|
$this->assertSame(['Content-Type: text/css'], $output->getProperty('headers'));
|
|
$this->assertStringContainsString('#cid div.prefixpre', $output->getOutput());
|
|
}
|
|
}
|