Skip Failing Tests On Windows

This commit is contained in:
Unknown 2018-05-20 20:20:32 -04:00 committed by Calum Lind
parent 333c81c1d7
commit 4fd51a4ef9
14 changed files with 91 additions and 13 deletions

View File

@ -5,12 +5,12 @@ environment:
matrix:
# See: http://www.appveyor.com/docs/installed-software#python
- TOXENV: pydef
- TOXENV: flake8
- TOXENV: docs
- TOXENV: trial
- TOXENV: pydef
- TOXENV: pygtkui
- TOXENV: plugins
- TOXENV: docs
- PYTHON_VERSION: "2.7.x"
pull_requests:

View File

@ -238,7 +238,12 @@ def start_core(
import sys
import deluge.core.daemon_entry
sys.argv.extend(['-d', '-c', '%s', '-L', 'info', '-p', '%d'])
from deluge.common import windows_check
if windows_check():
sys.argv.extend(['-c', '%s', '-L', 'info', '-p', '%d'])
else
sys.argv.extend(['-d', '-c', '%s', '-L', 'info', '-p', '%d'])
try:
daemon = deluge.core.daemon_entry.start_daemon(skip_start=True)

View File

@ -14,12 +14,16 @@ from twisted.internet import defer
from twisted.internet.error import CannotListenError
import deluge.component as component
from deluge.common import windows_check
from . import common
class DaemonBase(object):
if windows_check:
skip = 'windows cant start_core not enough arguments for format string'
def common_set_up(self):
common.set_tmp_config_dir()
self.listen_port = 58900

View File

@ -11,7 +11,7 @@ from twisted.internet import defer
import deluge.component as component
from deluge import error
from deluge.common import AUTH_LEVEL_NORMAL, get_localhost_auth
from deluge.common import AUTH_LEVEL_NORMAL, get_localhost_auth, windows_check
from deluge.core.authmanager import AUTH_LEVEL_ADMIN
from deluge.ui.client import Client, DaemonSSLProxy, client
@ -77,6 +77,9 @@ class NoVersionSendingClient(Client):
class ClientTestCase(BaseTestCase, DaemonBase):
if windows_check:
skip = 'windows cant start_core not enough arguments for format string'
def set_up(self):
d = self.common_set_up()
d.addCallback(self.start_core)

View File

@ -13,7 +13,7 @@ import tarfile
from twisted.trial import unittest
from deluge.common import (VersionSplit, archive_files, fdate, fpcnt, fpeer, fsize, fspeed, ftime, get_path_size,
is_infohash, is_ip, is_ipv4, is_ipv6, is_magnet, is_url)
is_infohash, is_ip, is_ipv4, is_ipv6, is_magnet, is_url, windows_check)
from deluge.ui.translations_util import setup_translations
from .common import get_test_data_file, set_tmp_config_dir
@ -77,6 +77,8 @@ class CommonTestCase(unittest.TestCase):
self.assertTrue(is_infohash('2dc5d0e71a66fe69649a640d39cb00a259704973'))
def test_get_path_size(self):
if windows_check():
raise unittest.SkipTest('os devnull is different on windows')
self.assertTrue(get_path_size(os.devnull) == 0)
self.assertTrue(get_path_size('non-existant.file') == -1)

View File

