← Back to team overview

yahoo-eng-team team mailing list archive

[Bug 1247142] Re: Live LDAP tests fail when trying to create user with an arbitrary attribute

 

The above fix has not been released yet.

** Changed in: keystone
       Status: Fix Released => Fix Committed

-- 
You received this bug notification because you are a member of Yahoo!
Engineering Team, which is subscribed to Keystone.
https://bugs.launchpad.net/bugs/1247142

Title:
  Live LDAP tests fail when trying to create user with an arbitrary
  attribute

Status in OpenStack Identity (Keystone):
  Fix Committed

Bug description:
  I ran _ldap_livetest and it failed with the following traceback:

  FAIL: keystone.tests.test_ldap_livetest.LiveLDAPIdentity.test_arbitrary_attributes_are_returned_from_create_user
  tags: worker-0
  ----------------------------------------------------------------------
  Traceback (most recent call last):
    File "keystone/tests/test_backend.py", line 2646, in test_arbitrary_attributes_are_returned_from_create_user
      user = self.identity_api.create_user(user_data['id'], user_data)
    File "keystone/notifications.py", line 44, in wrapper
      result = f(*args, **kwargs)
    File "keystone/identity/core.py", line 179, in wrapper
      return f(self, *args, **kwargs)
    File "keystone/identity/core.py", line 324, in create_user
      ref = driver.create_user(user_id, user)
    File "keystone/identity/backends/ldap.py", line 95, in create_user
      user_ref = self.user.create(user)
    File "keystone/identity/backends/ldap.py", line 229, in create
      values = super(UserApi, self).create(values)
    File "keystone/common/ldap/core.py", line 738, in create
      ref = super(EnabledEmuMixIn, self).create(values)
    File "keystone/common/ldap/core.py", line 342, in create
      conn.add_s(self._id_to_dn(values['id']), attrs)
    File "keystone/common/ldap/core.py", line 565, in add_s
      return self.conn.add_s(dn, ldap_attrs)
    File "/usr/lib/python2.7/dist-packages/ldap/ldapobject.py", line 194, in add_s
      return self.result(msgid,all=1,timeout=self.timeout)
    File "/usr/lib/python2.7/dist-packages/ldap/ldapobject.py", line 422, in result
      res_type,res_data,res_msgid = self.result2(msgid,all,timeout)
    File "/usr/lib/python2.7/dist-packages/ldap/ldapobject.py", line 426, in result2
      res_type, res_data, res_msgid, srv_ctrls = self.result3(msgid,all,timeout)
    File "/usr/lib/python2.7/dist-packages/ldap/ldapobject.py", line 432, in result3
      ldap_result = self._ldap_call(self._l.result3,msgid,all,timeout)
    File "/usr/lib/python2.7/dist-packages/ldap/ldapobject.py", line 96, in _ldap_call
      result = func(*args,**kwargs)

  There are four tests in total which work with arbitrary attributes,
  but three of them are skipped in test_backend_ldap:

  def test_arbitrary_attributes_are_returned_from_get_user(self):
      self.skipTest("Using arbitrary attributes doesn't work under LDAP")

  def test_new_arbitrary_attributes_are_returned_from_update_user(self):
      self.skipTest("Using arbitrary attributes doesn't work under LDAP")

  def test_updated_arbitrary_attributes_are_returned_from_update_user(self):
      self.skipTest("Using arbitrary attributes doesn't work under LDAP") 

  So I find it strange that
  test_arbitrary_attributes_are_returned_from_create_user is not skipped
  like these three.

To manage notifications about this bug go to:
https://bugs.launchpad.net/keystone/+bug/1247142/+subscriptions