admin_user = $this->drupalCreateUser(array('administer users', 'access user profiles')); // This is the user whose profile will be edited. $this->normal_user = $this->drupalCreateUser(); } /** * Create a profile field. * * @param $type * The field type to be created. * @param $category * The category in which the field should be created. * @param $edit * Additional parameters to be submitted. * @return * The fid of the field that was just created. */ function createProfileField($type = 'textfield', $category = 'simpletest', $edit = array()) { $edit['title'] = $title = $this->randomName(4, $type . '_'); $edit['name'] = $form_name = 'profile_' . $title; $edit['category'] = $category; $edit['explanation'] = $this->randomName(50); $this->drupalPost('admin/user/profile/add/' . $type, $edit, t('Save field')); $fid = db_result(db_query("SELECT fid FROM {profile_fields} WHERE title = '%s'", $title)); $this->assertTrue($fid, t('New Profile field has been entered in the database')); // Check that the new field is appearing on the user edit form. $this->drupalGet('user/' . $this->admin_user->uid . '/edit/' . $category); // Checking field. if ($type == 'date') { $this->assertField($form_name . '[month]', t('Found month selection field')); $this->assertField($form_name . '[day]', t('Found day selection field')); $this->assertField($form_name . '[year]', t('Found day selection field')); } else { $this->assertField($form_name , t('Found form named @name', array('@name' => $form_name))); } // Checking name. $this->assertText($title, t('Checking title for field %title', array('%title' => $title))); // Checking explanation. $this->assertText($edit['explanation'], t('Checking explanation for field %title', array('%title' => $title))); return array( 'fid' => $fid, 'type' => $type, 'form_name' => $form_name, 'title' => $title, 'category' => $category, ); } /** * Set the profile field to a random value * * @param $field * The field that should be set. * @param $value * The value for the field, defaults to a random string. * @return * The value that has been assigned to */ function setProfileField($field, $value = NULL) { if (!isset($value)) { $value = $this->randomName(); } $edit = array( $field['form_name'] => $value, ); $this->drupalPost('user/' . $this->normal_user->uid . '/edit/' . $field['category'], $edit, t('Save')); // Check profile page. $content = $this->drupalGet('user/' . $this->normal_user->uid); $this->assertText($field['title'], t('Found profile field with title %title', array('%title' => $field['title']))); if ($field['type'] != 'checkbox') { // $value must be cast to a string in order to be found by assertText. $this->assertText("$value", t('Found profile field with value %value', array('%value' => $value))); } return $value; } /** * Delete a profile field. * * @param $field * The field to be deleted. */ function deleteProfileField($field) { $this->drupalPost('admin/user/profile/delete/' . $field['fid'], array(), t('Delete')); $this->drupalGet('admin/user/profile'); $this->assertNoText($field['title'], t('Checking deleted field %title', array('%title' => $field['title']))); } } class ProfileTestFields extends ProfileTestCase { /** * Implementation of getInfo(). */ function getInfo() { return array( 'name' => 'Test single fields', 'description' => t('Testing profile module with add/edit/delete textfield, textarea, list, checkbox, and url fields into profile page') , 'group' => t('Profile')); } /** * Test each of the field types. List selection and date fields are tested * separately because they need some special handling. */ function testProfileFields() { $this->drupalLogin($this->admin_user); // Set test values for every field type. $field_types = array( 'textfield' => $this->randomName(), 'textarea' => $this->randomName(), 'list' => $this->randomName(), 'checkbox' => 1, 'url' => 'http://www.' . $this->randomName(10). '.org', ); // For each field type, create a field, give it a value and delete the field. foreach ($field_types as $type => $value) { $field = $this->createProfileField($type); $this->setProfileField($field, $value); $this->deleteProfileField($field); } } } class ProfileTestSelect extends ProfileTestCase { /** * Implementation of getInfo(). */ function getInfo() { return array( 'name' => 'Test select field', 'description' => t('Testing profile module with add/edit/delete a select field') , 'group' => t('Profile')); } /** * Create a list selection field, give it a value, and delete the field. */ function testProfileSelectionField() { $this->drupalLogin($this->admin_user); $edit = array( 'options' => implode("\n", range(1, 10)), ); $field = $this->createProfileField('selection', 'simpletest', $edit); $this->setProfileField($field, rand(1, 10)); $this->deleteProfileField($field); } } class ProfileTestDate extends ProfileTestCase { /** * Implementation of getInfo(). */ function getInfo() { return array( 'name' => 'Test date field', 'description' => t('Testing profile module with add/edit/delete a date field') , 'group' => t('Profile')); } /** * Create a date field, give it a value, and delete the field. */ function testProfileDateField() { $this->drupalLogin($this->admin_user); variable_set('date_format_short', 'm/d/Y - H:i'); $field = $this->createProfileField('date'); // Set date to January 09, 1983 $edit = array( $field['form_name'] . '[month]' => 1, $field['form_name'] . '[day]' => 9, $field['form_name'] . '[year]' => 1983, ); $this->drupalPost('user/' . $this->normal_user->uid . '/edit/' . $field['category'], $edit, t('Save')); // Check profile page. $this->drupalGet('user/' . $this->normal_user->uid); $this->assertText($field['title'], t('Found profile field with title %title', array('%title' => $field['title']))); $this->assertText('01/09/1983', t('Found date profile field.')); $this->deleteProfileField($field); } } class ProfileTestWeights extends ProfileTestCase { /** * Implementation of getInfo(). */ function getInfo() { return array( 'name' => 'Test field weights', 'description' => t('Testing profile modules weigting of fields') , 'group' => t('Profile')); } function testProfileFieldWeights() { $this->drupalLogin($this->admin_user); $category = $this->randomName(); $field1 = $this->createProfileField('textfield', $category, array('weight' => 1)); $field2 = $this->createProfileField('textfield', $category, array('weight' => -1)); $this->setProfileField($field1, $this->randomName(4, 'first_')); $this->setProfileField($field2, $this->randomName(4, 'second_')); $profile_edit = $this->drupalGet('user/' . $this->normal_user->uid . '/edit/' . $category); $this->assertTrue(strpos($profile_edit, $field1['title']) > strpos($profile_edit, $field2['title']), t('Profile field weights are respected on the user edit form.')); $profile_page = $this->drupalGet('user/' . $this->normal_user->uid); $this->assertTrue(strpos($profile_page, $field1['title']) > strpos($profile_page, $field2['title']), t('Profile field weights are respected on the user profile page.')); } } /** * Test profile field autocompletion and access. */ class ProfileTestAutocomplete extends ProfileTestCase { /** * Implementation of getInfo(). */ function getInfo() { return array( 'name' => t('Autocompletion'), 'description' => t('Test profile fields with autocompletion.'), 'group' => t('Profile') ); } /** * Tests profile field autocompletion and access. */ function testAutocomplete() { $this->drupalLogin($this->admin_user); // Create a new profile field with autocompletion enabled. $category = $this->randomName(); $field = $this->createProfileField('textfield', $category, array('weight' => 1, 'autocomplete' => 1)); // Enter profile field value. $field['value'] = $this->randomName(); $this->setProfileField($field, $field['value']); // Set some html for what we want to see in the page output later. $autocomplete_html = ''; $field_html = ''; // Check that autocompletion html is found on the user's profile edit page. $this->drupalGet('user/' . $this->admin_user->uid . '/edit/' . $category); $this->assertRaw($autocomplete_html, t('Autocomplete found.')); $this->assertRaw('misc/autocomplete.js', t('Autocomplete JavaScript found.')); $this->assertRaw('class="form-text form-autocomplete"', t('Autocomplete form element class found.')); // Check the autocompletion path using the first letter of our user's profile // field value to make sure access is allowed and a valid result if found. $this->drupalGet('profile/autocomplete/' . $field['fid'] . '/' . $field['value'][0]); $this->assertResponse(200, t('Autocomplete path allowed to user with permission.')); $this->assertRaw($field['value'], t('Autocomplete value found.')); // Logout and login with a user without the 'access user profiles' permission. $this->drupalLogout(); $this->drupalLogin($this->normal_user); // Check that autocompletion html is not found on the user's profile edit page. $this->drupalGet('user/' . $this->normal_user->uid . '/edit/' . $category); $this->assertNoRaw($autocomplete_html, t('Autocomplete not found.')); // User should be denied access to the profile autocomplete path. $this->drupalGet('profile/autocomplete/' . $field['fid'] . '/' . $field['value'][0]); $this->assertResponse(403, t('Autocomplete path denied to user without permission.')); } } /** * TODO: * - Test field visibility * - Test profile browsing * - Test required fields * - Test fields on registration form * - Test updating fields */