buildframework/helium/sf/python/pythoncore/lib/pythoncoretests/test_session_provider.py
author wbernard
Fri, 13 Aug 2010 14:59:05 +0300
changeset 628 7c4a911dc066
parent 588 c7c26511138f
permissions -rw-r--r--
helium_11.0.0-e00f171ca185
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     1
#============================================================================ 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     2
#Name        : test_session_provider.py 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     3
#Part of     : Helium 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     4
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     5
#Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     6
#All rights reserved.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     7
#This component and the accompanying materials are made available
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     8
#under the terms of the License "Eclipse Public License v1.0"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     9
#which accompanies this distribution, and is available
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    10
#at the URL "http://www.eclipse.org/legal/epl-v10.html".
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    11
#
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    12
#Initial Contributors:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    13
#Nokia Corporation - initial contribution.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    14
#
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    15
#Contributors:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    16
#
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    17
#Description:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    18
#===============================================================================
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    19
588
c7c26511138f helium-10.0.0-bc45d50958fe
wbernard
parents: 587
diff changeset
    20
""" Test cases for ccm python toolkit."""
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    21
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
    22
# pylint: disable=R0201
588
c7c26511138f helium-10.0.0-bc45d50958fe
wbernard
parents: 587
diff changeset
    23
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    24
import unittest
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    25
import ccm
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    26
import ccm.extra
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    27
import os
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    28
import logging
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    29
import tempfile
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    30
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    31
_logger = logging.getLogger('test.test_session_provider')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    32
logging.basicConfig(level=logging.INFO)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    33
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
    34
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    35
class MockResultSession(ccm.AbstractSession):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    36
    """ Fake session used to test Result"""
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
    37
    def __init__(self, behave=None, database="fakedb"):
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    38
        ccm.AbstractSession.__init__(self, None, None, None, None)
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
    39
        if behave == None:
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
    40
            behave = {}
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    41
        self._behave = behave
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    42
        self._database = database
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    43
        self.dbpath = "/path/to/" + database
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    44
        self._session_addr = "LOCALHOST:127.0.0.1:1234"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    45
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    46
    def database(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    47
        """database"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    48
        _logger.info("running database from MockResultSession")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    49
        return self._database
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    50
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    51
    def execute(self, cmdline, result=None):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    52
        """execute the class"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    53
        if result == None:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    54
            result = ccm.Result(self)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    55
        if self._behave.has_key(cmdline):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    56
            result.statuserrors = 0  
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    57
            result.output = self._behave[cmdline]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    58
        else:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    59
            result.status = -1  
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    60
        return result
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    61
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
    62
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    63
class MockOpener(object):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    64
    """ An Opener which provides a mock session """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    65
    def __init__(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    66
        self.failOnNewOpen = False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    67
    
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
    68
# pylint: disable=W0613
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    69
#need disable msg to prevent pylint warning as this is emulating the real method.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    70
    def __call__(self, username=None, password=None, engine=None, dbpath=None, database=None, reuse=True):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    71
        assert self.failOnNewOpen == False, "This method should not be called again."
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    72
        if database != "fakedb":
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    73
            raise ccm.CCMException("Invalid database")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    74
        return MockResultSession()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    75
# pylint: enable-msg=W0613
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    76
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
    77
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    78
class SessionProviderTest(unittest.TestCase):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    79
    """ Testing Results parsers. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    80
    def test_get_valid_db(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    81
        """ Test the opening of a valid database. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    82
        prov = ccm.extra.SessionProvider(opener=MockOpener())
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    83
        dbase = prov.get(database="fakedb")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    84
        assert dbase is not None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    85
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    86
    def test_get_invalid_db(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    87
        """ Test the opening of an invalid database. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    88
        prov = ccm.extra.SessionProvider(opener=MockOpener())
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    89
        try:
588
c7c26511138f helium-10.0.0-bc45d50958fe
wbernard
parents: 587
diff changeset
    90
            _ = prov.get(database="invaliddb")
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    91
            assert False, "Should raise Exception when giving unexisting dbase.'"
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
    92
        except ccm.CCMException, exc:
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    93
            _logger.info(exc)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    94
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    95
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    96
class CachedSessionProviderTest(unittest.TestCase):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    97
    """ Testing Results parsers. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    98
    session_cache = os.path.join(tempfile.mkdtemp(), 'session_cache.xml')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    99
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   100
    def setUp(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   101
        """called before any of the test methods are run"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   102
        if not os.path.exists(os.path.dirname(self.session_cache)):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   103
            os.makedirs(os.path.dirname(self.session_cache))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   104
        if os.path.exists(self.session_cache):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   105
            os.remove(self.session_cache)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   106
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   107
    def tearDown(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   108
        """called after all the tests are run to tidy up """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   109
        if os.path.exists(self.session_cache):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   110
            os.remove(self.session_cache)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   111
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   112
    def test_get_valid_db(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   113
        """ Test the opening of a valid database (cached). """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   114
        prov = ccm.extra.CachedSessionProvider(opener=MockOpener())
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   115
        dbase = prov.get(database="fakedb")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   116
        assert dbase is not None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   117
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   118
    def test_get_invalid_db(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   119
        """ Test the opening of an invalid database (cached). """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   120
        prov = ccm.extra.CachedSessionProvider(opener=MockOpener())
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   121
        try:
588
c7c26511138f helium-10.0.0-bc45d50958fe
wbernard
parents: 587
diff changeset
   122
            _ = prov.get(database="invaliddb")
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   123
            assert False, "Should raise Exception when giving unexisting dbase.'"
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
   124
        except ccm.CCMException, exc:
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   125
            _logger.info(exc)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   126
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   127
    def test_open_session_twice(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   128
        """ Open session then free it then open it again... """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   129
        opener = MockOpener()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   130
        prov = ccm.extra.CachedSessionProvider(opener=opener)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   131
        dbase = prov.get(database="fakedb")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   132
        assert dbase is not None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   133
        dbase.close()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   134
        opener.failOnNewOpen = True
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   135
        db2 = prov.get(database="fakedb")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   136
        assert db2 is not None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   137
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   138
    def test_write_cache(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   139
        """write to the cache"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   140
        prov = ccm.extra.CachedSessionProvider(opener=MockOpener(), cache=self.session_cache)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   141
        dbase = prov.get(database="fakedb")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   142
        assert dbase is not None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   143
        del dbase
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   144
        prov.save()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   145
        assert os.path.exists(self.session_cache), "Cache file %s is missing." % self.session_cache
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   146
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   147
    def test_write_and_load_cache(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   148
        """write to and load the cache"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   149
        # patching the default implementation
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   150
        def always_true(_, d_base=None):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   151
            """always true return 1"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   152
            d_base = True       #done to prevent pylint warning
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   153
            return d_base
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   154
        ccm.session_exists = always_true
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   155
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   156
        prov = ccm.extra.CachedSessionProvider(opener=MockOpener(), cache=self.session_cache)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   157
        dbase = prov.get(database="fakedb")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   158
        assert dbase is not None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   159
        del dbase
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   160
        prov.close()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   161
        assert os.path.exists(self.session_cache), "Cache file %s is missing." % self.session_cache
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   162
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   163
        opener = MockOpener()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   164
        opener.failOnNewOpen = True
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   165
        prov = ccm.extra.CachedSessionProvider(opener=opener, cache=self.session_cache)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   166
        assert 'fakedb' in prov.cacheFree
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   167
        assert len(prov.cacheFree['fakedb']) == 1