summaryrefslogtreecommitdiffstats
path: root/tests/unit/test_local.py
blob: bc7b05d2499b340a361ac2db5fd3311844d4e596 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
# vim: tabstop=4 shiftwidth=4 softtabstop=4

# Copyright 2012 OpenStack Foundation.
# All Rights Reserved.
#
#    Licensed under the Apache License, Version 2.0 (the "License"); you may
#    not use this file except in compliance with the License. You may obtain
#    a copy of the License at
#
#         http://www.apache.org/licenses/LICENSE-2.0
#
#    Unless required by applicable law or agreed to in writing, software
#    distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
#    WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
#    License for the specific language governing permissions and limitations
#    under the License.

import threading

from openstack.common import local
from tests import utils


class Dict(dict):
    """Make weak referencable object."""
    pass


class LocalStoreTestCase(utils.BaseTestCase):
    v1 = Dict(a='1')
    v2 = Dict(a='2')
    v3 = Dict(a='3')

    def setUp(self):
        super(LocalStoreTestCase, self).setUp()
        # NOTE(mrodden): we need to make sure that local store
        # gets imported in the current python context we are
        # testing in (eventlet vs normal python threading) so
        # we test the correct type of local store for the current
        # threading model
        reload(local)

    def test_thread_unique_storage(self):
        """Make sure local store holds thread specific values."""
        expected_set = []
        local.store.a = self.v1

        def do_something():
            local.store.a = self.v2
            expected_set.append(getattr(local.store, 'a'))

        def do_something2():
            local.store.a = self.v3
            expected_set.append(getattr(local.store, 'a'))

        t1 = threading.Thread(target=do_something)
        t2 = threading.Thread(target=do_something2)
        t1.start()
        t2.start()
        t1.join()
        t2.join()

        expected_set.append(getattr(local.store, 'a'))

        self.assertTrue(self.v1 in expected_set)
        self.assertTrue(self.v2 in expected_set)
        self.assertTrue(self.v3 in expected_set)