Find this useful? Enter your email to receive occasional updates for securing PHP code.
Signing you up...
Thank you for signing up!
PHP Decode
<?php namespace Roundcube\Tests\Actions\Contacts; use PHPUnit\Framework\Attributes\Depen..
Decoded Output download
<?php
namespace Roundcube\Tests\Actions\Contacts;
use PHPUnit\Framework\Attributes\Depends;
use Roundcube\Tests\ActionTestCase;
use Roundcube\Tests\OutputHtmlMock;
use Roundcube\Tests\StderrMock;
/**
* Test class to test rcmail_action_contacts_export
*/
class ExportTest extends ActionTestCase
{
/**
* Test exporting all contacts
*/
public function test_export_all()
{
$action = new
cmail_action_contacts_export();
$output = $this->initOutput(
cmail_action::MODE_HTTP, 'contacts', 'export');
$this->assertInstanceOf(
cmail_action::class, $action);
$this->assertTrue($action->checks());
self::initDB('contacts');
$_GET = ['_source' => '0'];
$_POST = [];
// Here we expect request security check error
$this->runAndAssert($action, OutputHtmlMock::E_EXIT);
$this->assertSame('ERROR: Request security check failed', trim(StderrMock::$output));
// Now we'll try with the proper token
$_SESSION['request_token'] = 'secure';
$_SERVER['HTTP_X_ROUNDCUBE_REQUEST'] = 'secure';
ob_start();
$this->runAndAssert($action, OutputHtmlMock::E_EXIT);
$vcf = ob_get_contents();
ob_end_clean();
$this->assertSame([
'Content-Type: text/vcard; charset=UTF-8',
'Content-Disposition: attachment; filename="contacts.vcf"',
], $output->headers
);
$this->assertSame(6, substr_count($vcf, 'BEGIN:VCARD'));
$this->assertSame(6, substr_count($vcf, 'END:VCARD'));
$this->assertSame(1, substr_count($vcf, 'FN:Jane Stalone'));
}
/**
* Test exporting selected contacts
*
* @depends test_export_all
*/
#[Depends('test_export_all')]
public function test_export_selected()
{
$action = new
cmail_action_contacts_export();
$output = $this->initOutput(
cmail_action::MODE_HTTP, 'contacts', 'export');
$this->assertTrue($action->checks());
$cids = [];
$db =
cmail::get_instance()->get_dbh();
$query = $db->query("SELECT `contact_id` FROM `contacts` WHERE `email` IN ('[email protected]', '[email protected]')");
while ($result = $db->fetch_assoc($query)) {
$cids[] = $result['contact_id'];
}
$_GET = ['_source' => '0', '_cid' => implode(',', $cids)];
// TODO: This really shouldn't be needed
$_REQUEST = ['_cid' => implode(',', $cids)];
$_SESSION['request_token'] = 'secure';
$_SERVER['HTTP_X_ROUNDCUBE_REQUEST'] = 'secure';
ob_start();
$this->runAndAssert($action, OutputHtmlMock::E_EXIT);
$vcf = ob_get_contents();
ob_end_clean();
$this->assertSame([
'Content-Type: text/vcard; charset=UTF-8',
'Content-Disposition: attachment; filename="contacts.vcf"',
], $output->headers
);
$this->assertSame(2, substr_count($vcf, 'BEGIN:VCARD'));
$this->assertSame(2, substr_count($vcf, 'END:VCARD'));
$this->assertSame(0, substr_count($vcf, 'FN:Jane Stalone'));
$this->assertSame(1, substr_count($vcf, 'FN:Jack Rian'));
$this->assertSame(1, substr_count($vcf, 'FN:George Bush'));
}
/**
* Test exporting search result
*
* @depends test_export_all
*/
#[Depends('test_export_all')]
public function test_export_search()
{
$this->markTestIncomplete();
}
/**
* Test prepare_for_export() method
*/
public function test_prepare_for_export()
{
$this->markTestIncomplete();
}
}
?>
Did this file decode correctly?
Original Code
<?php
namespace Roundcube\Tests\Actions\Contacts;
use PHPUnit\Framework\Attributes\Depends;
use Roundcube\Tests\ActionTestCase;
use Roundcube\Tests\OutputHtmlMock;
use Roundcube\Tests\StderrMock;
/**
* Test class to test rcmail_action_contacts_export
*/
class ExportTest extends ActionTestCase
{
/**
* Test exporting all contacts
*/
public function test_export_all()
{
$action = new \rcmail_action_contacts_export();
$output = $this->initOutput(\rcmail_action::MODE_HTTP, 'contacts', 'export');
$this->assertInstanceOf(\rcmail_action::class, $action);
$this->assertTrue($action->checks());
self::initDB('contacts');
$_GET = ['_source' => '0'];
$_POST = [];
// Here we expect request security check error
$this->runAndAssert($action, OutputHtmlMock::E_EXIT);
$this->assertSame('ERROR: Request security check failed', trim(StderrMock::$output));
// Now we'll try with the proper token
$_SESSION['request_token'] = 'secure';
$_SERVER['HTTP_X_ROUNDCUBE_REQUEST'] = 'secure';
ob_start();
$this->runAndAssert($action, OutputHtmlMock::E_EXIT);
$vcf = ob_get_contents();
ob_end_clean();
$this->assertSame([
'Content-Type: text/vcard; charset=UTF-8',
'Content-Disposition: attachment; filename="contacts.vcf"',
], $output->headers
);
$this->assertSame(6, substr_count($vcf, 'BEGIN:VCARD'));
$this->assertSame(6, substr_count($vcf, 'END:VCARD'));
$this->assertSame(1, substr_count($vcf, 'FN:Jane Stalone'));
}
/**
* Test exporting selected contacts
*
* @depends test_export_all
*/
#[Depends('test_export_all')]
public function test_export_selected()
{
$action = new \rcmail_action_contacts_export();
$output = $this->initOutput(\rcmail_action::MODE_HTTP, 'contacts', 'export');
$this->assertTrue($action->checks());
$cids = [];
$db = \rcmail::get_instance()->get_dbh();
$query = $db->query("SELECT `contact_id` FROM `contacts` WHERE `email` IN ('[email protected]', '[email protected]')");
while ($result = $db->fetch_assoc($query)) {
$cids[] = $result['contact_id'];
}
$_GET = ['_source' => '0', '_cid' => implode(',', $cids)];
// TODO: This really shouldn't be needed
$_REQUEST = ['_cid' => implode(',', $cids)];
$_SESSION['request_token'] = 'secure';
$_SERVER['HTTP_X_ROUNDCUBE_REQUEST'] = 'secure';
ob_start();
$this->runAndAssert($action, OutputHtmlMock::E_EXIT);
$vcf = ob_get_contents();
ob_end_clean();
$this->assertSame([
'Content-Type: text/vcard; charset=UTF-8',
'Content-Disposition: attachment; filename="contacts.vcf"',
], $output->headers
);
$this->assertSame(2, substr_count($vcf, 'BEGIN:VCARD'));
$this->assertSame(2, substr_count($vcf, 'END:VCARD'));
$this->assertSame(0, substr_count($vcf, 'FN:Jane Stalone'));
$this->assertSame(1, substr_count($vcf, 'FN:Jack Rian'));
$this->assertSame(1, substr_count($vcf, 'FN:George Bush'));
}
/**
* Test exporting search result
*
* @depends test_export_all
*/
#[Depends('test_export_all')]
public function test_export_search()
{
$this->markTestIncomplete();
}
/**
* Test prepare_for_export() method
*/
public function test_prepare_for_export()
{
$this->markTestIncomplete();
}
}
Function Calls
None |
Stats
MD5 | ac521b628a5227684d8d055e2fd2c4cd |
Eval Count | 0 |
Decode Time | 76 ms |