341 lines
14 KiB
Plaintext
341 lines
14 KiB
Plaintext
<?php
|
|
// $Id$
|
|
|
|
/**
|
|
* Test the sitewide contact form.
|
|
*/
|
|
class ContactSitewideTestCase extends DrupalWebTestCase {
|
|
function getInfo() {
|
|
return array(
|
|
'name' => t('Site-wide contact form'),
|
|
'description' => t('Tests site-wide contact form functionality.'),
|
|
'group' => t('Contact'),
|
|
);
|
|
}
|
|
|
|
function setUp() {
|
|
parent::setUp('contact');
|
|
}
|
|
|
|
/**
|
|
* Test configuration options and site-wide contact form.
|
|
*/
|
|
function testSiteWideContact() {
|
|
// Create and login administative user.
|
|
$admin_user = $this->drupalCreateUser(array('administer site-wide contact form', 'administer permissions'));
|
|
$this->drupalLogin($admin_user);
|
|
|
|
// Set settings.
|
|
$edit = array();
|
|
$contact_form_information = $this->randomName(100);
|
|
$edit['contact_form_information'] = $contact_form_information;
|
|
$edit['contact_hourly_threshold'] = 3;
|
|
$edit['contact_default_status'] = TRUE;
|
|
$this->drupalPost('admin/build/contact/settings', $edit, t('Save configuration'));
|
|
$this->assertText(t('The configuration options have been saved.'), t('Setting successfully saved.'));
|
|
|
|
// Delete old categories to ensure that new categories are used.
|
|
$this->deleteCategories();
|
|
|
|
// Ensure that the contact form won't be shown without categories.
|
|
$this->setPermission('anonymous user', array('access site-wide contact form' => TRUE));
|
|
$this->drupalLogout();
|
|
$this->drupalGet('contact');
|
|
$this->assertText(t('The contact form has not been configured.'), t('Contact form will not work without categories configured.'));
|
|
$this->drupalLogin($admin_user);
|
|
|
|
// Add categories.
|
|
// Test invalid recipients.
|
|
$invalid_recipients = array('invalid', 'invalid@', 'invalid@site', 'invalid@site.', '@site.', '@site.com');
|
|
foreach ($invalid_recipients as $invalid_recipient) {
|
|
$this->addCategory($this->randomName(16), $invalid_recipient, '', FALSE);
|
|
$this->assertRaw(t('%recipient is an invalid e-mail address.', array('%recipient' => $invalid_recipient)), t('Caught invalid recipient (' . $invalid_recipient . ').'));
|
|
}
|
|
|
|
// Test validation of empty category and recipients fields.
|
|
$this->addCategory($category = '', '', '', TRUE);
|
|
$this->assertText(t('Category field is required.'), t('Caught empty category field'));
|
|
$this->assertText(t('Recipients field is required.'), t('Caught empty recipients field.'));
|
|
|
|
// Create first valid category.
|
|
$recipients = array('simpletest@example.com', 'simpletest2@example.com', 'simpletest3@example.com');
|
|
$this->addCategory($category = $this->randomName(16), implode(',', array($recipients[0])), '', TRUE);
|
|
$this->assertRaw(t('Category %category has been added.', array('%category' => $category)), t('Category successfully added.'));
|
|
|
|
// Test update contact form category.
|
|
$categories = $this->getCategories();
|
|
$category_id = $this->updateCategory($categories, $category = $this->randomName(16), $recipients_str = implode(',', array($recipients[0], $recipients[1])), $reply = $this->randomName(30), FALSE);
|
|
$category_array = db_fetch_array(db_query('SELECT category, recipients, reply, selected FROM {contact} WHERE cid = %d', array($category_id)));
|
|
$this->assertEqual($category_array['category'], $category);
|
|
$this->assertEqual($category_array['recipients'], $recipients_str);
|
|
$this->assertEqual($category_array['reply'], $reply);
|
|
$this->assertFalse($category_array['selected']);
|
|
$this->assertRaw(t('Category %category has been updated.', array('%category' => $category)), t('Category successfully updated.'));
|
|
|
|
// Ensure that the contact form is shown without a category selection input.
|
|
$this->setPermission('anonymous user', array('access site-wide contact form' => TRUE));
|
|
$this->drupalLogout();
|
|
$this->drupalGet('contact');
|
|
$this->assertText($contact_form_information, t('Contact form is shown when there is one category.'));
|
|
$this->assertNoText(t('Category'), t('When there is only one category, the category selection element is hidden.'));
|
|
$this->drupalLogin($admin_user);
|
|
|
|
// Add more categories.
|
|
$this->addCategory($category = $this->randomName(16), implode(',', array($recipients[0], $recipients[1])), '', FALSE);
|
|
$this->assertRaw(t('Category %category has been added.', array('%category' => $category)), t('Category successfully added.'));
|
|
|
|
$this->addCategory($category = $this->randomName(16), implode(',', array($recipients[0], $recipients[1], $recipients[2])), '', FALSE);
|
|
$this->assertRaw(t('Category %category has been added.', array('%category' => $category)), t('Category successfully added.'));
|
|
|
|
// Clear flood table in preparation for flood test and allow other checks to complete.
|
|
$this->assertTrue(db_query('DELETE FROM {flood}'), t('Flood table emptied.'));
|
|
|
|
// Check to see that anonymous user cannot see contact page without permission.
|
|
$this->setPermission('anonymous user', array('access site-wide contact form' => FALSE));
|
|
$this->drupalLogout();
|
|
|
|
$this->drupalGet('contact');
|
|
$this->assertResponse(403, t('Access denied to anonymous user without permission.'));
|
|
|
|
// Give anonymous user permission and see that page is viewable.
|
|
$this->drupalLogin($admin_user);
|
|
$this->setPermission('anonymous user', array('access site-wide contact form' => TRUE));
|
|
$this->drupalLogout();
|
|
|
|
$this->drupalGet('contact');
|
|
$this->assertResponse(200, t('Access granted to anonymous user with permission.'));
|
|
|
|
// Check that "Additional information" is displayed on the page.
|
|
$this->assertText($edit['contact_form_information'], t('Contact information displayed.'));
|
|
|
|
// Submit contact form with invalid values.
|
|
$this->submitContact('', $recipients[0], $this->randomName(16), $categories[0], $this->randomName(64));
|
|
$this->assertText(t('Your name field is required.'), t('Name required.'));
|
|
|
|
$this->submitContact($this->randomName(16), '', $this->randomName(16), $categories[0], $this->randomName(64));
|
|
$this->assertText(t('Your e-mail address field is required.'), t('E-mail required.'));
|
|
|
|
$this->submitContact($this->randomName(16), $invalid_recipients[0], $this->randomName(16), $categories[0], $this->randomName(64));
|
|
$this->assertText(t('You must enter a valid e-mail address.'), t('Valid e-mail required.'));
|
|
|
|
$this->submitContact($this->randomName(16), $recipients[0], '', $categories[0], $this->randomName(64));
|
|
$this->assertText(t('Subject field is required.'), t('Subject required.'));
|
|
|
|
$this->submitContact($this->randomName(16), $recipients[0], $this->randomName(16), $categories[0], '');
|
|
$this->assertText(t('Message field is required.'), t('Message required.'));
|
|
|
|
// Test contact form with no default category selected.
|
|
db_query('UPDATE {contact} SET selected = 0');
|
|
$this->drupalGet('contact');
|
|
$this->assertRaw(t('- Please choose -'), t('Without selected categories the visitor is asked to chose a category.'));
|
|
|
|
// Submit contact form with invalid category id (cid 0).
|
|
$this->submitContact($this->randomName(16), $recipients[0], $this->randomName(16), 0, '');
|
|
$this->assertText(t('You must select a valid category.'), t('Valid category required.'));
|
|
|
|
// Submit contact form with correct values and check flood interval.
|
|
for ($i = 0; $i < $edit['contact_hourly_threshold']; $i++) {
|
|
$this->submitContact($this->randomName(16), $recipients[0], $this->randomName(16), $categories[0], $this->randomName(64));
|
|
$this->assertText(t('Your message has been sent.'), t('Message sent.'));
|
|
}
|
|
// Submit contact form one over limit.
|
|
$this->drupalGet('contact');
|
|
$this->assertRaw(t('You cannot send more than %number messages per hour. Please try again later.', array('%number' => $edit['contact_hourly_threshold'])), t('Message threshold reached.'));
|
|
|
|
// Delete created categories.
|
|
$this->drupalLogin($admin_user);
|
|
$this->deleteCategories();
|
|
}
|
|
|
|
/**
|
|
* Add a category.
|
|
*
|
|
* @param string $category Name of category.
|
|
* @param string $recipients List of recipient e-mail addresses.
|
|
* @param string $reply Auto-reply text.
|
|
* @param boolean $selected Defautly selected.
|
|
*/
|
|
function addCategory($category, $recipients, $reply, $selected) {
|
|
$edit = array();
|
|
$edit['category'] = $category;
|
|
$edit['recipients'] = $recipients;
|
|
$edit['reply'] = $reply;
|
|
$edit['selected'] = ($selected ? '1' : '0');
|
|
$this->drupalPost('admin/build/contact/add', $edit, t('Save'));
|
|
}
|
|
|
|
/**
|
|
* Update a category.
|
|
*
|
|
* @param string $category Name of category.
|
|
* @param string $recipients List of recipient e-mail addresses.
|
|
* @param string $reply Auto-reply text.
|
|
* @param boolean $selected Defautly selected.
|
|
*/
|
|
function updateCategory($categories, $category, $recipients, $reply, $selected) {
|
|
$category_id = $categories[array_rand($categories)];
|
|
$edit = array();
|
|
$edit['category'] = $category;
|
|
$edit['recipients'] = $recipients;
|
|
$edit['reply'] = $reply;
|
|
$edit['selected'] = ($selected ? '1' : '0');
|
|
$this->drupalPost('admin/build/contact/edit/' . $category_id, $edit, t('Save'));
|
|
return($category_id);
|
|
}
|
|
|
|
/**
|
|
* Submit contact form.
|
|
*
|
|
* @param string $name Name.
|
|
* @param string $mail E-mail address.
|
|
* @param string $subject Subject.
|
|
* @param integer $cid Category id.
|
|
* @param string $message Message.
|
|
*/
|
|
function submitContact($name, $mail, $subject, $cid, $message) {
|
|
$edit = array();
|
|
$edit['name'] = $name;
|
|
$edit['mail'] = $mail;
|
|
$edit['subject'] = $subject;
|
|
$edit['cid'] = $cid;
|
|
$edit['message'] = $message;
|
|
$this->drupalPost('contact', $edit, t('Send e-mail'));
|
|
}
|
|
|
|
/**
|
|
* Delete all categories.
|
|
*/
|
|
function deleteCategories() {
|
|
$categories = $this->getCategories();
|
|
foreach ($categories as $category) {
|
|
$category_name = db_result(db_query('SELECT category FROM {contact} WHERE cid = %d', array($category)));
|
|
$this->drupalPost('admin/build/contact/delete/' . $category, array(), t('Delete'));
|
|
$this->assertRaw(t('Category %category has been deleted.', array('%category' => $category_name)), t('Category deleted sucessfully.'));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get list category ids.
|
|
*
|
|
* @return array Category ids.
|
|
*/
|
|
function getCategories() {
|
|
$result = db_query('SELECT cid FROM {contact}');
|
|
$categories = array();
|
|
while ($category = db_result($result)) {
|
|
$categories[] = $category;
|
|
}
|
|
return $categories;
|
|
}
|
|
|
|
/**
|
|
* Set permission.
|
|
*
|
|
* @param string $role User role to set permissions for.
|
|
* @param array $permissions Key-value array of permissions to set.
|
|
*/
|
|
function setPermission($role, $permissions) {
|
|
// Get role id (rid) for specified role.
|
|
$rid = db_result(db_query("SELECT rid FROM {role} WHERE name = '%s'", array($role)));
|
|
if ($rid === FALSE) {
|
|
$this->fail(t(' [permission] Role "' . $role . '" not found.'));
|
|
}
|
|
|
|
// Create edit array from permission.
|
|
$edit = array();
|
|
foreach ($permissions as $name => $value) {
|
|
$edit[$rid . '[' . $name . ']'] = $value;
|
|
}
|
|
|
|
$this->drupalPost('admin/user/permissions', $edit, t('Save permissions'));
|
|
$this->assertText(t('The changes have been saved.'), t(' [permission] Saved changes.'));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Test the personal contact form.
|
|
*/
|
|
class ContactPersonalTestCase extends DrupalWebTestCase {
|
|
function getInfo() {
|
|
return array(
|
|
'name' => t('Personal contact form'),
|
|
'description' => t('Tests personal contact form functionality.'),
|
|
'group' => t('Contact'),
|
|
);
|
|
}
|
|
|
|
function setUp() {
|
|
parent::setUp('contact');
|
|
}
|
|
|
|
/**
|
|
* Test personal contact form.
|
|
*/
|
|
function testPersonalContact() {
|
|
$admin_user = $this->drupalCreateUser(array('administer site-wide contact form'));
|
|
$this->drupalLogin($admin_user);
|
|
|
|
// Enable the personal contact form.
|
|
$flood_control = 3;
|
|
$edit = array();
|
|
$edit['contact_default_status'] = TRUE;
|
|
$edit['contact_hourly_threshold'] = $flood_control;
|
|
$this->drupalPost('admin/build/contact/settings', $edit, t('Save configuration'));
|
|
$this->assertText(t('The configuration options have been saved.'), t('Setting successfully saved.'));
|
|
|
|
// Reload variables.
|
|
$this->drupalLogout();
|
|
|
|
// Create web users and attempt to use personal contact forms with default set to true.
|
|
$web_user1 = $this->drupalCreateUser(array());
|
|
$web_user2 = $this->drupalCreateUser(array());
|
|
|
|
$this->drupalLogin($web_user1);
|
|
|
|
$this->drupalGet('user/' . $web_user2->uid . '/contact');
|
|
$this->assertResponse(200, t('Access to personal contact form granted.'));
|
|
|
|
$edit = array();
|
|
$edit['subject'] = $this->randomName(16);
|
|
$edit['message'] = $this->randomName(64);
|
|
$this->drupalPost(NULL, $edit, t('Send e-mail'));
|
|
$this->assertText(t('The message has been sent.'), t('Message sent.'));
|
|
|
|
// Clear flood table in preparation for flood test and allow other checks to complete.
|
|
$this->assertTrue(db_query('DELETE FROM {flood}'), t('Flood table emptied.'));
|
|
|
|
// Submit contact form with correct values and check flood interval.
|
|
for ($i = 0; $i < $flood_control; $i++) {
|
|
$this->drupalGet('user/' . $web_user2->uid . '/contact');
|
|
$this->drupalPost(NULL, $edit, t('Send e-mail'));
|
|
$this->assertText(t('The message has been sent.'), t('Message sent.'));
|
|
}
|
|
|
|
// Submit contact form one over limit.
|
|
$this->drupalGet('user/' . $web_user2->uid . '/contact');
|
|
$this->assertRaw(t('You cannot send more than %number messages per hour. Please try again later.', array('%number' => $flood_control)), t('Message threshold reached.'));
|
|
|
|
$this->drupalLogout();
|
|
|
|
$this->drupalLogin($admin_user);
|
|
|
|
// Disable the personal contact form.
|
|
$edit = array();
|
|
$edit['contact_default_status'] = FALSE;
|
|
$this->drupalPost('admin/build/contact/settings', $edit, t('Save configuration'));
|
|
$this->assertText(t('The configuration options have been saved.'), t('Setting successfully saved.'));
|
|
|
|
// Reload variables.
|
|
$this->drupalLogout();
|
|
|
|
// Create web users and attempt to use personal contact forms with default set to false.
|
|
$web_user3 = $this->drupalCreateUser(array());
|
|
$web_user4 = $this->drupalCreateUser(array());
|
|
|
|
$this->drupalLogin($web_user3);
|
|
|
|
$this->drupalGet('user/' . $web_user4->uid . '/contact');
|
|
$this->assertResponse(403, t('Access to personal contact form denied.'));
|
|
}
|
|
}
|