Merge branch 'master' into develop

This commit is contained in:
JackDandy 2016-10-06 20:35:00 +01:00
commit 9772e8e41f
4 changed files with 51 additions and 6 deletions

View file

@ -199,6 +199,11 @@
* Change load cached images on demand * Change load cached images on demand
### 0.11.16 (2016-10-16 17:30:00 UTC)
* Change ensure a cache.db table does exist on migration
### 0.11.15 (2016-09-13 19:50:00 UTC) ### 0.11.15 (2016-09-13 19:50:00 UTC)
* Add rollback capability to undo database changes made during tests * Add rollback capability to undo database changes made during tests

View file

@ -64,6 +64,12 @@ class ConsolidateProviders(InitialSchema):
'indexerid NUMERIC, url TEXT UNIQUE, time NUMERIC, quality TEXT, release_group TEXT, ' 'indexerid NUMERIC, url TEXT UNIQUE, time NUMERIC, quality TEXT, release_group TEXT, '
'version NUMERIC)') 'version NUMERIC)')
if not self.hasTable('network_conversions'):
self.connection.action('CREATE TABLE network_conversions ' +
'(tvdb_network TEXT PRIMARY KEY, tvrage_network TEXT, tvrage_country TEXT)')
self.connection.action('CREATE INDEX tvrage_idx ' +
'on network_conversions (tvrage_network, tvrage_country)')
keep_tables = set(['lastUpdate', 'lastSearch', 'db_version', keep_tables = set(['lastUpdate', 'lastSearch', 'db_version',
'network_timezones', 'network_conversions', 'provider_cache']) 'network_timezones', 'network_conversions', 'provider_cache'])
current_tables = set(self.listTables()) current_tables = set(self.listTables())

View file

@ -992,6 +992,35 @@ class Migrate41(db.SchemaUpgrade):
return self.checkDBVersion() return self.checkDBVersion()
# 43,44 -> 10001
class Migrate43(db.SchemaUpgrade):
def execute(self):
db.backup_database('sickbeard.db', self.checkDBVersion())
db_chg = None
table = 'tmdb_info'
if self.hasTable(table):
logger.log(u'Dropping redundant table tmdb_info')
self.connection.action('DROP TABLE [%s]' % table)
db_chg = True
if self.hasColumn('tv_shows', 'tmdb_id'):
logger.log(u'Dropping redundant tmdb_info refs')
self.dropColumn('tv_shows', 'tmdb_id')
db_chg = True
if not self.hasTable('db_version'):
self.connection.action('PRAGMA user_version = 0')
self.connection.action('CREATE TABLE db_version (db_version INTEGER);')
self.connection.action('INSERT INTO db_version (db_version) VALUES (0);')
if not db_chg:
logger.log(u'Bumping database version')
self.setDBVersion(10001)
return self.checkDBVersion()
# 4301 -> 10002 # 4301 -> 10002
class Migrate4301(db.SchemaUpgrade): class Migrate4301(db.SchemaUpgrade):
def execute(self): def execute(self):

View file

@ -66,11 +66,16 @@ class DBConnection(object):
def checkDBVersion(self): def checkDBVersion(self):
result = None
try: try:
if self.hasTable('db_version'): if self.hasTable('db_version'):
result = self.select('SELECT db_version FROM db_version') result = self.select('SELECT db_version FROM db_version')
else:
version = self.select('PRAGMA user_version')[0]['user_version']
if version:
self.action('PRAGMA user_version = 0')
self.action('CREATE TABLE db_version (db_version INTEGER);')
self.action('INSERT INTO db_version (db_version) VALUES (%s);' % version)
return version
except: except:
return 0 return 0
@ -429,8 +434,8 @@ def MigrationCode(myDB):
40: sickbeard.mainDB.BumpDatabaseVersion, 40: sickbeard.mainDB.BumpDatabaseVersion,
41: sickbeard.mainDB.Migrate41, 41: sickbeard.mainDB.Migrate41,
42: sickbeard.mainDB.Migrate41, 42: sickbeard.mainDB.Migrate41,
43: sickbeard.mainDB.Migrate41, 43: sickbeard.mainDB.Migrate43,
44: sickbeard.mainDB.Migrate41, 44: sickbeard.mainDB.Migrate43,
4301: sickbeard.mainDB.Migrate4301, 4301: sickbeard.mainDB.Migrate4301,
4302: sickbeard.mainDB.Migrate4302, 4302: sickbeard.mainDB.Migrate4302,