@ -11,6 +11,7 @@ import pytest
from twisted.trial import unittest
import deluge.component as component
from deluge.common import windows_check
from deluge.configmanager import ConfigManager
from deluge.ui.translations_util import setup_translations
@ -98,6 +99,8 @@ class FilesTabTestCase(BaseTestCase):
self.assertTrue(ret)
def test_files_tab2(self):
if windows_check():
raise unittest.SkipTest('on windows \ != / for path names')
self.filestab.files_list[self.t_id] = (
{'index': 0, 'path': '1/1/test_10.txt', 'offset': 0, 'size': 13},
{'index': 1, 'path': 'test_100.txt', 'offset': 13, 'size': 14},
@ -111,6 +114,8 @@ class FilesTabTestCase(BaseTestCase):
self.assertTrue(ret)
def test_files_tab3(self):
if windows_check():
raise unittest.SkipTest('on windows \ != / for path names')
self.filestab.files_list[self.t_id] = (
{'index': 0, 'path': '1/test_10.txt', 'offset': 0, 'size': 13},
{'index': 1, 'path': 'test_100.txt', 'offset': 13, 'size': 14},
@ -144,6 +149,8 @@ class FilesTabTestCase(BaseTestCase):
self.assertTrue(ret)
def test_files_tab5(self):
if windows_check():
raise unittest.SkipTest('on windows \ != / for path names')
self.filestab.files_list[self.t_id] = (
{'index': 0, 'path': '1/test_10.txt', 'offset': 0, 'size': 13},
{'index': 1, 'path': '2/test_100.txt', 'offset': 13, 'size': 14},

View File

@ -20,6 +20,7 @@ from twisted.web.resource import Resource
from twisted.web.server import Site
from twisted.web.util import redirectTo
from deluge.common import windows_check
from deluge.httpdownloader import download_file
from deluge.log import setup_logger
from deluge.ui.web.common import compress
@ -185,6 +186,10 @@ class DownloadFileTestCase(unittest.TestCase):
return d
def test_download_with_rename(self):
if windows_check():
raise unittest.SkipTest('on windows \ != / for path names')
url = self.get_url('rename?filename=renamed')
d = download_file(url, fname('original'))
d.addCallback(self.assertEqual, fname('renamed'))
@ -192,6 +197,10 @@ class DownloadFileTestCase(unittest.TestCase):
return d
def test_download_with_rename_exists(self):
if windows_check():
raise unittest.SkipTest('on windows \ != / for path names')
open(fname('renamed'), 'w').close()
url = self.get_url('rename?filename=renamed')
d = download_file(url, fname('original'))
@ -200,6 +209,10 @@ class DownloadFileTestCase(unittest.TestCase):
return d
def test_download_with_rename_sanitised(self):
if windows_check():
raise unittest.SkipTest('on windows \ != / for path names')
url = self.get_url('rename?filename=/etc/passwd')
d = download_file(url, fname('original'))
d.addCallback(self.assertEqual, fname('passwd'))

View File

@ -13,6 +13,7 @@ import tempfile
from twisted.trial import unittest
from deluge import maketorrent
from deluge.common import windows_check
def check_torrent(filename):
@ -51,6 +52,8 @@ class MakeTorrentTestCase(unittest.TestCase):
os.remove(tmp_file)
def test_save_singlefile(self):
if windows_check():
raise unittest.SkipTest('on windows file not released')
tmp_data = tempfile.mkstemp('testdata')[1]
with open(tmp_data, 'wb') as _file:
_file.write('a' * (2314 * 1024))

View File

@ -13,6 +13,7 @@ import tempfile
from twisted.trial import unittest
from deluge import metafile
from deluge.common import windows_check
def check_torrent(filename):
@ -49,6 +50,8 @@ class MetafileTestCase(unittest.TestCase):
os.remove(tmp_file)
def test_save_singlefile(self):
if windows_check():
raise unittest.SkipTest('on windows \ != / for path names')
tmp_path = tempfile.mkstemp('testdata')[1]
with open(tmp_path, 'wb') as tmp_file:
tmp_file.write('a' * (2314 * 1024))

View File

@ -13,12 +13,13 @@ import time
from twisted.internet import reactor
from twisted.internet.task import deferLater
from twisted.trial import unittest
import deluge.component as component
import deluge.core.torrent
import deluge.tests.common as common
from deluge._libtorrent import lt
from deluge.common import utf8_encode_structure
from deluge.common import utf8_encode_structure, windows_check
from deluge.core.core import Core
from deluge.core.rpcserver import RPCServer
from deluge.core.torrent import Torrent
@ -123,6 +124,8 @@ class TorrentTestCase(BaseTestCase):
# self.print_priority_list(priorities)
def test_torrent_error_data_missing(self):
if windows_check():
raise unittest.SkipTest('unexpected end of file in bencoded string')
options = {'seed_mode': True}
filename = common.get_test_data_file('test_torrent.file.torrent')
with open(filename) as _file:
@ -139,6 +142,8 @@ class TorrentTestCase(BaseTestCase):
self.assert_state(torrent, 'Error')
def test_torrent_error_resume_original_state(self):
if windows_check():
raise unittest.SkipTest('unexpected end of file in bencoded string')
options = {'seed_mode': True, 'add_paused': True}
filename = common.get_test_data_file('test_torrent.file.torrent')
with open(filename) as _file:
@ -158,6 +163,8 @@ class TorrentTestCase(BaseTestCase):
torrent.force_recheck()
def test_torrent_error_resume_data_unaltered(self):
if windows_check():
raise unittest.SkipTest('unexpected end of file in bencoded string')
resume_data = {
'active_time': 13399, 'num_incomplete': 16777215, 'announce_to_lsd': 1, 'seed_mode': 0,
'pieces': '\x01\x01\x01\x01\x01\x01\x01\x01\x01\x01\x01\x01\x01\x01\x01\x01', 'paused': 0,

View File

@ -11,6 +11,7 @@ import pytest
import deluge.component as component
import deluge.ui.tracker_icons
from deluge.common import windows_check
from deluge.ui.tracker_icons import TrackerIcon, TrackerIcons
from . import common
@ -24,6 +25,9 @@ common.disable_new_release_check()
@pytest.mark.internet
class TrackerIconsTestCase(BaseTestCase):
if windows_check():
skip = 'cannot use os.path.samefile to compair on windows(unix only)'
def set_up(self):
self.icons = TrackerIcons()

View File

@ -10,6 +10,7 @@ from __future__ import unicode_literals
from twisted.trial import unittest
from deluge.common import windows_check
from deluge.ui.common import TorrentInfo
from . import common
@ -29,6 +30,8 @@ class UICommonTestCase(unittest.TestCase):
self.assertTrue('azcvsupdater_2.6.2.jar' in ti.files_tree)
def test_utf8_encoded_paths2(self):
if windows_check():
raise unittest.SkipTest('on windows KeyError: unicode_filenames')
filename = common.get_test_data_file('unicode_filenames.torrent')
ti = TorrentInfo(filename)

View File

@ -19,11 +19,8 @@ from twisted.internet import defer
import deluge
import deluge.component as component
import deluge.ui.console
import deluge.ui.console.cmdline.commands.quit
import deluge.ui.console.main
import deluge.ui.web.server
from deluge.common import get_localhost_auth, utf8_encode_structure
from deluge.common import get_localhost_auth, utf8_encode_structure, windows_check
from deluge.ui import ui_entry
from deluge.ui.web.server import DelugeWeb
@ -31,6 +28,11 @@ from . import common
from .basetest import BaseTestCase
from .daemon_base import DaemonBase
if not windows_check():
import deluge.ui.console
import deluge.ui.console.cmdline.commands.quit
import deluge.ui.console.main
DEBUG_COMMAND = False
sys_stdout = sys.stdout
@ -96,6 +98,9 @@ class UIWithDaemonBaseTestCase(UIBaseTestCase, DaemonBase):
class DelugeEntryTestCase(BaseTestCase):
if windows_check():
skip = 'cannot test console ui on windows'
def set_up(self):
common.set_tmp_config_dir()
return component.start()
@ -229,6 +234,9 @@ class WebUIBaseTestCase(UIBaseTestCase):
class WebUIScriptEntryTestCase(BaseTestCase, WebUIBaseTestCase):
if windows_check():
skip = 'cannot test console ui on windows'
def __init__(self, testname):
super(WebUIScriptEntryTestCase, self).__init__(testname)
WebUIBaseTestCase.__init__(self)
@ -245,6 +253,9 @@ class WebUIScriptEntryTestCase(BaseTestCase, WebUIBaseTestCase):
class WebUIDelugeScriptEntryTestCase(BaseTestCase, WebUIBaseTestCase):
if windows_check():
skip = 'cannot test console ui on windows'
def __init__(self, testname):
super(WebUIDelugeScriptEntryTestCase, self).__init__(testname)
WebUIBaseTestCase.__init__(self)
@ -354,6 +365,9 @@ class ConsoleUIWithDaemonBaseTestCase(UIWithDaemonBaseTestCase):
class ConsoleScriptEntryWithDaemonTestCase(BaseTestCase, ConsoleUIWithDaemonBaseTestCase):
if windows_check():
skip = 'cannot test console ui on windows'
def __init__(self, testname):
super(ConsoleScriptEntryWithDaemonTestCase, self).__init__(testname)
ConsoleUIWithDaemonBaseTestCase.__init__(self)
@ -377,6 +391,9 @@ class ConsoleScriptEntryWithDaemonTestCase(BaseTestCase, ConsoleUIWithDaemonBase
class ConsoleScriptEntryTestCase(BaseTestCase, ConsoleUIBaseTestCase):
if windows_check():
skip = 'cannot test console ui on windows'
def __init__(self, testname):
super(ConsoleScriptEntryTestCase, self).__init__(testname)
ConsoleUIBaseTestCase.__init__(self)
@ -393,6 +410,9 @@ class ConsoleScriptEntryTestCase(BaseTestCase, ConsoleUIBaseTestCase):
class ConsoleDelugeScriptEntryTestCase(BaseTestCase, ConsoleUIBaseTestCase):
if windows_check():
skip = 'cannot test console ui on windows'
def __init__(self, testname):
super(ConsoleDelugeScriptEntryTestCase, self).__init__(testname)
ConsoleUIBaseTestCase.__init__(self)

View File

@ -57,9 +57,13 @@ class Mock(object):
return Mock()
MOCK_MODULES = ['deluge.ui.gtkui.gtkui', 'deluge._libtorrent',
MOCK_MODULES = [
'deluge.ui.gtkui.gtkui', 'deluge._libtorrent',
'libtorrent', 'psyco',
'pygtk', 'gtk', 'gobject', 'gtk.gdk', 'pango', 'cairo', 'pangocairo']
'pygtk', 'gtk', 'gobject', 'gtk.gdk', 'pango', 'cairo', 'pangocairo',
'curses', 'win32api', 'win32file', 'win32process', 'win32pipe',
'pywintypes', 'win32con', 'win32event',
]
for mod_name in MOCK_MODULES:
sys.modules[mod_name] = Mock()