summaryrefslogtreecommitdiff
path: root/modules/comment
diff options
context:
space:
mode:
authorDries Buytaert <dries@buytaert.net>2009-10-16 13:20:16 +0000
committerDries Buytaert <dries@buytaert.net>2009-10-16 13:20:16 +0000
commit5a89fef970b26af6eb1d970ad8a9a5876e4126df (patch)
tree428fb3cdfba1db14551b2a84a1992adeb8e8d359 /modules/comment
parentf0a8150b1160e47d7d2865836240f973292ac68d (diff)
downloadbrdo-5a89fef970b26af6eb1d970ad8a9a5876e4126df.tar.gz
brdo-5a89fef970b26af6eb1d970ad8a9a5876e4126df.tar.bz2
- Patch #275368 by michaelfavia, sun, mattconnolly: allow disabling comment preview + unify with node preview settings.
Diffstat (limited to 'modules/comment')
-rw-r--r--modules/comment/comment.install20
-rw-r--r--modules/comment/comment.module35
-rw-r--r--modules/comment/comment.test118
3 files changed, 117 insertions, 56 deletions
diff --git a/modules/comment/comment.install b/modules/comment/comment.install
index 272c50944..640b54f7f 100644
--- a/modules/comment/comment.install
+++ b/modules/comment/comment.install
@@ -175,6 +175,26 @@ function comment_update_7008() {
}
/**
+ * Update preview setting variable to use new constants
+ */
+function comment_update_7009() {
+ foreach (node_type_get_types() as $type => $object) {
+ // There were only two comment modes in the past:
+ // - 1 was 'required' previously, convert into DRUPAL_REQUIRED (2).
+ // - 0 was 'optional' previously, convert into DRUPAL_OPTIONAL (1).
+ $original_preview = variable_get('comment_preview_' . $type, 1);
+ if ($original_preview) {
+ $preview = DRUPAL_REQUIRED;
+ }
+ else {
+ $preview = DRUPAL_OPTIONAL;
+ }
+ variable_set('comment_preview_' . $type, $preview);
+ }
+ return array();
+}
+
+/**
* @} End of "defgroup updates-6.x-to-7.x"
* The next series of updates should start at 8000.
*/
diff --git a/modules/comment/comment.module b/modules/comment/comment.module
index 266b35499..8dca3845e 100644
--- a/modules/comment/comment.module
+++ b/modules/comment/comment.module
@@ -71,16 +71,6 @@ define('COMMENT_NODE_CLOSED', 1);
define('COMMENT_NODE_OPEN', 2);
/**
- * Comment preview is optional.
- */
-define('COMMENT_PREVIEW_OPTIONAL', 0);
-
-/**
- * Comment preview is required.
- */
-define('COMMENT_PREVIEW_REQUIRED', 1);
-
-/**
* Implement hook_help().
*/
function comment_help($path, $arg) {
@@ -1010,9 +1000,14 @@ function comment_form_node_type_form_alter(&$form, $form_state) {
'#default_value' => variable_get('comment_form_location_' . $form['#node_type']->type, COMMENT_FORM_BELOW),
);
$form['comment']['comment_preview'] = array(
- '#type' => 'checkbox',
- '#title' => t('Require preview'),
- '#default_value' => variable_get('comment_preview_' . $form['#node_type']->type, COMMENT_PREVIEW_OPTIONAL),
+ '#type' => 'radios',
+ '#title' => t('Preview comment'),
+ '#default_value' => variable_get('comment_preview_' . $form['#node_type']->type, DRUPAL_OPTIONAL),
+ '#options' => array(
+ DRUPAL_DISABLED => t('Disabled'),
+ DRUPAL_OPTIONAL => t('Optional'),
+ DRUPAL_REQUIRED => t('Required'),
+ ),
);
}
}
@@ -1874,16 +1869,16 @@ function comment_form($form, &$form_state, $comment) {
// already previewing the submission. However, if there are form errors,
// we hide the save button no matter what, so that optional form elements
// (e.g., captchas) can be updated.
- if (!form_get_errors() && ((variable_get('comment_preview_' . $node->type, COMMENT_PREVIEW_OPTIONAL) == COMMENT_PREVIEW_OPTIONAL) || ($op == t('Preview')) || ($op == t('Save')))) {
- $form['submit'] = array(
- '#type' => 'submit',
- '#value' => t('Save'),
- '#weight' => 19,
- );
- }
+ $form['submit'] = array(
+ '#type' => 'submit',
+ '#value' => t('Save'),
+ '#access' => variable_get('comment_preview_' . $node->type, DRUPAL_OPTIONAL) != DRUPAL_REQUIRED || (!form_get_errors() && isset($form_state['comment_preview'])),
+ '#weight' => 19,
+ );
$form['preview'] = array(
'#type' => 'submit',
'#value' => t('Preview'),
+ '#access' => (variable_get('comment_preview_' . $node->type, DRUPAL_OPTIONAL) != DRUPAL_DISABLED),
'#weight' => 20,
'#submit' => array('comment_form_build_preview'),
);
diff --git a/modules/comment/comment.test b/modules/comment/comment.test
index 79e54c516..265bf0705 100644
--- a/modules/comment/comment.test
+++ b/modules/comment/comment.test
@@ -18,29 +18,51 @@ class CommentHelperCase extends DrupalWebTestCase {
* Post comment.
*
* @param object $node Node to post comment on.
- * @param string $subject Comment subject.
* @param string $comment Comment body.
- * @param boolean $preview Should preview be required.
+ * @param string $subject Comment subject.
* @param mixed $contact Set to NULL for no contact info, TRUE to ignore success checking, and array of values to set contact info.
*/
- function postComment($node, $subject, $comment, $preview = FALSE, $contact = NULL) {
+ function postComment($node, $comment, $subject = '', $contact = NULL) {
$edit = array();
- $edit['subject'] = $subject;
$edit['comment'] = $comment;
- if ($contact !== NULL && is_array($contact)) {
- $edit += $contact;
- }
+ $preview_mode = variable_get('comment_preview_article', DRUPAL_OPTIONAL);
+ $subject_mode = variable_get('comment_subject_field_article', 1);
+ // Must get the page before we test for fields.
if ($node !== NULL) {
$this->drupalGet('comment/reply/' . $node->nid);
}
- if ($preview) {
- $this->assertNoFieldByName('op', t('Save'), t('Save button not found.')); // Preview required so no save button should be found.
- $this->drupalPost(NULL, $edit, t('Preview'));
+ if ($subject_mode == TRUE) {
+ $edit['subject'] = $subject;
+ }
+ else {
+ $this->assertNoFieldByName('subject', '', t('Subject field not found.'));
+ }
+
+ if ($contact !== NULL && is_array($contact)) {
+ $edit += $contact;
+ }
+ switch ($preview_mode) {
+ case DRUPAL_REQUIRED:
+ // Preview required so no save button should be found.
+ $this->assertNoFieldByName('op', t('Save'), t('Save button not found.'));
+ $this->drupalPost(NULL, $edit, t('Preview'));
+ // Don't break here so that we can test post-preview field presence and
+ // function below.
+ case DRUPAL_OPTIONAL:
+ $this->assertFieldByName('op', t('Preview'), t('Preview button found.'));
+ $this->assertFieldByName('op', t('Save'), t('Save button found.'));
+ $this->drupalPost(NULL, $edit, t('Save'));
+ break;
+
+ case DRUPAL_DISABLED:
+ $this->assertNoFieldByName('op', t('Preview'), t('Preview button not found.'));
+ $this->assertFieldByName('op', t('Save'), t('Save button found.'));
+ $this->drupalPost(NULL, $edit, t('Save'));
+ break;
}
- $this->drupalPost(NULL, $edit, t('Save'));
$match = array();
// Get comment ID
preg_match('/#comment-([0-9]+)/', $this->getURL(), $match);
@@ -106,11 +128,24 @@ class CommentHelperCase extends DrupalWebTestCase {
/**
* Set comment preview setting.
*
- * @param boolean $required
+ * @param int $mode
* Preview value.
*/
- function setCommentPreview($required) {
- $this->setCommentSettings('comment_preview', ($required ? '1' : '0'), 'Comment preview ' . ($required ? 'required' : 'optional') . '.');
+ function setCommentPreview($mode) {
+ switch ($mode) {
+ case DRUPAL_DISABLED:
+ $mode_text = 'disabled';
+ break;
+
+ case DRUPAL_OPTIONAL:
+ $mode_text = 'optional';
+ break;
+
+ case DRUPAL_REQUIRED:
+ $mode_text = 'required';
+ break;
+ }
+ $this->setCommentSettings('comment_preview', $mode, 'Comment preview ' . $mode_text . '.');
}
/**
@@ -221,31 +256,33 @@ class CommentInterfaceTest extends CommentHelperCase {
* Test comment interface.
*/
function testCommentInterface() {
- // Set comments to not have subject.
+ // Set comments to have subject and preview disabled.
$this->drupalLogin($this->admin_user);
- $this->setCommentPreview(TRUE);
+ $this->setCommentPreview(DRUPAL_DISABLED);
$this->setCommentForm(TRUE);
$this->setCommentSubject(FALSE);
$this->setCommentSettings('comment_default_mode', COMMENT_MODE_THREADED, t('Comment paging changed.'));
$this->drupalLogout();
- // Post comment without subject.
+ // Post comment #1 without subject or preview.
$this->drupalLogin($this->web_user);
- $this->drupalGet('comment/reply/' . $this->node->nid);
- $this->assertNoFieldByName('subject', '', t('Subject field not found.'));
+ $comment_text = $this->randomName();
+ $comment = $this->postComment($this->node, $comment_text);
+ $comment_loaded = comment_load($comment->id);
+ $this->assertTrue($this->commentExists($comment), t('Comment found.'));
// Set comments to have subject and preview to required.
$this->drupalLogout();
$this->drupalLogin($this->admin_user);
$this->setCommentSubject(TRUE);
- $this->setCommentPreview(TRUE);
+ $this->setCommentPreview(DRUPAL_REQUIRED);
$this->drupalLogout();
- // Create comment that requires preview.
+ // Create comment #2 that allows subject and requires preview.
$this->drupalLogin($this->web_user);
$subject_text = $this->randomName();
$comment_text = $this->randomName();
- $comment = $this->postComment($this->node, $subject_text, $comment_text, TRUE);
+ $comment = $this->postComment($this->node, $comment_text, $subject_text, TRUE);
$comment_loaded = comment_load($comment->id);
$this->assertTrue($this->commentExists($comment), t('Comment found.'));
@@ -254,17 +291,26 @@ class CommentInterfaceTest extends CommentHelperCase {
$this->assertText($subject_text, t('Individual comment subject found.'));
$this->assertText($comment_text, t('Individual comment body found.'));
- // Reply to comment without a subject.
+ // Set comments to have subject and preview to optional.
+ $this->drupalLogout();
+ $this->drupalLogin($this->admin_user);
+ $this->setCommentSubject(TRUE);
+ $this->setCommentPreview(DRUPAL_OPTIONAL);
+ $this->drupalLogout();
+
+ // Reply to comment #2 creating comment #3 with optional preview and no
+ // subject though field enabled.
+ $this->drupalLogin($this->web_user);
$this->drupalGet('comment/reply/' . $this->node->nid . '/' . $comment->id);
$this->assertText($subject_text, t('Individual comment-reply subject found.'));
$this->assertText($comment_text, t('Individual comment-reply body found.'));
- $reply = $this->postComment(NULL, '', $this->randomName(), TRUE);
+ $reply = $this->postComment(NULL, $this->randomName(), '', TRUE);
$reply_loaded = comment_load($reply->id);
$this->assertTrue($this->commentExists($reply, TRUE), t('Reply found.'));
$this->assertEqual($comment->id, $reply_loaded->pid, t('Pid of a reply to a comment is set correctly.'));
$this->assertEqual(rtrim($comment_loaded->thread, '/') . '.00/', $reply_loaded->thread, t('Thread of reply grows correctly.'));
- // Second reply to comment
+ // Second reply to comment #3 creating comment #4.
$this->drupalGet('comment/reply/' . $this->node->nid . '/' . $comment->id);
$this->assertText($subject_text, t('Individual comment-reply subject found.'));
$this->assertText($comment_text, t('Individual comment-reply body found.'));
@@ -280,7 +326,7 @@ class CommentInterfaceTest extends CommentHelperCase {
// Correct link count
$this->drupalGet('node');
- $this->assertRaw('3 comments', t('Link to the 3 comments exist.'));
+ $this->assertRaw('4 comments', t('Link to the 4 comments exist.'));
// Confirm a new comment is posted to the correct page.
$this->setCommentsPerPage(2);
@@ -469,12 +515,12 @@ class CommentAnonymous extends CommentHelperCase {
$this->drupalGet('comment/reply/' . $this->node->nid);
$this->assertTrue($this->commentContactInfoAvailable(), t('Contact information available.'));
- $anonymous_comment3 = $this->postComment($this->node, $this->randomName(), $this->randomName(), FALSE, TRUE);
+ $anonymous_comment3 = $this->postComment($this->node, $this->randomName(), $this->randomName(), TRUE);
$this->assertText(t('E-mail field is required.'), t('E-mail required.')); // Name should have 'Anonymous' for value by default.
$this->assertFalse($this->commentExists($anonymous_comment3), t('Anonymous comment with contact info (required) not found.'));
// Post comment with contact info (required).
- $anonymous_comment3 = $this->postComment($this->node, $this->randomName(), $this->randomName(), FALSE, array('mail' => 'tester@simpletest.org'));
+ $anonymous_comment3 = $this->postComment($this->node, $this->randomName(), $this->randomName(), array('mail' => 'tester@simpletest.org'));
$this->assertTrue($this->commentExists($anonymous_comment3), t('Anonymous comment with contact info (required) found.'));
// Unpublish comment.
@@ -556,9 +602,9 @@ class CommentPagerTest extends CommentHelperCase {
// Create a node and three comments.
$node = $this->drupalCreateNode(array('type' => 'article', 'promote' => 1));
$comments = array();
- $comments[] = $this->postComment($node, $this->randomName(), $this->randomName(), FALSE, TRUE);
- $comments[] = $this->postComment($node, $this->randomName(), $this->randomName(), FALSE, TRUE);
- $comments[] = $this->postComment($node, $this->randomName(), $this->randomName(), FALSE, TRUE);
+ $comments[] = $this->postComment($node, $this->randomName(), $this->randomName(), TRUE);
+ $comments[] = $this->postComment($node, $this->randomName(), $this->randomName(), TRUE);
+ $comments[] = $this->postComment($node, $this->randomName(), $this->randomName(), TRUE);
$this->setCommentSettings('comment_default_mode', COMMENT_MODE_FLAT, t('Comment paging changed.'));
@@ -590,7 +636,7 @@ class CommentPagerTest extends CommentHelperCase {
$replies = array();
$oldest_comment = reset($comments);
$this->drupalGet('comment/reply/' . $node->nid . '/' . $oldest_comment->id);
- $reply = $this->postComment(NULL, $this->randomName(), $this->randomName(), FALSE, TRUE);
+ $reply = $this->postComment(NULL, $this->randomName(), $this->randomName(), TRUE);
$this->setCommentsPerPage(2);
// We are still in flat view - the replies should not be on the first page,
@@ -608,7 +654,7 @@ class CommentPagerTest extends CommentHelperCase {
// If (# replies > # comments per page) in threaded expanded view,
// the overage should be bumped.
- $reply2 = $this->postComment(NULL, $this->randomName(), $this->randomName(), FALSE, TRUE);
+ $reply2 = $this->postComment(NULL, $this->randomName(), $this->randomName(), TRUE);
$this->drupalGet('node/' . $node->nid, array('query' => array('page' => 0)));
$this->assertFalse($this->commentExists($reply2, TRUE), t('In threaded mode where # replies > # comments per page, the newest reply does not appear on page 1.'));
@@ -642,7 +688,7 @@ class CommentApprovalTest extends CommentHelperCase {
// Post anonymous comment without contact info.
$subject = $this->randomName();
$body = $this->randomName();
- $this->postComment($this->node, $subject, $body, FALSE, TRUE); // Set $contact to true so that it won't check for id and message.
+ $this->postComment($this->node, $body, $subject, TRUE); // Set $contact to true so that it won't check for id and message.
$this->assertText(t('Your comment has been queued for review by site administrators and will be published after approval.'), t('Comment requires approval.'));
// Get unapproved comment id.
@@ -679,7 +725,7 @@ class CommentApprovalTest extends CommentHelperCase {
// Post anonymous comment without contact info.
$subject = $this->randomName();
$body = $this->randomName();
- $this->postComment($this->node, $subject, $body, FALSE, TRUE); // Set $contact to true so that it won't check for id and message.
+ $this->postComment($this->node, $body, $subject, TRUE); // Set $contact to true so that it won't check for id and message.
$this->assertText(t('Your comment has been queued for review by site administrators and will be published after approval.'), t('Comment requires approval.'));
// Get unapproved comment id.
@@ -737,7 +783,7 @@ class CommentBlockFunctionalTest extends CommentHelperCase {
// Add some test comments, one without a subject.
$comment1 = $this->postComment($this->node, $this->randomName(), $this->randomName());
$comment2 = $this->postComment($this->node, $this->randomName(), $this->randomName());
- $comment3 = $this->postComment($this->node, '', $this->randomName());
+ $comment3 = $this->postComment($this->node, $this->randomName());
// Test that a user without the 'access comments' permission can not see the block.
$this->drupalLogout();