Commit 6c88dc5c authored by Jim Fulton's avatar Jim Fulton

Updated DemoStorage ZConfig support.

parent 40e98541
...@@ -278,3 +278,52 @@ storage wrapped around it when necessary: ...@@ -278,3 +278,52 @@ storage wrapped around it when necessary:
>>> import os >>> import os
>>> os.path.exists(blobdir) >>> os.path.exists(blobdir)
False False
ZConfig support
===============
You can configure demo storages using ZConfig, using name, changes,
and base options:
>>> import ZODB.config
>>> storage = ZODB.config.storageFromString("""
... <demostorage>
... </demostorage>
... """)
>>> storage.getName()
"DemoStorage('MappingStorage', 'MappingStorage')"
>>> storage = ZODB.config.storageFromString("""
... <demostorage>
... <filestorage base>
... path base.fs
... </filestorage>
...
... <filestorage changes>
... path changes.fs
... </filestorage>
... </demostorage>
... """)
>>> storage.getName()
"DemoStorage('base.fs', 'changes.fs')"
>>> storage.close()
>>> storage = ZODB.config.storageFromString("""
... <demostorage>
... name bob
... <filestorage>
... path base.fs
... </filestorage>
...
... <filestorage changes>
... path changes.fs
... </filestorage>
... </demostorage>
... """)
>>> storage.getName()
'bob'
>>> storage.base.getName()
'base.fs'
>>> storage.close()
...@@ -175,8 +175,7 @@ ...@@ -175,8 +175,7 @@
<sectiontype name="demostorage" datatype=".DemoStorage" <sectiontype name="demostorage" datatype=".DemoStorage"
implements="ZODB.storage"> implements="ZODB.storage">
<key name="name" /> <key name="name" />
<section type="ZODB.storage" name="*" attribute="base" /> <multisection type="ZODB.storage" name="*" attribute="factories" />
<section type="ZODB.storage" name="changes" attribute="changes" />
</sectiontype> </sectiontype>
......
...@@ -120,15 +120,17 @@ class MappingStorage(BaseConfig): ...@@ -120,15 +120,17 @@ class MappingStorage(BaseConfig):
class DemoStorage(BaseConfig): class DemoStorage(BaseConfig):
def open(self): def open(self):
from ZODB.DemoStorage import DemoStorage base = changes = None
if self.config.base: for factory in self.config.factories:
base = self.config.base.open() if factory.name == 'changes':
changes = factory.open()
else: else:
base = None if base is None:
if self.config.changes: base = factory.open()
changes = self.config.changes.open()
else: else:
changes = None raise ValueError("Too many base storages defined!")
from ZODB.DemoStorage import DemoStorage
return DemoStorage(self.config.name, base=base, changes=changes) return DemoStorage(self.config.name, base=base, changes=changes)
class FileStorage(BaseConfig): class FileStorage(BaseConfig):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment