Add support for keystoneclient 0.4.0

Keystoneclient auth_middleware changed the way it parses the datetime
returned from the cache, breaking the Ceilometer unit tests. This patch
fixes the fake cache system that's used in unit test, so it works with
all keystoneclient versions.

This also update the sample configuration files to include the new
options provided by keystoneclient 0.4.0.

Fixes-Bug: #1238529

Change-Id: Iecfd50d9e9801aeb919f2c09a728e4ea15245a5e
This commit is contained in:
Julien Danjou 2013-10-11 10:54:56 +02:00
parent 3a3b8463ef
commit e3cef871ac
2 changed files with 19 additions and 11 deletions

View File

@ -742,6 +742,10 @@
# server. (boolean value) # server. (boolean value)
#http_connect_timeout=<None> #http_connect_timeout=<None>
# How many times are we trying to reconnect when communicating
# with Identity API Server. (integer value)
#http_request_max_retries=3
# Allows to pass in the name of a fake http_handler callback # Allows to pass in the name of a fake http_handler callback
# function used instead of httplib.HTTPConnection or # function used instead of httplib.HTTPConnection or
# httplib.HTTPSConnection. Useful for unit testing where # httplib.HTTPSConnection. Useful for unit testing where
@ -774,6 +778,13 @@
# (string value) # (string value)
#keyfile=<None> #keyfile=<None>
# A PEM encoded Certificate Authority to use when verifying
# HTTPs connections. Defaults to system CAs. (string value)
#cafile=<None>
# Verify HTTPS connections. (boolean value)
#insecure=false
# Directory used to cache files related to PKI tokens (string # Directory used to cache files related to PKI tokens (string
# value) # value)
#signing_dir=<None> #signing_dir=<None>

View File

@ -27,6 +27,7 @@ from ceilometer import sample
from ceilometer.api import acl from ceilometer.api import acl
from ceilometer.publisher import rpc from ceilometer.publisher import rpc
from ceilometer.tests import db as tests_db from ceilometer.tests import db as tests_db
from ceilometer.openstack.common import timeutils
from .base import FunctionalTest from .base import FunctionalTest
@ -37,12 +38,8 @@ VALID_TOKEN2 = '4562138218392832'
class FakeMemcache(object): class FakeMemcache(object):
def __init__(self): @staticmethod
self.set_key = None def get(key):
self.set_value = None
self.token_expiration = None
def get(self, key):
if key == "tokens/%s" % VALID_TOKEN: if key == "tokens/%s" % VALID_TOKEN:
dt = datetime.datetime.now() + datetime.timedelta(minutes=5) dt = datetime.datetime.now() + datetime.timedelta(minutes=5)
return json.dumps(({'access': { return json.dumps(({'access': {
@ -55,7 +52,7 @@ class FakeMemcache(object):
'roles': [ 'roles': [
{'name': 'admin'}, {'name': 'admin'},
]}, ]},
}}, dt.strftime("%s"))) }}, timeutils.isotime(dt)))
if key == "tokens/%s" % VALID_TOKEN2: if key == "tokens/%s" % VALID_TOKEN2:
dt = datetime.datetime.now() + datetime.timedelta(minutes=5) dt = datetime.datetime.now() + datetime.timedelta(minutes=5)
return json.dumps(({'access': { return json.dumps(({'access': {
@ -68,11 +65,11 @@ class FakeMemcache(object):
'roles': [ 'roles': [
{'name': 'Member'}, {'name': 'Member'},
]}, ]},
}}, dt.strftime("%s"))) }}, timeutils.isotime(dt)))
def set(self, key, value, **kwargs): @staticmethod
self.set_value = value def set(key, value, **kwargs):
self.set_key = key pass
class TestAPIACL(FunctionalTest, class TestAPIACL(FunctionalTest,