summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTomas Babej <tbabej@redhat.com>2014-11-20 18:37:57 +0100
committerPetr Vobornik <pvoborni@redhat.com>2014-11-27 17:27:48 +0100
commit7215f7e2215b485daac7dc5d54478752b682181b (patch)
treef02b618463327aeb2df7fc8e142ccbf7288f6120
parent2f8c4e7b165609706a4af9f680579c0e47edaeca (diff)
downloadfreeipa-7215f7e2215b485daac7dc5d54478752b682181b.tar.gz
freeipa-7215f7e2215b485daac7dc5d54478752b682181b.tar.xz
freeipa-7215f7e2215b485daac7dc5d54478752b682181b.zip
Re-initialize NSS database after otptoken plugin tests
OTP token tests do not properly reinitialize the NSS db, thus making subsequent xmlrpc tests fail on SSL cert validation. Make sure NSS db is re-initalized in the teardown method. https://fedorahosted.org/freeipa/ticket/4748 Reviewed-By: Petr Vobornik <pvoborni@redhat.com> Reviewed-By: Petr Viktorin <pviktori@redhat.com>
-rw-r--r--ipalib/x509.py31
-rw-r--r--ipatests/test_ipaserver/test_otptoken_import.py5
2 files changed, 25 insertions, 11 deletions
diff --git a/ipalib/x509.py b/ipalib/x509.py
index 88ea415bf..a87dbf413 100644
--- a/ipalib/x509.py
+++ b/ipalib/x509.py
@@ -89,19 +89,12 @@ def strip_header(pem):
return pem
-def load_certificate(data, datatype=PEM, dbdir=None):
+def initialize_nss_database(dbdir=None):
"""
- Given a base64-encoded certificate, with or without the
- header/footer, return a request object.
-
- Returns a nss.Certificate type
+ Initializes NSS database, if not initialized yet. Uses a proper database
+ directory (.ipa/alias or HTTPD_ALIAS_DIR), depending on the value of
+ api.env.in_tree.
"""
- if type(data) in (tuple, list):
- data = data[0]
-
- if (datatype == PEM):
- data = strip_header(data)
- data = base64.b64decode(data)
if not nss.nss_is_initialized():
if dbdir is None:
@@ -116,6 +109,22 @@ def load_certificate(data, datatype=PEM, dbdir=None):
else:
nss.nss_init(dbdir)
+def load_certificate(data, datatype=PEM, dbdir=None):
+ """
+ Given a base64-encoded certificate, with or without the
+ header/footer, return a request object.
+
+ Returns a nss.Certificate type
+ """
+ if type(data) in (tuple, list):
+ data = data[0]
+
+ if (datatype == PEM):
+ data = strip_header(data)
+ data = base64.b64decode(data)
+
+ initialize_nss_database(dbdir=dbdir)
+
return nss.Certificate(buffer(data))
def load_certificate_from_file(filename, dbdir=None):
diff --git a/ipatests/test_ipaserver/test_otptoken_import.py b/ipatests/test_ipaserver/test_otptoken_import.py
index 7ee0754da..9e463466c 100644
--- a/ipatests/test_ipaserver/test_otptoken_import.py
+++ b/ipatests/test_ipaserver/test_otptoken_import.py
@@ -21,12 +21,17 @@ import os
import sys
import nose
from nss import nss
+from ipalib.x509 import initialize_nss_database
from ipaserver.install.ipa_otptoken_import import PSKCDocument, ValidationError
basename = os.path.join(os.path.dirname(__file__), "data")
class test_otptoken_import(object):
+
+ def tearDown(self):
+ initialize_nss_database()
+
def test_figure3(self):
doc = PSKCDocument(os.path.join(basename, "pskc-figure3.xml"))
assert doc.keyname is None