add more tests for Email-ApiCommands
Signed-off-by: Michael Kaufmann (d00p) <d00p@froxlor.org>
This commit is contained in:
@@ -103,24 +103,6 @@ abstract class ApiParameter
|
|||||||
return $param_value;
|
return $param_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* update value of parameter
|
|
||||||
*
|
|
||||||
* @param string $param
|
|
||||||
* @param mixed $value
|
|
||||||
*
|
|
||||||
* @throws Exception
|
|
||||||
* @return boolean
|
|
||||||
*/
|
|
||||||
protected function updateParam($param, $value = null)
|
|
||||||
{
|
|
||||||
if (isset($this->cmd_params[$param])) {
|
|
||||||
$this->cmd_params[$param] = $value;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
throw new Exception("Unable to update parameter '" . $param . "' as it does not exist", 500);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* return list of all parameters
|
* return list of all parameters
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -317,6 +317,7 @@ class EmailAccounts extends ApiCommand implements ResourceEntity
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (Settings::Get('system.mail_quota_enabled') == 1) {
|
||||||
if ($quota != $result['quota']) {
|
if ($quota != $result['quota']) {
|
||||||
if ($customer['email_quota'] != '-1' && ($quota == 0 || ($quota + $customer['email_quota_used'] - $result['quota']) > $customer['email_quota'])) {
|
if ($customer['email_quota'] != '-1' && ($quota == 0 || ($quota + $customer['email_quota_used'] - $result['quota']) > $customer['email_quota'])) {
|
||||||
standard_error('allocatetoomuchquota', $quota, true);
|
standard_error('allocatetoomuchquota', $quota, true);
|
||||||
@@ -327,6 +328,10 @@ class EmailAccounts extends ApiCommand implements ResourceEntity
|
|||||||
$upd_query .= "`quota` = :quota";
|
$upd_query .= "`quota` = :quota";
|
||||||
$upd_params['quota'] = $quota;
|
$upd_params['quota'] = $quota;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
// disable
|
||||||
|
$quota = 0;
|
||||||
|
}
|
||||||
|
|
||||||
// build update query
|
// build update query
|
||||||
if (! empty($upd_query)) {
|
if (! empty($upd_query)) {
|
||||||
@@ -416,6 +421,7 @@ class EmailAccounts extends ApiCommand implements ResourceEntity
|
|||||||
"id" => $id
|
"id" => $id
|
||||||
);
|
);
|
||||||
Database::pexecute($stmt, $params, true, true);
|
Database::pexecute($stmt, $params, true, true);
|
||||||
|
$result['popaccountid'] = 0;
|
||||||
|
|
||||||
if (Settings::Get('system.mail_quota_enabled') == '1' && $customer['email_quota'] != '-1') {
|
if (Settings::Get('system.mail_quota_enabled') == '1' && $customer['email_quota'] != '-1') {
|
||||||
$quota = (int) $result['quota'];
|
$quota = (int) $result['quota'];
|
||||||
|
|||||||
@@ -222,7 +222,7 @@ class MailsTest extends TestCase
|
|||||||
/**
|
/**
|
||||||
* @depends testCustomerEmailForwardersAddAnother
|
* @depends testCustomerEmailForwardersAddAnother
|
||||||
*/
|
*/
|
||||||
public function testCustomerEmailForwardersDeleteunknown()
|
public function testCustomerEmailForwardersDeleteUnknown()
|
||||||
{
|
{
|
||||||
global $admin_userdata;
|
global $admin_userdata;
|
||||||
|
|
||||||
@@ -240,4 +240,132 @@ class MailsTest extends TestCase
|
|||||||
$this->expectExceptionMessage("Unknown forwarder id");
|
$this->expectExceptionMessage("Unknown forwarder id");
|
||||||
EmailForwarders::getLocal($customer_userdata, $data)->delete();
|
EmailForwarders::getLocal($customer_userdata, $data)->delete();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testCustomerEmailsListing()
|
||||||
|
{
|
||||||
|
global $admin_userdata;
|
||||||
|
|
||||||
|
// get customer
|
||||||
|
$json_result = Customers::getLocal($admin_userdata, array(
|
||||||
|
'loginname' => 'test1'
|
||||||
|
))->get();
|
||||||
|
$customer_userdata = json_decode($json_result, true)['data'];
|
||||||
|
|
||||||
|
$json_result = Emails::getLocal($customer_userdata)->listing();
|
||||||
|
$result = json_decode($json_result, true)['data'];
|
||||||
|
$this->assertEquals(2, $result['count']);
|
||||||
|
$this->assertEquals("info@test2.local", $result['list'][0]['email']);
|
||||||
|
$this->assertEquals("@test2.local", $result['list'][1]['email']);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCustomerEmailAccountsAdd()
|
||||||
|
{
|
||||||
|
global $admin_userdata;
|
||||||
|
|
||||||
|
Settings::Set('panel.sendalternativemail', 1, true);
|
||||||
|
// get customer
|
||||||
|
$json_result = Customers::getLocal($admin_userdata, array(
|
||||||
|
'loginname' => 'test1'
|
||||||
|
))->get();
|
||||||
|
$customer_userdata = json_decode($json_result, true)['data'];
|
||||||
|
|
||||||
|
$data = [
|
||||||
|
'emailaddr' => 'info@test2.local',
|
||||||
|
'email_password' => generatePassword(),
|
||||||
|
'alternative_email' => 'noone@example.com',
|
||||||
|
'email_quota' => 1337
|
||||||
|
];
|
||||||
|
$json_result = EmailAccounts::getLocal($customer_userdata, $data)->add();
|
||||||
|
$result = json_decode($json_result, true)['data'];
|
||||||
|
$this->assertEquals(1, $result['popaccountid']);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAdminEmailAccountsUpdate()
|
||||||
|
{
|
||||||
|
global $admin_userdata;
|
||||||
|
|
||||||
|
// get customer
|
||||||
|
$json_result = Customers::getLocal($admin_userdata, array(
|
||||||
|
'loginname' => 'test1'
|
||||||
|
))->get();
|
||||||
|
$customer_userdata = json_decode($json_result, true)['data'];
|
||||||
|
|
||||||
|
$data = [
|
||||||
|
'emailaddr' => 'info@test2.local',
|
||||||
|
'email_password' => generatePassword(),
|
||||||
|
'alternative_email' => 'noone@example.com',
|
||||||
|
'email_quota' => 1338
|
||||||
|
];
|
||||||
|
$json_result = EmailAccounts::getLocal($customer_userdata, $data)->update();
|
||||||
|
$result = json_decode($json_result, true)['data'];
|
||||||
|
// quota is disabled
|
||||||
|
$this->assertEquals(0, $result['quota']);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAdminEmailAccountsUndefinedGet()
|
||||||
|
{
|
||||||
|
global $admin_userdata;
|
||||||
|
$this->expectExceptionCode(303);
|
||||||
|
EmailAccounts::getLocal($admin_userdata)->get();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAdminEmailAccountsUndefinedListing()
|
||||||
|
{
|
||||||
|
global $admin_userdata;
|
||||||
|
$this->expectExceptionCode(303);
|
||||||
|
EmailAccounts::getLocal($admin_userdata)->listing();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCustomerEmailAccountsDelete()
|
||||||
|
{
|
||||||
|
global $admin_userdata;
|
||||||
|
|
||||||
|
// get customer
|
||||||
|
$json_result = Customers::getLocal($admin_userdata, array(
|
||||||
|
'loginname' => 'test1'
|
||||||
|
))->get();
|
||||||
|
$customer_userdata = json_decode($json_result, true)['data'];
|
||||||
|
|
||||||
|
$data = [
|
||||||
|
'emailaddr' => 'info@test2.local',
|
||||||
|
'delete_userfiles' => 1
|
||||||
|
];
|
||||||
|
$json_result = EmailAccounts::getLocal($customer_userdata, $data)->delete();
|
||||||
|
$result = json_decode($json_result, true)['data'];
|
||||||
|
$this->assertEquals(0, $result['popaccountid']);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCustomerEmailsDelete()
|
||||||
|
{
|
||||||
|
global $admin_userdata;
|
||||||
|
|
||||||
|
// remove possible existing delete tasks
|
||||||
|
Database::query("TRUNCATE `".TABLE_PANEL_TASKS."`");
|
||||||
|
|
||||||
|
Settings::Set('panel.sendalternativemail', 0, true);
|
||||||
|
// get customer
|
||||||
|
$json_result = Customers::getLocal($admin_userdata, array(
|
||||||
|
'loginname' => 'test1'
|
||||||
|
))->get();
|
||||||
|
$customer_userdata = json_decode($json_result, true)['data'];
|
||||||
|
|
||||||
|
// add account
|
||||||
|
$data = [
|
||||||
|
'emailaddr' => 'info@test2.local',
|
||||||
|
'email_password' => generatePassword(),
|
||||||
|
'alternative_email' => 'noone@example.com'
|
||||||
|
];
|
||||||
|
$json_result = EmailAccounts::getLocal($customer_userdata, $data)->add();
|
||||||
|
$result = json_decode($json_result, true)['data'];
|
||||||
|
$this->assertEquals(2, $result['popaccountid']);
|
||||||
|
|
||||||
|
// now delete the whole address
|
||||||
|
$data = [
|
||||||
|
'emailaddr' => 'info@test2.local',
|
||||||
|
'delete_userfiles' => 1
|
||||||
|
];
|
||||||
|
$json_result = Emails::getLocal($customer_userdata, $data)->delete();
|
||||||
|
$result = json_decode($json_result, true)['data'];
|
||||||
|
$this->assertEquals("info@test2.local", $result['email_full']);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user