summaryrefslogtreecommitdiff
path: root/modules/trigger/trigger.test
blob: 5e9d7a28653ef052d71c15a40342aebbc320f717 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
<?php
// $Id$

class TriggerContentTestCase extends DrupalWebTestCase {
  var $_cleanup_roles = array();
  var $_cleanup_users = array();

  public static function getInfo() {
    return array(
      'name' => t('Trigger content (node) actions'),
      'description' => t('Perform various tests with content actions.') ,
      'group' => t('Trigger'),
    );
  }

  function setUp() {
    parent::setUp('trigger');
  }

  /**
   * Various tests, all in one function to assure they happen in the right order.
   */
  function testActionsContent() {
    global $user;
    $content_actions = array('node_publish_action', 'node_unpublish_action', 'node_make_sticky_action', 'node_make_unsticky_action', 'node_promote_action', 'node_unpromote_action');

    foreach ($content_actions as $action) {
      $hash = md5($action);
      $info = $this->actionInfo($action);

      // Test 1: Assign an action to a trigger, then pull the trigger, and make sure the actions fire.
      $test_user = $this->drupalCreateUser(array('administer actions'));
      $this->drupalLogin($test_user);
      $edit = array('aid' => $hash);
      $this->drupalPost('admin/build/trigger/node', $edit, t('Assign'));
      // Create an unpublished node.
      $web_user = $this->drupalCreateUser(array('create page content', 'access content', 'administer nodes'));
      $this->drupalLogin($web_user);
      $edit = array();
      $edit['title'] = '!SimpleTest test node! ' . $this->randomName(10);
      $edit['body[0][value]'] = '!SimpleTest test body! ' . $this->randomName(32) . ' ' . $this->randomName(32);
      $edit[$info['property']] = !$info['expected'];
      $this->drupalPost('node/add/page', $edit, t('Save'));
      // Make sure the text we want appears.
      $this->assertRaw(t('!post %title has been created.', array('!post' => 'Page', '%title' => $edit['title'])), t('Make sure the page has actually been created'));
      // Action should have been fired.
      $loaded_node = $this->drupalGetNodeByTitle($edit['title']);;
      $this->assertTrue($loaded_node->$info['property'] == $info['expected'], t('Make sure the @action action fired.', array('@action' => $info['name'])));
      // Leave action assigned for next test

      // Test 2: There should be an error when the action is assigned to the trigger twice.
      $test_user = $this->drupalCreateUser(array('administer actions'));
      $this->drupalLogin($test_user);
      $edit = array('aid' => $hash);
      $this->drupalPost('admin/build/trigger/node', $edit, t('Assign'));
      $edit = array('aid' => $hash);
      $this->drupalPost('admin/build/trigger/node', $edit, t('Assign'));
      $this->assertRaw(t('The action you chose is already assigned to that trigger.'), t('Check to make sure an error occurs when assigning an action to a trigger twice.'));

      // Test 3: The action should be able to be unassigned from a trigger.
      $this->drupalPost('admin/build/trigger/unassign/node/presave/' . $hash, array(), t('Unassign'));
      $this->assertRaw(t('Action %action has been unassigned.', array('%action' => ucfirst($info['name']))), t('Check to make sure the @action action can be unassigned from the trigger.', array('@action' => $info['name'])));
      $assigned = db_result(db_query("SELECT COUNT(*) FROM {trigger_assignments} WHERE aid IN ('" . implode("','", $content_actions) . "')"));
      $this->assertFalse($assigned, t('Check to make sure unassign worked properly at the database level.'));
    }
  }

  /**
   * Helper function for testActionsContent(): returns some info about each of the content actions.
   *
   * @param $action
   *   The name of the action to return info about.
   * @return
   *   An associative array of info about the action.
   */
  function actionInfo($action) {
    $info = array(
      'node_publish_action' => array(
        'property' => 'status',
        'expected' => 1,
        'name' => t('publish post'),
      ),
      'node_unpublish_action' => array(
        'property' => 'status',
        'expected' => 0,
        'name' => t('unpublish post'),
      ),
      'node_make_sticky_action' => array(
        'property' => 'sticky',
        'expected' => 1,
        'name' => t('make post sticky'),
      ),
      'node_make_unsticky_action' => array(
        'property' => 'sticky',
        'expected' => 0,
        'name' => t('make post unsticky'),
      ),
      'node_promote_action' => array(
        'property' => 'promote',
        'expected' => 1,
        'name' => t('promote post to front page'),
      ),
      'node_unpromote_action' => array(
        'property' => 'promote',
        'expected' => 0,
        'name' => t('remove post from front page'),
      ),
    );
    return $info[$action];
  }
}

/**
 * Test cron trigger.
 */
class TriggerCronTestCase extends DrupalWebTestCase {
  public static function getInfo() {
    return array(
      'name' => t('Trigger cron (system) actions'),
      'description' => t('Perform various tests with cron trigger.') ,
      'group' => t('Trigger'),
    );
  }

  function setUp() {
    parent::setUp('trigger', 'trigger_test');
  }

  /**
   * Test assigning multiple actions to the cron trigger.
   *
   * This test ensures that both simple and multiple complex actions
   * succeed properly. This is done in the cron trigger test because
   * cron allows passing multiple actions in at once.
   */
  function testActionsCron() {
    // Create an administrative user.
    $test_user = $this->drupalCreateUser(array('administer actions'));
    $this->drupalLogin($test_user);
 
    // Assign a non-configurable action to the cron run trigger.
    $edit = array('aid' => md5('trigger_test_system_cron_action'));
    $this->drupalPost('admin/build/trigger/cron', $edit, t('Assign'));
 
    // Assign a configurable action to the cron trigger.
    $hash = md5('trigger_test_system_cron_conf_action');
    $action_description = $this->randomName();
    $edit = array(
      'actions_description' => $action_description,
      'subject' => $action_description,
    );
    $this->drupalPost('admin/settings/actions/configure/' . $hash, $edit, t('Save'));
    $edit = array('aid' => md5('1'));
    $this->drupalPost('admin/build/trigger/cron', $edit, t('Assign'));
 
    // Add a second configurable action to the cron trigger.
    $action_description = $this->randomName();
    $edit = array(
      'actions_description' => $action_description,
      'subject' => $action_description,
    );
    $this->drupalPost('admin/settings/actions/configure/' . $hash, $edit, t('Save'));
    $edit = array('aid' => md5('2'));
    $this->drupalPost('admin/build/trigger/cron', $edit, t('Assign'));
 
    // Force a cron run.
    drupal_cron_run();
 
    // Make sure the non-configurable action has fired.
    $action_run = variable_get('trigger_test_system_cron_action', FALSE);
    $this->assertTrue($action_run, t('Check that the cron run triggered the test action.'));
 
    // Make sure that both configurable actions have fired.
    $action_run = variable_get('trigger_test_system_cron_conf_action', 0) == 2;
    $this->assertTrue($action_run, t('Check that the cron run triggered both complex actions.'));
  }
}