Add rollback capability to undo database changes made during tests.

This commit is contained in:
Prinz23 2016-09-13 19:50:05 +01:00 committed by JackDandy
parent bad5c443aa
commit ea702379c3
5 changed files with 76 additions and 12 deletions

View file

@ -1,4 +1,9 @@
### 0.11.14 (2016-07-25 03:10:00 UTC) ### 0.11.15 (2016-09-13 19:50:00 UTC)
* Add rollback capability to undo database changes made during tests
### 0.11.14 (2016-07-25 03:10:00 UTC)
* Fix BeyondHD torrent provider * Fix BeyondHD torrent provider

View file

@ -270,18 +270,36 @@ class SickGear(object):
sickbeard.CFG = ConfigObj(sickbeard.CONFIG_FILE) sickbeard.CFG = ConfigObj(sickbeard.CONFIG_FILE)
CUR_DB_VERSION = db.DBConnection().checkDBVersion() # check all db versions
for d, min_v, max_v, mo in [
('failed.db', sickbeard.failed_db.MIN_DB_VERSION, sickbeard.failed_db.MAX_DB_VERSION, 'FailedDb'),
('cache.db', sickbeard.cache_db.MIN_DB_VERSION, sickbeard.cache_db.MAX_DB_VERSION, 'CacheDb'),
('sickbeard.db', sickbeard.mainDB.MIN_DB_VERSION, sickbeard.mainDB.MAX_DB_VERSION, 'MainDb')
]:
cur_db_version = db.DBConnection(d).checkDBVersion()
if CUR_DB_VERSION > 0: if cur_db_version > 0:
if CUR_DB_VERSION < MIN_DB_VERSION: if cur_db_version < min_v:
print(u'Your database version (%s) is too old to migrate from with this version of SickGear' \ print(u'Your [%s] database version (%s) is too old to migrate from with this version of SickGear'
% CUR_DB_VERSION) % (d, cur_db_version))
sys.exit(u'Upgrade using a previous version of SG first, or start with no database file to begin fresh') sys.exit(u'Upgrade using a previous version of SG first,'
if CUR_DB_VERSION > MAX_DB_VERSION: + u' or start with no database file to begin fresh')
print(u'Your database version (%s) has been incremented past what this version of SickGear supports' \ if cur_db_version > max_v:
% CUR_DB_VERSION) print(u'Your [%s] database version (%s) has been incremented past'
sys.exit( u' what this version of SickGear supports. Trying to rollback now. Please wait...' %
u'If you have used other forks of SG, your database may be unusable due to their modifications') (d, cur_db_version))
try:
rollback_loaded = db.get_rollback_module()
if None is not rollback_loaded:
rollback_loaded.__dict__[mo]().run(max_v)
else:
print(u'ERROR: Could not download Rollback Module.')
except (StandardError, Exception):
pass
if db.DBConnection(d).checkDBVersion() > max_v:
print(u'Rollback failed.')
sys.exit(u'If you have used other forks, your database may be unusable due to their changes')
print(u'Rollback of [%s] successful.' % d)
# Initialize the config and our threads # Initialize the config and our threads
sickbeard.initialize(consoleLogging=self.consoleLogging) sickbeard.initialize(consoleLogging=self.consoleLogging)

View file

@ -18,6 +18,9 @@
from sickbeard import db from sickbeard import db
MIN_DB_VERSION = 1
MAX_DB_VERSION = 2
# Add new migrations at the bottom of the list; subclass the previous migration. # Add new migrations at the bottom of the list; subclass the previous migration.
class InitialSchema(db.SchemaUpgrade): class InitialSchema(db.SchemaUpgrade):
def test(self): def test(self):

View file

@ -19,6 +19,8 @@
from sickbeard import db from sickbeard import db
from sickbeard.common import Quality from sickbeard.common import Quality
MIN_DB_VERSION = 1
MAX_DB_VERSION = 1
# Add new migrations at the bottom of the list; subclass the previous migration. # Add new migrations at the bottom of the list; subclass the previous migration.
class InitialSchema(db.SchemaUpgrade): class InitialSchema(db.SchemaUpgrade):

View file

@ -472,9 +472,45 @@ def MigrationCode(myDB):
else: else:
logger.log_error_and_exit(u'Failed to restore database version: %s' % db_version) logger.log_error_and_exit(u'Failed to restore database version: %s' % db_version)
def backup_database(filename, version): def backup_database(filename, version):
logger.log(u'Backing up database before upgrade') logger.log(u'Backing up database before upgrade')
if not sickbeard.helpers.backupVersionedFile(dbFilename(filename), version): if not sickbeard.helpers.backupVersionedFile(dbFilename(filename), version):
logger.log_error_and_exit(u'Database backup failed, abort upgrading database') logger.log_error_and_exit(u'Database backup failed, abort upgrading database')
else: else:
logger.log(u'Proceeding with upgrade') logger.log(u'Proceeding with upgrade')
def get_rollback_module():
import imp
module_urls = [
'https://raw.githubusercontent.com/SickGear/sickgear.extdata/master/SickGear/Rollback/rollback.py']
try:
hdr = '# SickGear Rollback Module'
module = ''
fetched = False
for t in range(1, 4):
for url in module_urls:
try:
module = helpers.getURL(url)
if module and module.startswith(hdr):
fetched = True
break
except (StandardError, Exception):
continue
if fetched:
break
time.sleep(30)
if fetched:
loaded = imp.new_module('DbRollback')
exec(module, loaded.__dict__)
return loaded
except (StandardError, Exception):
pass
return None