You are here

class UserImportProfile in User Import 5

Same name and namespace in other branches
  1. 8 tests/user_import_profile.test \UserImportProfile

Test import of user data into Profile module

Hierarchy

Expanded class hierarchy of UserImportProfile

File

tests/user_import_profile.test, line 6

View source
class UserImportProfile extends UserImportTest {
  function get_info() {
    return array(
      'name' => t('Import Users (Profile)'),
      'desc' => t('Test import of user data into Profile module.'),
      'group' => t('User Import'),
    );
  }

  /**
   *  User with right permissions creates import (with new settings)
   *  - test import of user data into Profile module
   */
  function testCreateImport() {
    $this
      ->drupalModuleEnable('profile');
    $this
      ->drupalLoginUser($this->admin_user);
    $this
      ->profileFieldsCreate();

    // Prepare a user to do testing
    $this
      ->get('logout');

    // log out first
    $this
      ->drupalLoginUser($this->user_importer);

    // Select CSV file (the included example file)
    $this
      ->settingsFileSelect();

    // import settings
    $this
      ->importID($this
      ->getUrl());

    // store import ID for later
    $settings = array();
    $this
      ->settingsEmailMatch($settings);
    $this
      ->settingsProfileMatch($settings);
    $this
      ->settingsIgnoreFirstLine($settings);
    $this
      ->drupalPostRequest($this
      ->getUrl(), $settings, 'Import');

    // check if users have been imported
    $this
      ->checkProfileExist();
  }

  /**
   *  create profile fields
   */
  function profileFieldsCreate() {

    // Textfield
    $edit = array(
      'category' => 'Name',
      'title' => 'First Name',
      'name' => 'profile_first_name',
    );
    $this
      ->drupalPostRequest('admin/user/profile/add/textfield', $edit, t('Save field'));

    // Textfield
    $edit = array(
      'category' => 'Name',
      'title' => 'Last Name',
      'name' => 'profile_last_name',
    );
    $this
      ->drupalPostRequest('admin/user/profile/add/textfield', $edit, t('Save field'));

    // Textarea
    $edit = array(
      'category' => 'Biography',
      'title' => 'CV',
      'name' => 'profile_cv',
    );
    $this
      ->drupalPostRequest('admin/user/profile/add/textarea', $edit, t('Save field'));

    // Checkbox
    $edit = array(
      'category' => 'Contact Details',
      'title' => 'Can Be Contacted',
      'name' => 'profile_contact_permission',
    );
    $this
      ->drupalPostRequest('admin/user/profile/add/checkbox', $edit, t('Save field'));

    // List
    $edit = array(
      'category' => 'Contact Details',
      'title' => 'Contact Preference',
      'name' => 'profile_contact_preference',
      'options' => 'email,telephone,post',
    );
    $this
      ->drupalPostRequest('admin/user/profile/add/selection', $edit, t('Save field'));

    // Freeform List
    $edit = array(
      'category' => 'Biography',
      'title' => 'Interests',
      'name' => 'profile_interests',
    );
    $this
      ->drupalPostRequest('admin/user/profile/add/list', $edit, t('Save field'));

    // URL
    $edit = array(
      'category' => 'Biography',
      'title' => 'Blog',
      'name' => 'profile_blog',
    );
    $this
      ->drupalPostRequest('admin/user/profile/add/url', $edit, t('Save field'));

    // Date
    $edit = array(
      'category' => 'Biography',
      'title' => 'Birthday',
      'name' => 'profile_birthday',
    );
    $this
      ->drupalPostRequest('admin/user/profile/add/date', $edit, t('Save field'));
  }

  /**
   *  Match CSV columns to Profile fields
   */
  function settingsProfileMatch(&$edit) {
    $edit['field_match[0][field_match]'] = 'profile-1';

    // First Name
    $edit['field_match[1][field_match]'] = 'profile-2';

    // Last Name
    $edit['field_match[10][field_match]'] = 'profile-3';

    // CV
    $edit['field_match[7][field_match]'] = 'profile-4';

    // Contact Permision
    $edit['field_match[8][field_match]'] = 'profile-5';

    // Contact Preference
    $edit['field_match[9][field_match]'] = 'profile-6';

    // Interests
    $edit['field_match[6][field_match]'] = 'profile-7';

    // Blog
    $edit['field_match[11][field_match]'] = 'profile-8';

    // Birthday
  }

  /**
   *  Check data in CSV file matches data in profiles
   */
  function checkProfileExist() {
    $file_path = drupal_get_path('module', 'user_import') . '/sample.txt';
    $handle = @fopen($file_path, "r");
    $row = 0;
    while ($csv = fgetcsv($handle, 1000, ',')) {
      if ($row > 0) {
        $user = user_load(array(
          'mail' => $csv[5],
        ));

        // test each data cell against Profile field content
        $this
          ->assertEqual($user->profile_first_name, $csv[0], "[Compare CSV data to Profile data] Row: {$row} Field: First Name");
        $this
          ->assertEqual($user->profile_last_name, $csv[1], "[Compare CSV data to Profile data] Row: {$row} Field: Last Name");
        $this
          ->assertEqual($user->profile_blog, $csv[6], "[Compare CSV data to Profile data] Row: {$row} Field: Blog");
        $this
          ->assertEqual($user->profile_contact_permission, $csv[7], "[Compare CSV data to Profile data] Row: {$row} Field: Contact Permission");
        $this
          ->assertEqual($user->profile_contact_preference, $csv[8], "[Compare CSV data to Profile data] Row: {$row} Field: Contact Preference");
        $this
          ->assertEqual($user->profile_interests, $csv[9], "[Compare CSV data to Profile data] Row: {$row} Field: Profile Interests");
        $this
          ->assertEqual($user->profile_cv, $csv[10], "[Compare CSV data to Profile data] Row: {$row} Field: CV");
        $this
          ->assertEqual($user->profile_birthday, $csv[11], "[Compare CSV data to Profile data] Row: {$row} Field: Birthday");

        //test interests link on profile page
        if (!empty($user->profile_interests)) {
          $interests = explode(',', $user->profile_interests);
          $this
            ->drupalGet('profile/profile_interests/' . $interests[0]);
          $this
            ->assertWantedRaw('<a title="View user profile." href="/' . url('user/' . $user->uid) . '">' . $user->name . '</a>', '[Freeform List] User is listed on page about item in list');
        }
      }
      $row++;
    }
  }

}

Members

Namesort descending Modifiers Type Description Overrides
DrupalTestCase::$_cleanupModules property
DrupalTestCase::$_cleanupRoles property
DrupalTestCase::$_cleanupUsers property
DrupalTestCase::$_cleanupVariables property
DrupalTestCase::$_content property
DrupalTestCase::assertCopy function Will trigger a pass if both parameters refer to different objects. Fail otherwise.
DrupalTestCase::assertEqual function Will trigger a pass if the two parameters have the same value only. Otherwise a fail.
DrupalTestCase::assertError function Confirms that an error has occurred and optionally that the error text matches exactly.
DrupalTestCase::assertErrorPattern function Confirms that an error has occurred and that the error text matches a Perl regular expression.
DrupalTestCase::assertIdentical function Will trigger a pass if the two parameters have the same value and same type. Otherwise a fail.
DrupalTestCase::assertIsA function Type and class test. Will pass if class matches the type name or is a subclass or if not an object, but the type is correct.
DrupalTestCase::assertNoErrors function Confirms that no errors have occurred so far in the test method.
DrupalTestCase::assertNotA function Type and class mismatch test. Will pass if class name or underling type does not match the one specified.
DrupalTestCase::assertNotEqual function Will trigger a pass if the two parameters have a different value. Otherwise a fail.
DrupalTestCase::assertNotIdentical function Will trigger a pass if the two parameters have the different value or different type.
DrupalTestCase::assertNotNull function Will be true if the value is set.
DrupalTestCase::assertNoUnwantedPattern function Will trigger a pass if the Perl regex pattern is not present in subject. Fail if found.
DrupalTestCase::assertNoUnwantedRaw function Will trigger a pass if the raw text is NOT found on the loaded page Fail otherwise.
DrupalTestCase::assertNull function Will be true if the value is null.
DrupalTestCase::assertReference function Will trigger a pass if both parameters refer to the same object. Fail otherwise.
DrupalTestCase::assertWantedPattern function Will trigger a pass if the Perl regex pattern is found in the subject. Fail otherwise.
DrupalTestCase::assertWantedRaw function Will trigger a pass if the raw text is found on the loaded page Fail otherwise.
DrupalTestCase::clickLink function Follows a link by name. Will click the first link found with this link text by default, or a later one if an index is given. Match is case insensitive with normalised space. Does make assertations if the click was sucessful or not and it does…
DrupalTestCase::drupalCheckAuth function @abstract Checks to see if we need to send a http-auth header to authenticate when browsing a site.
DrupalTestCase::drupalCreateRolePerm function Create a role / perm combination specified by permissions
DrupalTestCase::drupalCreateUserRolePerm function Creates a user / role / permissions combination specified by permissions
DrupalTestCase::drupalGet function @abstract Brokder for the get function adds the authentication headers if necessary @author Earnest Berry III <earnest.berry@gmail.com>
DrupalTestCase::drupalGetContent function @TODO: needs documentation
DrupalTestCase::drupalLoginUser function Logs in a user with the internal browser
DrupalTestCase::drupalModuleDisable function Disables a drupal module
DrupalTestCase::drupalModuleEnable function Enables a drupal module
DrupalTestCase::drupalPostRequest function Do a post request on a drupal page. It will be done as usual post request with SimpleBrowser
DrupalTestCase::drupalRawPost function @abstract Broker for the post function adds the authentication headers if necessary @author Earnest Berry III <earnest.berry@gmail.com>
DrupalTestCase::DrupalTestCase function
DrupalTestCase::drupalVariableSet function Set a druapl variable and keep track of the changes for tearDown()
DrupalTestCase::randomName function Generates a random string, to be used as name or whatever
DrupalTestCase::run function Just some info for the reporter
UserImportProfile::checkProfileExist function * Check data in CSV file matches data in profiles
UserImportProfile::get_info function
UserImportProfile::profileFieldsCreate function * create profile fields
UserImportProfile::settingsProfileMatch function * Match CSV columns to Profile fields
UserImportProfile::testCreateImport function * User with right permissions creates import (with new settings) * - test import of user data into Profile module
UserImportTest::$user_importer property
UserImportTest::$user_limited_importer property
UserImportTest::checkAccountsExist function
UserImportTest::enableModules function * enable necessary modules
UserImportTest::importID function * Store import ID * - set on import settings page, retrieve on later tasks
UserImportTest::settingsEmailMatch function
UserImportTest::settingsFileSelect function * Select CSV file (the included example file)
UserImportTest::settingsIgnoreFirstLine function
UserImportTest::setUp function
UserImportTest::tearDown function SimpleTest core method: code run after each and every test method. Overrides DrupalTestCase::tearDown 1
UserImportTest::usersList function * List of users (email addresses) being imported * To Do - Generate this dynamically, bearing in mind it could be used for stress testing