mirror of
https://github.com/SickGear/SickGear.git
synced 2025-01-21 00:53:37 +00:00
7165df7405
Used regex checks with javascript popup, for checking if valid imdb csv watchlist. Added test/test_tvdb_api.py for testing the tvdb api for retrieving shows by IMDB id. TODO: Help for assisting users in getting the correct IMDB url. maybe, make interval configurable First changes for imdb watchlist checker Thrown the couch code overboard and created my own version of an imdb watchlist scraper Added IMDB thread and test values with an IMDB csv url. These values should be replaced by front end UI settings. - Removed some tracelogs when unable to download watchlist - Added settings for enabling and setting of the watchlist csv url TODO: - create UI for setting from frontend - Implement frontend and backend checks for validating the csv url Default interval is 1 hour.
236 lines
7 KiB
Python
236 lines
7 KiB
Python
# coding=UTF-8
|
|
# Author: Dennis Lutter <lad1337@gmail.com>
|
|
# URL: http://code.google.com/p/sickbeard/
|
|
#
|
|
# This file is part of SickRage.
|
|
#
|
|
# SickRage 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 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# SickRage 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 SickRage. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
from __future__ import with_statement
|
|
|
|
import unittest
|
|
|
|
import sqlite3
|
|
|
|
import sys
|
|
import os.path
|
|
sys.path.append(os.path.abspath('..'))
|
|
sys.path.append(os.path.abspath('../lib'))
|
|
|
|
import sickbeard
|
|
import shutil
|
|
|
|
from sickbeard import encodingKludge as ek, providers, tvcache
|
|
from sickbeard import db
|
|
from sickbeard.databases import mainDB
|
|
from sickbeard.databases import cache_db
|
|
|
|
#=================
|
|
# test globals
|
|
#=================
|
|
TESTDIR = os.path.abspath('.')
|
|
TESTDBNAME = "sickbeard.db"
|
|
TESTCACHEDBNAME = "cache.db"
|
|
|
|
|
|
SHOWNAME = u"show name"
|
|
SEASON = 4
|
|
EPISODE = 2
|
|
FILENAME = u"show name - s0" + str(SEASON) + "e0" + str(EPISODE) + ".mkv"
|
|
FILEDIR = os.path.join(TESTDIR, SHOWNAME)
|
|
FILEPATH = os.path.join(FILEDIR, FILENAME)
|
|
|
|
SHOWDIR = os.path.join(TESTDIR, SHOWNAME + " final")
|
|
|
|
#sickbeard.logger.sb_log_instance = sickbeard.logger.SBRotatingLogHandler(os.path.join(TESTDIR, 'sickbeard.log'), sickbeard.logger.NUM_LOGS, sickbeard.logger.LOG_SIZE)
|
|
sickbeard.logger.SBRotatingLogHandler.log_file = os.path.join(os.path.join(TESTDIR, 'Logs'), 'test_sickbeard.log')
|
|
|
|
|
|
#=================
|
|
# prepare env functions
|
|
#=================
|
|
def createTestLogFolder():
|
|
if not os.path.isdir(sickbeard.LOG_DIR):
|
|
os.mkdir(sickbeard.LOG_DIR)
|
|
|
|
def createTestCacheFolder():
|
|
if not os.path.isdir(sickbeard.CACHE_DIR):
|
|
os.mkdir(sickbeard.CACHE_DIR)
|
|
|
|
# call env functions at appropriate time during sickbeard var setup
|
|
|
|
#=================
|
|
# sickbeard globals
|
|
#=================
|
|
sickbeard.SYS_ENCODING = 'UTF-8'
|
|
sickbeard.showList = []
|
|
sickbeard.QUALITY_DEFAULT = 4 # hdtv
|
|
sickbeard.FLATTEN_FOLDERS_DEFAULT = 0
|
|
|
|
sickbeard.NAMING_PATTERN = ''
|
|
sickbeard.NAMING_ABD_PATTERN = ''
|
|
sickbeard.NAMING_SPORTS_PATTERN = ''
|
|
sickbeard.NAMING_MULTI_EP = 1
|
|
|
|
|
|
sickbeard.PROVIDER_ORDER = ["sick_beard_index"]
|
|
sickbeard.newznabProviderList = providers.getNewznabProviderList("'Sick Beard Index|http://lolo.sickbeard.com/|0|5030,5040,5060|0|eponly|0!!!NZBs.org|https://nzbs.org/||5030,5040,5060,5070,5090|0|eponly|0!!!Usenet-Crawler|https://www.usenet-crawler.com/||5030,5040,5060|0|eponly|0'")
|
|
sickbeard.providerList = providers.makeProviderList()
|
|
|
|
sickbeard.PROG_DIR = os.path.abspath('..')
|
|
sickbeard.DATA_DIR = sickbeard.PROG_DIR
|
|
sickbeard.LOG_DIR = os.path.join(TESTDIR, 'Logs')
|
|
createTestLogFolder()
|
|
sickbeard.logger.sb_log_instance.initLogging(False)
|
|
|
|
sickbeard.CACHE_DIR = os.path.join(TESTDIR, 'cache')
|
|
createTestCacheFolder()
|
|
|
|
#=================
|
|
# dummy functions
|
|
#=================
|
|
def _dummy_saveConfig():
|
|
return True
|
|
# this overrides the sickbeard save_config which gets called during a db upgrade
|
|
# this might be considered a hack
|
|
mainDB.sickbeard.save_config = _dummy_saveConfig
|
|
|
|
|
|
# the real one tries to contact tvdb just stop it from getting more info on the ep
|
|
def _fake_specifyEP(self, season, episode):
|
|
pass
|
|
|
|
sickbeard.tv.TVEpisode.specifyEpisode = _fake_specifyEP
|
|
|
|
|
|
#=================
|
|
# test classes
|
|
#=================
|
|
class SickbeardTestDBCase(unittest.TestCase):
|
|
def setUp(self):
|
|
sickbeard.showList = []
|
|
setUp_test_db()
|
|
setUp_test_episode_file()
|
|
setUp_test_show_dir()
|
|
|
|
def tearDown(self):
|
|
sickbeard.showList = []
|
|
tearDown_test_db()
|
|
tearDown_test_episode_file()
|
|
tearDown_test_show_dir()
|
|
|
|
|
|
class TestDBConnection(db.DBConnection, object):
|
|
|
|
def __init__(self, dbFileName=TESTDBNAME):
|
|
dbFileName = os.path.join(TESTDIR, dbFileName)
|
|
super(TestDBConnection, self).__init__(dbFileName)
|
|
|
|
|
|
class TestCacheDBConnection(TestDBConnection, object):
|
|
|
|
def __init__(self, providerName):
|
|
db.DBConnection.__init__(self, os.path.join(TESTDIR, TESTCACHEDBNAME))
|
|
|
|
# Create the table if it's not already there
|
|
try:
|
|
sql = "CREATE TABLE " + providerName + " (name TEXT, season NUMERIC, episodes TEXT, indexerid NUMERIC, url TEXT, time NUMERIC, quality TEXT);"
|
|
self.connection.execute(sql)
|
|
self.connection.commit()
|
|
except sqlite3.OperationalError, e:
|
|
if str(e) != "table " + providerName + " already exists":
|
|
raise
|
|
|
|
# Create the table if it's not already there
|
|
try:
|
|
sql = "CREATE TABLE lastUpdate (provider TEXT, time NUMERIC);"
|
|
self.connection.execute(sql)
|
|
self.connection.commit()
|
|
except sqlite3.OperationalError, e:
|
|
if str(e) != "table lastUpdate already exists":
|
|
raise
|
|
|
|
# this will override the normal db connection
|
|
sickbeard.db.DBConnection = TestDBConnection
|
|
sickbeard.tvcache.CacheDBConnection = TestCacheDBConnection
|
|
|
|
|
|
#=================
|
|
# test functions
|
|
#=================
|
|
def setUp_test_db():
|
|
"""upgrades the db to the latest version
|
|
"""
|
|
# upgrading the db
|
|
db.upgradeDatabase(db.DBConnection(), mainDB.InitialSchema)
|
|
# fix up any db problems
|
|
db.sanityCheckDatabase(db.DBConnection(), mainDB.MainSanityCheck)
|
|
|
|
#and for cache.b too
|
|
db.upgradeDatabase(db.DBConnection("cache.db"), cache_db.InitialSchema)
|
|
|
|
|
|
def tearDown_test_db():
|
|
"""Deletes the test db
|
|
although this seams not to work on my system it leaves me with an zero kb file
|
|
"""
|
|
# uncomment next line so leave the db intact between test and at the end
|
|
return False
|
|
if os.path.exists(os.path.join(TESTDIR, TESTDBNAME)):
|
|
os.remove(os.path.join(TESTDIR, TESTDBNAME))
|
|
if os.path.exists(os.path.join(TESTDIR, TESTCACHEDBNAME)):
|
|
os.remove(os.path.join(TESTDIR, TESTCACHEDBNAME))
|
|
|
|
|
|
def setUp_test_episode_file():
|
|
if not os.path.exists(FILEDIR):
|
|
os.makedirs(FILEDIR)
|
|
|
|
try:
|
|
with open(FILEPATH, 'w') as f:
|
|
f.write("foo bar")
|
|
except EnvironmentError:
|
|
print "Unable to set up test episode"
|
|
raise
|
|
|
|
|
|
def tearDown_test_episode_file():
|
|
if os.path.exists(FILEDIR):
|
|
shutil.rmtree(FILEDIR)
|
|
|
|
|
|
def setUp_test_show_dir():
|
|
if not os.path.exists(SHOWDIR):
|
|
os.makedirs(SHOWDIR)
|
|
|
|
|
|
def tearDown_test_show_dir():
|
|
if os.path.exists(SHOWDIR):
|
|
shutil.rmtree(SHOWDIR)
|
|
|
|
tearDown_test_db()
|
|
|
|
if __name__ == '__main__':
|
|
print "=================="
|
|
print "Dont call this directly"
|
|
print "=================="
|
|
print "you might want to call"
|
|
|
|
dirList = os.listdir(TESTDIR)
|
|
for fname in dirList:
|
|
if (fname.find("_test") > 0) and (fname.find("pyc") < 0):
|
|
print "- " + fname
|
|
|
|
print "=================="
|
|
print "or just call all_tests.py"
|