diff --git a/zaza/openstack/charm_tests/ceph/dashboard/tests.py b/zaza/openstack/charm_tests/ceph/dashboard/tests.py
index 4e0e5c2..66309d0 100644
--- a/zaza/openstack/charm_tests/ceph/dashboard/tests.py
+++ b/zaza/openstack/charm_tests/ceph/dashboard/tests.py
@@ -27,14 +27,63 @@ import zaza.openstack.charm_tests.test_utils as test_utils
import zaza.openstack.utilities.openstack as openstack_utils
+X509_CERT = '''
+MIICZDCCAg6gAwIBAgICBr8wDQYJKoZIhvcNAQEEBQAwgZIxCzAJBgNVBAYTAlVTMRMwEQYDVQQI
+EwpDYWxpZm9ybmlhMRQwEgYDVQQHEwtTYW50YSBDbGFyYTEeMBwGA1UEChMVU3VuIE1pY3Jvc3lz
+dGVtcyBJbmMuMRowGAYDVQQLExFJZGVudGl0eSBTZXJ2aWNlczEcMBoGA1UEAxMTQ2VydGlmaWNh
+dGUgTWFuYWdlcjAeFw0wNzAzMDcyMTUwMDVaFw0xMDEyMDEyMTUwMDVaMDsxFDASBgNVBAoTC2V4
+YW1wbGUuY29tMSMwIQYDVQQDExpMb2FkQmFsYW5jZXItMy5leGFtcGxlLmNvbTCBnzANBgkqhkiG
+9w0BAQEFAAOBjQAwgYkCgYEAlOhN9HddLMpE3kCjkPSOFpCkDxTNuhMhcgBkYmSEF/iJcQsLX/ga
+pO+W1SIpwqfsjzR5ZvEdtc/8hGumRHqcX3r6XrU0dESM6MW5AbNNJsBnwIV6xZ5QozB4wL4zREhw
+zwwYejDVQ/x+8NRESI3ym17tDLEuAKyQBueubgjfic0CAwEAAaNgMF4wEQYJYIZIAYb4QgEBBAQD
+AgZAMA4GA1UdDwEB/wQEAwIE8DAfBgNVHSMEGDAWgBQ7oCE35Uwn7FsjS01w5e3DA1CrrjAYBgNV
+HREEETAPgQ1tYWxsYUBzdW4uY29tMA0GCSqGSIb3DQEBBAUAA0EAGhJhep7X2hqWJWQoXFcdU7eQ
+'''
+
+X509_DATA = '''
+EwpDYWxpZm9ybmlhMRQwEgYDVQQHEwtTYW50YSBDbGFyYTEeMBwGA1UEChMVU3VuIE1pY3Jvc3lz
+dGVtcyBJbmMuMRowGAYDVQQLExFJZGVudGl0eSBTZXJ2aWNlczEcMBoGA1UEAxMTQ2VydGlmaWNh
+dGUgTWFuYWdlcjAeFw0wNzAzMDcyMjAxMTVaFw0xMDEyMDEyMjAxMTVaMDsxFDASBgNVBAoTC2V4
+YW1wbGUuY29tMSMwIQYDVQQDExpMb2FkQmFsYW5jZXItMy5leGFtcGxlLmNvbTCBnzANBgkqhkiG
+HREEETAPgQ1tYWxsYUBzdW4uY29tMA0GCSqGSIb3DQEBBAUAA0EAEgbmnOz2Rvpj9bludb9lEeVa
+OA46zRiyt4BPlbgIaFyG6P7GWSddMi/14EimQjjDbr4ZfvlEdPJmimHExZY3KQ==
+'''
+
SAML_IDP_METADATA = '''
-
-
-
- {}
-
-
-
+
+
+
+
+
+
+ {cert}
+
+
+
+
+
+
+
+ {data}
+
+
+
+
+
+ urn:oasis:names:tc:SAML:2.0:nameid-format:persistent
+
+
+ urn:oasis:names:tc:SAML:2.0:nameid-format:transient
+
+
+
+
'''
@@ -112,16 +161,10 @@ class CephDashboardTest(test_utils.BaseCharmTest):
:returns: URL of dashboard on unit
:rtype: Union[str, None]
"""
- units = zaza.model.get_units(self.application_name)
- for unit in units:
- r = self._run_request_get(
- 'https://{}:8443'.format(
- zaza.model.get_unit_public_address(unit)),
- verify=self.local_ca_cert,
- allow_redirects=False)
- if r.status_code == requests.codes.ok:
- return 'https://{}:8443'.format(
- zaza.model.get_unit_public_address(unit))
+ output = zaza.model.run_on_leader(
+ 'ceph-mon',
+ 'ceph mgr services')['Stdout']
+ return json.loads(output)['dashboard']
def test_dashboard_units(self):
"""Check dashboard units are configured correctly."""
@@ -187,7 +230,7 @@ class CephDashboardTest(test_utils.BaseCharmTest):
path = "api/auth"
headers = {
'Content-type': 'application/json',
- 'Accept': 'application/vnd.ceph.api.v1.0'}
+ 'Accept': 'application/vnd.ceph.api.v1.0+json'}
payload = {"username": user, "password": password}
verify = self.local_ca_cert
r = self._run_request_post(
@@ -232,22 +275,28 @@ class CephDashboardTest(test_utils.BaseCharmTest):
return
url = self.get_master_dashboard_url()
- with tempfile.NamedTemporaryFile(mode='w') as tmp, \
- open(self.local_ca_cert) as cert:
- tmp.write(SAML_IDP_METADATA.format(cert.read()))
- tmp.flush()
- zaza.model.set_application_config(
- 'ceph-dashboard',
- {
- 'saml-base-url': url,
- 'saml-idp-metadata': 'file://{}'.format(tmp.name),
- }
- )
+ idp_meta = SAML_IDP_METADATA.format(
+ cert=X509_CERT,
+ data=X509_DATA,
+ host=url)
- # Login must be redirected.
- resp = requests.get(url + '/auth/saml2/login')
- self.assertTrue(resp.is_redirect)
+ zaza.model.set_application_config(
+ 'ceph-dashboard',
+ {
+ 'saml-base-url': url,
+ 'saml-idp-metadata': idp_meta,
+ }
+ )
- # Check that metadata is present.
- resp = requests.get(url + '/auth/saml2/metadata')
- self.assertEqual(resp.status_code, requests.code.ok)
+ # Check that both login and metadata are accesible.
+ resp = self._run_request_get(
+ url + '/auth/saml2/login',
+ verify=self.local_ca_cert,
+ allow_redirects=False)
+ self.assertTrue(resp.status_code, requests.codes.ok)
+
+ resp = self._run_request_get(
+ url + '/auth/saml2/metadata',
+ verify=self.local_ca_cert,
+ allow_redirects=False)
+ self.assertEqual(resp.status_code, requests.codes.ok)