Code cleanup - Pep8
This commit is contained in:
parent
2d850f7106
commit
8dd0249af9
@ -1,11 +1,34 @@
|
||||
#!/usr/bin/env python3
|
||||
|
||||
# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et:
|
||||
|
||||
# Copyright 2014-2015 Florian Bruhin (The Compiler) <mail@qutebrowser.org>
|
||||
#
|
||||
# This file is part of qutebrowser.
|
||||
#
|
||||
# qutebrowser 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.
|
||||
#
|
||||
# qutebrowser 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 qutebrowser. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
"""Tests for qutebrowser.browser.adblock"""
|
||||
|
||||
import pytest
|
||||
from qutebrowser.browser import adblock
|
||||
from qutebrowser.config import config
|
||||
from qutebrowser.utils import objreg
|
||||
import os
|
||||
import zipfile
|
||||
import io
|
||||
|
||||
# TODO Should I use it ? And how ?
|
||||
# @pytest.yield_fixture
|
||||
# def default_config():
|
||||
# """Fixture that provides and registers an empty default config object."""
|
||||
@ -14,57 +37,61 @@ import io
|
||||
# yield config_obj
|
||||
# objreg.delete('config')
|
||||
|
||||
|
||||
def create_text_files(files_names, directory):
|
||||
"""Returns a list of created text files"""
|
||||
"""Returns a list of text files created
|
||||
with given names in given directory"""
|
||||
directory = str(directory)
|
||||
created_files = []
|
||||
for file_name in files_names:
|
||||
test_file = os.path.join(directory, file_name)
|
||||
with open(test_file, 'w') as f :
|
||||
with open(test_file, 'w') as f:
|
||||
f.write('inside ' + file_name)
|
||||
created_files.append(test_file)
|
||||
return created_files
|
||||
|
||||
|
||||
def create_zipfile(files_names, directory):
|
||||
"""Returns a zipfile populated with created files and its name"""
|
||||
directory = str(directory)
|
||||
files = create_text_files(files_names, directory)
|
||||
# include created files in a ZipFile
|
||||
zipfile_name = os.path.join(directory,'test.zip')
|
||||
zipfile_name = os.path.join(directory, 'test.zip')
|
||||
with zipfile.ZipFile(zipfile_name, 'w') as zf:
|
||||
for file_name in files :
|
||||
for file_name in files:
|
||||
zf.write(file_name, arcname=os.path.basename(file_name))
|
||||
# Removes path from file name
|
||||
return zf, zipfile_name
|
||||
|
||||
class TestGuessZipFilename :
|
||||
|
||||
class TestGuessZipFilename:
|
||||
""" Test function adblock.guess_zip_filename() """
|
||||
|
||||
def test_with_single_file(self, tmpdir):
|
||||
"""Zip provided only contains a single file"""
|
||||
zf = create_zipfile(['testa'], tmpdir)[0]
|
||||
assert adblock.guess_zip_filename(zf) == 'testa'
|
||||
# guess_zip_filename doesn't include the root slash /
|
||||
# whereas os.path.join() does, so we exclude first character
|
||||
zf = create_zipfile(['test_a'], tmpdir)[0]
|
||||
assert adblock.guess_zip_filename(zf) == 'test_a'
|
||||
|
||||
def test_with_multiple_files(self, tmpdir):
|
||||
"""Zip provided contains multiple files including hosts"""
|
||||
zf = create_zipfile(['testa','testb','hosts','testc'], tmpdir)[0]
|
||||
names = ['test_a', 'test_b', 'hosts', 'test_c']
|
||||
zf = create_zipfile(names, tmpdir)[0]
|
||||
assert adblock.guess_zip_filename(zf) == 'hosts'
|
||||
# guess_zip_filename doesn't include the root slash /
|
||||
# whereas os.path.join() does, so we exclude first character
|
||||
|
||||
def test_without_hosts_file(self, tmpdir):
|
||||
"""Zip provided does not contain any hosts file"""
|
||||
zf = create_zipfile(['testa','testb','testd','testc'], tmpdir)[0]
|
||||
names = ['test_a', 'test_b', 'test_d', 'test_c']
|
||||
zf = create_zipfile(names, tmpdir)[0]
|
||||
with pytest.raises(FileNotFoundError):
|
||||
adblock.guess_zip_filename(zf)
|
||||
|
||||
class TestGetFileObj :
|
||||
|
||||
class TestGetFileObj:
|
||||
"""Test Function adblock.get_fileobj()"""
|
||||
|
||||
def test_with_zipfile(self, tmpdir):
|
||||
zf_name = create_zipfile(['testa','testb','hosts','testc'], tmpdir)[1]
|
||||
names = ['test_a', 'test_b', 'hosts', 'test_c']
|
||||
zf_name = create_zipfile(names, tmpdir)[1]
|
||||
zipobj = open(zf_name, 'rb')
|
||||
assert adblock.get_fileobj(zipobj).read() == "inside hosts"
|
||||
|
||||
@ -72,36 +99,34 @@ class TestGetFileObj :
|
||||
test_file = open(create_text_files(['testfile'], tmpdir)[0], 'rb')
|
||||
assert adblock.get_fileobj(test_file).read() == "inside testfile"
|
||||
|
||||
class TestIsWhitelistedHost :
|
||||
|
||||
class TestIsWhitelistedHost:
|
||||
"""Test function adblock.is_whitelisted_host"""
|
||||
|
||||
# FIXME Error since we deleted host-blocking-whitelist
|
||||
# If we don't remove host-block-whitelist, test behaves as in a mismatch
|
||||
# def test_with_no_whitelist(self):
|
||||
# config_obj = config.ConfigManager(configdir=None, fname=None, relaxed=True)
|
||||
# config_obj.remove_option('content','host-blocking-whitelist')
|
||||
# objreg.register('config', config_obj)
|
||||
# assert adblock.is_whitelisted_host('pimpmytest.com') == False
|
||||
# objreg.delete('config')
|
||||
|
||||
def test_with_no_whitelist(self):
|
||||
# FIXME Behaves like a mismatch
|
||||
config_obj = config.ConfigManager(configdir=None, fname=None, relaxed=True)
|
||||
default_config.remove_option('content','host-blocking-whitelist')
|
||||
objreg.register('config', config_obj)
|
||||
assert adblock.is_whitelisted_host('pimpmytest.com') == False
|
||||
objreg.delete('config')
|
||||
|
||||
def test_with_match(self):
|
||||
config_obj = config.ConfigManager(configdir=None, fname=None, relaxed=True)
|
||||
config_obj.set('conf','content','host-blocking-whitelist','qutebrowser.org')
|
||||
config_obj.set('conf', 'content', 'host-blocking-whitelist', 'qutebrowser.org')
|
||||
objreg.register('config', config_obj)
|
||||
assert adblock.is_whitelisted_host('qutebrowser.org') == True
|
||||
objreg.delete('config')
|
||||
|
||||
def test_without_match(self):
|
||||
config_obj = config.ConfigManager(configdir=None, fname=None, relaxed=True)
|
||||
config_obj.set('conf','content','host-blocking-whitelist','cutebrowser.org')
|
||||
config_obj.set('conf', 'content', 'host-blocking-whitelist', 'cutebrowser.org')
|
||||
objreg.register('config', config_obj)
|
||||
assert adblock.is_whitelisted_host('qutebrowser.org') == False
|
||||
objreg.delete('config')
|
||||
|
||||
class TestHostBlocker :
|
||||
|
||||
class TestHostBlocker:
|
||||
# TODO
|
||||
pass
|
||||
#testBlocker = adblock.HostBlocker()
|
||||
|
Loading…
Reference in New Issue
Block a user