#!/usr/bin/python # # Copyright (C) 2014 Ipsilon project Contributors, for license see COPYING from helpers.common import IpsilonTestBase # pylint: disable=relative-import from helpers.http import HttpSessions # pylint: disable=relative-import import os import pwd import sys import inspect from string import Template idp_g = {'TEMPLATES': '${TESTDIR}/templates/install', 'CONFDIR': '${TESTDIR}/etc', 'DATADIR': '${TESTDIR}/lib', 'HTTPDCONFD': '${TESTDIR}/${NAME}/conf.d', 'STATICDIR': '${ROOTDIR}', 'BINDIR': '${ROOTDIR}/ipsilon', 'WSGI_SOCKET_PREFIX': '${TESTDIR}/${NAME}/logs/wsgi'} idp_a = {'hostname': '${ADDRESS}:${PORT}', 'admin_user': '${TEST_USER}', 'system_user': '${TEST_USER}', 'instance': '${NAME}', 'secure': 'no', 'testauth': 'yes', 'openid': 'yes', 'openid_extensions': 'Attribute Exchange,Simple Registration,Teams', 'pam': 'no', 'gssapi': 'no', 'ipa': 'no', 'server_debugging': 'True'} def fixup_sp_httpd(httpdir, testdir): client_wsgi = """ WSGIScriptAlias / ${TESTDIR}/blobs/openid_app.py Require all granted """ t = Template(client_wsgi) text = t.substitute({'TESTDIR': testdir}) with open(httpdir + '/conf.d/ipsilon-openid-client.conf', 'a') as f: f.write(text) class IpsilonTest(IpsilonTestBase): def __init__(self): super(IpsilonTest, self).__init__('openid', __file__) def setup_servers(self, env=None): print "Installing IDP server" name = 'idp1' addr = '127.0.0.10' port = '45080' idp = self.generate_profile(idp_g, idp_a, name, addr, port) conf = self.setup_idp_server(idp, name, addr, port, env) print "Starting IDP's httpd server" self.start_http_server(conf, env) print "Installing first SP server" name = 'sp1' addr = '127.0.0.11' port = '45081' conf = self.setup_http(name, addr, port) testdir = os.path.dirname(os.path.abspath(inspect.getfile( inspect.currentframe()))) fixup_sp_httpd(os.path.dirname(conf), testdir) print "Starting SP's httpd server" self.start_http_server(conf, env) if __name__ == '__main__': idpname = 'idp1' sp1name = 'sp1' user = pwd.getpwuid(os.getuid())[0] sess = HttpSessions() sess.add_server(idpname, 'http://127.0.0.10:45080', user, 'ipsilon') sess.add_server(sp1name, 'http://127.0.0.11:45081') print "openid: Authenticate to IDP ...", try: sess.auth_to_idp(idpname) except Exception as e: # pylint: disable=broad-except print >> sys.stderr, " ERROR: %s" % repr(e) sys.exit(1) print " SUCCESS" print "openid: Run OpenID Protocol ...", try: page = sess.fetch_page(idpname, 'http://127.0.0.11:45081/?extensions=NO') page.expected_value('text()', 'SUCCESS, WITHOUT EXTENSIONS') except ValueError as e: print >> sys.stderr, " ERROR: %s" % repr(e) sys.exit(1) print " SUCCESS" print "openid: Run OpenID Protocol with extensions ...", try: page = sess.fetch_page(idpname, 'http://127.0.0.11:45081/?extensions=YES') page.expected_value('text()', 'SUCCESS, WITH EXTENSIONS') except ValueError as e: print >> sys.stderr, " ERROR: %s" % repr(e) sys.exit(1) print " SUCCESS"