new loops subpackage 'integrator' for importing and integrating operating system files and other external objects
git-svn-id: svn://svn.cy55.de/Zope3/src/loops/trunk@1682 fd906abe-77d9-0310-91a1-e0d9ade77398
This commit is contained in:
parent
2b250fce37
commit
503370574c
6 changed files with 152 additions and 0 deletions
35
integrator/README.txt
Normal file
35
integrator/README.txt
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
===============================================================
|
||||||
|
loops - Linked Objects for Organization and Processing Services
|
||||||
|
===============================================================
|
||||||
|
|
||||||
|
Integration of external sources.
|
||||||
|
|
||||||
|
($Id$)
|
||||||
|
|
||||||
|
|
||||||
|
Setting up a loops Site and Utilities
|
||||||
|
=====================================
|
||||||
|
|
||||||
|
Let's do some basic set up
|
||||||
|
|
||||||
|
>>> from zope import component, interface
|
||||||
|
>>> from zope.traversing.api import getName
|
||||||
|
>>> from zope.app.testing.setup import placefulSetUp, placefulTearDown
|
||||||
|
>>> site = placefulSetUp(True)
|
||||||
|
|
||||||
|
and build a simple loops site with a concept manager and some concepts
|
||||||
|
(with a relation registry, a catalog, and all the type machinery - what
|
||||||
|
in real life is done via standard ZCML setup or via local utility
|
||||||
|
configuration):
|
||||||
|
|
||||||
|
>>> from loops.integrator.testsetup import TestSite
|
||||||
|
>>> t = TestSite(site)
|
||||||
|
>>> concepts, resources, views = t.setup()
|
||||||
|
|
||||||
|
>>> len(concepts) + len(resources)
|
||||||
|
18
|
||||||
|
|
||||||
|
Fin de partie
|
||||||
|
=============
|
||||||
|
|
||||||
|
>>> placefulTearDown()
|
4
integrator/__init__.py
Normal file
4
integrator/__init__.py
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
"""
|
||||||
|
$Id$
|
||||||
|
"""
|
||||||
|
|
9
integrator/configure.zcml
Normal file
9
integrator/configure.zcml
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
<!-- $Id$ -->
|
||||||
|
|
||||||
|
<configure
|
||||||
|
xmlns:zope="http://namespaces.zope.org/zope"
|
||||||
|
xmlns:browser="http://namespaces.zope.org/browser"
|
||||||
|
i18n_domain="zope"
|
||||||
|
>
|
||||||
|
|
||||||
|
</configure>
|
32
integrator/interfaces.py
Normal file
32
integrator/interfaces.py
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
#
|
||||||
|
# Copyright (c) 2007 Helmut Merz helmutm@cy55.de
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation; either version 2 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
#
|
||||||
|
|
||||||
|
"""
|
||||||
|
Intergrator interfaces.
|
||||||
|
|
||||||
|
$Id$
|
||||||
|
"""
|
||||||
|
|
||||||
|
from zope.interface import Interface, Attribute
|
||||||
|
from zope import interface, component, schema
|
||||||
|
|
||||||
|
|
||||||
|
class IExternalCollection(Interface):
|
||||||
|
""" A collection of resources.
|
||||||
|
"""
|
||||||
|
|
23
integrator/tests.py
Executable file
23
integrator/tests.py
Executable file
|
@ -0,0 +1,23 @@
|
||||||
|
# $Id$
|
||||||
|
|
||||||
|
import unittest, doctest
|
||||||
|
from zope.testing.doctestunit import DocFileSuite
|
||||||
|
from zope.interface.verify import verifyClass
|
||||||
|
#from loops.versioning import versionable
|
||||||
|
|
||||||
|
class Test(unittest.TestCase):
|
||||||
|
"Basic tests for the expert sub-package."
|
||||||
|
|
||||||
|
def testSomething(self):
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
def test_suite():
|
||||||
|
flags = doctest.NORMALIZE_WHITESPACE | doctest.ELLIPSIS
|
||||||
|
return unittest.TestSuite((
|
||||||
|
unittest.makeSuite(Test),
|
||||||
|
DocFileSuite('README.txt', optionflags=flags),
|
||||||
|
))
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main(defaultTest='test_suite')
|
49
integrator/testsetup.py
Normal file
49
integrator/testsetup.py
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
"""
|
||||||
|
Set up a loops site for testing.
|
||||||
|
|
||||||
|
$Id$
|
||||||
|
"""
|
||||||
|
|
||||||
|
from zope import component
|
||||||
|
from zope.app.catalog.catalog import Catalog
|
||||||
|
from zope.app.catalog.interfaces import ICatalog
|
||||||
|
from zope.app.catalog.field import FieldIndex
|
||||||
|
from zope.app.catalog.text import TextIndex
|
||||||
|
|
||||||
|
from cybertools.relation.tests import IntIdsStub
|
||||||
|
from cybertools.relation.registry import RelationRegistry
|
||||||
|
from cybertools.relation.interfaces import IRelationRegistry
|
||||||
|
from cybertools.relation.registry import IndexableRelationAdapter
|
||||||
|
from cybertools.typology.interfaces import IType
|
||||||
|
|
||||||
|
from loops import Loops
|
||||||
|
from loops import util
|
||||||
|
from loops.interfaces import IIndexAttributes
|
||||||
|
from loops.concept import Concept
|
||||||
|
from loops.concept import IndexAttributes as ConceptIndexAttributes
|
||||||
|
from loops.resource import Resource
|
||||||
|
from loops.resource import IndexAttributes as ResourceIndexAttributes
|
||||||
|
from loops.integrator.interfaces import IExternalCollection
|
||||||
|
from loops.knowledge.setup import SetupManager as KnowledgeSetupManager
|
||||||
|
from loops.setup import SetupManager, addObject
|
||||||
|
from loops.tests.setup import TestSite as BaseTestSite
|
||||||
|
from loops.type import ConceptType, ResourceType, TypeConcept
|
||||||
|
|
||||||
|
|
||||||
|
class TestSite(BaseTestSite):
|
||||||
|
|
||||||
|
def __init__(self, site):
|
||||||
|
self.site = site
|
||||||
|
|
||||||
|
def setup(self):
|
||||||
|
component.provideAdapter(KnowledgeSetupManager, name='knowledge')
|
||||||
|
concepts, resources, views = self.baseSetup()
|
||||||
|
|
||||||
|
tType = concepts.getTypeConcept()
|
||||||
|
|
||||||
|
tExtFile = concepts['extfile'] = Concept(u'External File')
|
||||||
|
tExtCollection = concepts['extcollection'] = Concept(u'External Collection')
|
||||||
|
|
||||||
|
self.indexAll(concepts, resources)
|
||||||
|
return concepts, resources, views
|
||||||
|
|
Loading…
Add table
Reference in a new issue