~divmod-dev/divmod.org/trunk

« back to all changes in this revision

Viewing changes to Epsilon/epsilon/test/test_remember.py

  • Committer: Jean-Paul Calderone
  • Date: 2014-06-29 20:33:04 UTC
  • mfrom: (2749.1.1 remove-epsilon-1325289)
  • Revision ID: exarkun@twistedmatrix.com-20140629203304-gdkmbwl1suei4m97
mergeĀ lp:~exarkun/divmod.org/remove-epsilon-1325289

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
 
2
 
from twisted.trial.unittest import TestCase
3
 
 
4
 
from epsilon.remember import remembered
5
 
from epsilon.structlike import record
6
 
 
7
 
class Rememberee(record("rememberer whichValue")):
8
 
    """
9
 
    A sample value that holds on to its L{Rememberer}.
10
 
    """
11
 
 
12
 
 
13
 
class Rememberer(object):
14
 
    """
15
 
    Sample application code which uses epsilon.remember.
16
 
 
17
 
    @ivar invocations: The number of times that it is invoked.
18
 
    """
19
 
 
20
 
    invocations = 0
21
 
    otherInvocations = 0
22
 
 
23
 
    @remembered
24
 
    def value1(self):
25
 
        """
26
 
        I remember a value.
27
 
        """
28
 
        self.invocations += 1
29
 
        return Rememberee(self, 1)
30
 
 
31
 
 
32
 
    @remembered
33
 
    def value2(self):
34
 
        """
35
 
        A separate value.
36
 
        """
37
 
        self.otherInvocations += 1
38
 
        return Rememberee(self, 2)
39
 
 
40
 
 
41
 
class RememberedTests(TestCase):
42
 
    """
43
 
    The "remembered" decorator allows you to lazily create an attribute and
44
 
    remember it.
45
 
    """
46
 
 
47
 
    def setUp(self):
48
 
        """
49
 
        Create a L{Rememberer} for use with the tests.
50
 
        """
51
 
        self.rememberer = Rememberer()
52
 
 
53
 
 
54
 
    def test_selfArgument(self):
55
 
        """
56
 
        The "self" argument to the decorated creation function will be the
57
 
        instance the property is accessed upon.
58
 
        """
59
 
        value = self.rememberer.value1
60
 
        self.assertIdentical(value.rememberer, self.rememberer)
61
 
 
62
 
 
63
 
    def test_onlyOneInvocation(self):
64
 
        """
65
 
        The callable wrapped by C{@remembered} will only be invoked once,
66
 
        regardless of how many times the attribute is accessed.
67
 
        """
68
 
        self.assertEquals(self.rememberer.invocations, 0)
69
 
        firstTime = self.rememberer.value1
70
 
        self.assertEquals(self.rememberer.invocations, 1)
71
 
        secondTime = self.rememberer.value1
72
 
        self.assertEquals(self.rememberer.invocations, 1)
73
 
        self.assertIdentical(firstTime, secondTime)
74
 
 
75
 
 
76
 
    def test_twoValues(self):
77
 
        """
78
 
        If the L{@remembered} decorator is used more than once, each one will
79
 
        be an attribute with its own identity.
80
 
        """
81
 
        self.assertEquals(self.rememberer.invocations, 0)
82
 
        self.assertEquals(self.rememberer.otherInvocations, 0)
83
 
        firstValue1 = self.rememberer.value1
84
 
        self.assertEquals(self.rememberer.invocations, 1)
85
 
        self.assertEquals(self.rememberer.otherInvocations, 0)
86
 
        firstValue2 = self.rememberer.value2
87
 
        self.assertEquals(self.rememberer.otherInvocations, 1)
88
 
        self.assertNotIdentical(firstValue1, firstValue2)
89
 
        secondValue2 = self.rememberer.value2
90
 
        self.assertIdentical(firstValue2, secondValue2)