source: waeup/branches/ulif-namespace/src/sirp/university/facultycontainer.txt @ 4791

Last change on this file since 4791 was 4789, checked in by uli, 15 years ago

Merge changes from ulif-layout back into trunk (finally).

File size: 2.0 KB
Line 
1FacultyContainer
2****************
3
4Containers for faculties.
5
6:Test-Layer: unit
7
8Getting a faculty container
9===========================
10
11We can easily create `FacultyContainers`::
12
13    >>> from waeup.university.facultycontainer import FacultyContainer
14    >>> mycontainer = FacultyContainer()
15
16Faculty containers provide `IFacultyContainer`:
17
18    >>> from waeup.interfaces import IFacultyContainer
19    >>> IFacultyContainer.providedBy(mycontainer)
20    True
21
22Another way to get a faculty container -- without importing the class
23-- is via factories. We registered a factory for faculty containers
24under the name ``waeup.facultycontainer``::
25
26    >>> import grok
27    >>> grok.testing.grok('waeup')
28
29Now we can ask for an object by calling the appropriate factory:
30
31    >>> from zope.component import createObject
32    >>> createObject(u'waeup.FacultyContainer')
33    <waeup.university.facultycontainer.FacultyContainer object at 0x...>
34
35This way we get a thing that implements IFacultyContainer without
36imports or similar.
37
38We can be sure, that the full interface is supported by the
39FacultyContainer class::
40
41    >>> from zope.interface.verify import verifyClass
42    >>> verifyClass(IFacultyContainer, FacultyContainer)
43    True
44
45
46Storing things in faculty containers
47====================================
48
49We can, of course, store things in a faculty container. But when we
50really store an object, then it must be a faculty::
51
52    >>> mycontainer.addFaculty(42)
53    Traceback (most recent call last):
54    ...
55    TypeError: FacultyContainers contain only IFaculty instances
56
57Okay, so we have to get a faculty first::
58
59    >>> from waeup.university.faculty import Faculty
60    >>> myfaculty = Faculty()
61
62We can add this faculty to our container::
63
64    >>> mycontainer.addFaculty(myfaculty)
65
66We get back the key, under which the faculty was stored. It will be
67some string, but there is no guarantee at all, how this key looks
68like. It might be a string of integers, a name or whatever; you cannot
69know before.
70
Note: See TracBrowser for help on using the repository browser.