diff options
Diffstat (limited to 'modules/simpletest')
-rw-r--r-- | modules/simpletest/tests/form.test | 33 | ||||
-rw-r--r-- | modules/simpletest/tests/form_test.module | 13 |
2 files changed, 38 insertions, 8 deletions
diff --git a/modules/simpletest/tests/form.test b/modules/simpletest/tests/form.test index 8821ec97c..29fb5eb53 100644 --- a/modules/simpletest/tests/form.test +++ b/modules/simpletest/tests/form.test @@ -185,26 +185,43 @@ class FormsTestCase extends DrupalWebTestCase { // element. drupalPost() emulates a browser by not submitting input for // disabled elements, so we need to un-disable those elements first. $this->drupalGet('form-test/disabled-elements'); + $disabled_elements = array(); foreach ($this->xpath('//*[@disabled]') as $element) { + $disabled_elements[] = (string) $element['name']; unset($element['disabled']); } + + // All the elements should be marked as disabled, including the ones below + // the disabled container. + $this->assertEqual(count($disabled_elements), 20, t('The correct elements have the disabled property in the HTML code.')); + $this->drupalPost(NULL, $edit, t('Submit')); $returned_values['hijacked'] = drupal_json_decode($this->content); // Ensure that the returned values match the form's default values in both // cases. foreach ($returned_values as $type => $values) { - foreach (element_children($form) as $key) { - if (isset($form[$key]['#default_value'])) { - $expected_value = $form[$key]['#default_value']; + $this->assertFormValuesDefault($values, $form); + } + } - if ($key == 'checkboxes_multiple') { - // Checkboxes values are not filtered out. - $values[$key] = array_filter($values[$key]); - } - $this->assertIdentical($expected_value, $values[$key], t('Default value for %type: expected %expected, returned %returned.', array('%type' => $key, '%expected' => var_export($expected_value, TRUE), '%returned' => var_export($values[$key], TRUE)))); + /** + * Assert that the values submitted to a form matches the default values of the elements. + */ + function assertFormValuesDefault($values, $form) { + foreach (element_children($form) as $key) { + if (isset($form[$key]['#default_value'])) { + $expected_value = $form[$key]['#default_value']; + + if ($key == 'checkboxes_multiple') { + // Checkboxes values are not filtered out. + $values[$key] = array_filter($values[$key]); } + $this->assertIdentical($expected_value, $values[$key], t('Default value for %type: expected %expected, returned %returned.', array('%type' => $key, '%expected' => var_export($expected_value, TRUE), '%returned' => var_export($values[$key], TRUE)))); } + + // Recurse children. + $this->assertFormValuesDefault($values, $form[$key]); } } diff --git a/modules/simpletest/tests/form_test.module b/modules/simpletest/tests/form_test.module index 09cea654f..cbc4c0ead 100644 --- a/modules/simpletest/tests/form_test.module +++ b/modules/simpletest/tests/form_test.module @@ -852,6 +852,19 @@ function _form_test_disabled_elements($form, &$form_state) { ), ); + // The #disabled state should propagate to children. + $form['disabled_container'] = array( + '#disabled' => TRUE, + ); + foreach (array('textfield', 'textarea', 'hidden') as $type) { + $form['disabled_container']['disabled_container_' . $type] = array( + '#type' => $type, + '#title' => $type, + '#default_value' => $type, + '#test_hijack_value' => 'HIJACK', + ); + } + $form['submit'] = array( '#type' => 'submit', '#value' => t('Submit'), |