Make a zip backup if schema is to be upgraded see 8134: Error converting

python2 utf-8 strings to python3 str when loading data from database
This commit is contained in:
kulath 2015-03-02 17:42:51 +00:00
parent 5c6259edbc
commit d25385328b
2 changed files with 25 additions and 5 deletions

View File

@ -40,7 +40,7 @@ __all__ = (
('DBPAGE', 'DBMODE', 'DBCACHE', 'DBLOCKS', 'DBOBJECTS', 'DBUNDO', ('DBPAGE', 'DBMODE', 'DBCACHE', 'DBLOCKS', 'DBOBJECTS', 'DBUNDO',
'DBEXT', 'DBMODE_R', 'DBMODE_W', 'DBUNDOFN', 'DBLOCKFN', 'DBEXT', 'DBMODE_R', 'DBMODE_W', 'DBUNDOFN', 'DBLOCKFN',
'DBRECOVFN','BDBVERSFN', 'DBLOGNAME', 'DBFLAGS_O', 'DBFLAGS_R', 'DBRECOVFN','BDBVERSFN', 'DBLOGNAME', 'DBFLAGS_O', 'DBFLAGS_R',
'DBFLAGS_D', 'DBFLAGS_D', 'SCHVERSFN'
) + ) +
('PERSON_KEY', 'FAMILY_KEY', 'SOURCE_KEY', 'CITATION_KEY', ('PERSON_KEY', 'FAMILY_KEY', 'SOURCE_KEY', 'CITATION_KEY',
@ -56,6 +56,7 @@ DBUNDOFN = "undo.db" # File name of 'undo' database
DBLOCKFN = "lock" # File name of lock file DBLOCKFN = "lock" # File name of lock file
DBRECOVFN = "need_recover" # File name of recovery file DBRECOVFN = "need_recover" # File name of recovery file
BDBVERSFN = "bdbversion.txt"# File name of Berkeley DB version file BDBVERSFN = "bdbversion.txt"# File name of Berkeley DB version file
SCHVERSFN = "schemaversion.txt"# File name of schema version file
DBLOGNAME = ".Db" # Name of logger DBLOGNAME = ".Db" # Name of logger
DBMODE_R = "r" # Read-only access DBMODE_R = "r" # Read-only access
DBMODE_W = "w" # Full Read/Write access DBMODE_W = "w" # Full Read/Write access

View File

@ -558,6 +558,18 @@ class DbBsddb(DbBsddbRead, DbWriteBase, UpdateCallback):
self.__check_python_version(name, force_python_upgrade) self.__check_python_version(name, force_python_upgrade)
# Check for schema upgrade
versionpath = os.path.join(self.path, SCHVERSFN)
if os.path.isfile(versionpath):
with open(versionpath, "r") as version_file:
schema_version = int(version_file.read().strip())
else:
schema_version = 0
if not self.readonly and schema_version < _DBVERSION and \
force_schema_upgrade:
_LOG.debug("Make backup in case there is a schema upgrade")
self.__make_zip_backup(name)
# Set up database environment # Set up database environment
self.env = db.DBEnv() self.env = db.DBEnv()
self.env.set_cachesize(0, DBCACHE) self.env.set_cachesize(0, DBCACHE)
@ -664,7 +676,7 @@ class DbBsddb(DbBsddbRead, DbWriteBase, UpdateCallback):
versionpath = os.path.join(name, BDBVERSFN) versionpath = os.path.join(name, BDBVERSFN)
with open(versionpath, "w") as version_file: with open(versionpath, "w") as version_file:
version_file.write(str(db.version())) version_file.write(str(db.version()))
_LOG.debug("Updated BDBVERSFN file to %s" % str(db.version())) _LOG.debug("Updated bsddb version file to %s" % str(db.version()))
if self.update_python_version: if self.update_python_version:
versionpath = os.path.join(name, "pythonversion.txt") versionpath = os.path.join(name, "pythonversion.txt")
@ -683,6 +695,10 @@ class DbBsddb(DbBsddbRead, DbWriteBase, UpdateCallback):
(oldschema, newschema)) (oldschema, newschema))
if force_schema_upgrade == True: if force_schema_upgrade == True:
self.gramps_upgrade(callback) self.gramps_upgrade(callback)
versionpath = os.path.join(name, SCHVERSFN)
with open(versionpath, "w") as version_file:
version_file.write(str(_DBVERSION))
_LOG.debug("Updated schema version file to %s" % str(_DBVERSION))
else: else:
self.__close_early() self.__close_early()
clear_lock_file(name) clear_lock_file(name)
@ -2125,6 +2141,11 @@ class DbBsddb(DbBsddbRead, DbWriteBase, UpdateCallback):
with open(versionpath, "w") as version_file: with open(versionpath, "w") as version_file:
version_file.write(str(version_info[0])) version_file.write(str(version_info[0]))
versionpath = os.path.join(name, SCHVERSFN)
_LOG.debug("Write schema version file to %s" % str(_DBVERSION))
with open(versionpath, "w") as version_file:
version_file.write(str(_DBVERSION))
self.metadata.close() self.metadata.close()
self.env.close() self.env.close()
@ -2161,9 +2182,7 @@ def write_lock_file(name):
try: try:
user = os.getlogin() user = os.getlogin()
except: except:
# not win, so don't need get_env_var. user = os.environ.get('USER')
# under cron getlogin() throws and there is no USER.
user = os.environ.get('USER', 'noUSER')
if host: if host:
text = "%s@%s" % (user, host) text = "%s@%s" % (user, host)
else: else: