2017-12-03 08:00:23 +01:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
#
|
2019-02-01 03:05:56 +01:00
|
|
|
# Copyright (C) 2019 Chris Caron <lead2gold@gmail.com>
|
|
|
|
# All rights reserved.
|
2017-12-03 08:00:23 +01:00
|
|
|
#
|
2019-02-01 03:05:56 +01:00
|
|
|
# This code is licensed under the MIT License.
|
2017-12-03 08:00:23 +01:00
|
|
|
#
|
2019-02-01 03:05:56 +01:00
|
|
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
# of this software and associated documentation files(the "Software"), to deal
|
|
|
|
# in the Software without restriction, including without limitation the rights
|
|
|
|
# to use, copy, modify, merge, publish, distribute, sublicense, and / or sell
|
|
|
|
# copies of the Software, and to permit persons to whom the Software is
|
|
|
|
# furnished to do so, subject to the following conditions :
|
2017-12-03 08:00:23 +01:00
|
|
|
#
|
2019-02-01 03:05:56 +01:00
|
|
|
# The above copyright notice and this permission notice shall be included in
|
|
|
|
# all copies or substantial portions of the Software.
|
2017-12-03 08:00:23 +01:00
|
|
|
#
|
2019-02-01 03:05:56 +01:00
|
|
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE
|
|
|
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
# THE SOFTWARE.
|
2017-11-29 05:14:51 +01:00
|
|
|
|
|
|
|
from __future__ import print_function
|
2017-12-03 08:00:23 +01:00
|
|
|
try:
|
|
|
|
# Python 2.7
|
|
|
|
from urllib import unquote
|
|
|
|
|
|
|
|
except ImportError:
|
|
|
|
# Python 3.x
|
|
|
|
from urllib.parse import unquote
|
|
|
|
|
2017-11-29 05:14:51 +01:00
|
|
|
from apprise import utils
|
|
|
|
|
|
|
|
|
|
|
|
def test_parse_url():
|
|
|
|
"utils: parse_url() testing """
|
|
|
|
|
|
|
|
result = utils.parse_url('http://hostname')
|
|
|
|
assert(result['schema'] == 'http')
|
|
|
|
assert(result['host'] == 'hostname')
|
|
|
|
assert(result['port'] is None)
|
|
|
|
assert(result['user'] is None)
|
|
|
|
assert(result['password'] is None)
|
|
|
|
assert(result['fullpath'] is None)
|
|
|
|
assert(result['path'] is None)
|
|
|
|
assert(result['query'] is None)
|
|
|
|
assert(result['url'] == 'http://hostname')
|
|
|
|
assert(result['qsd'] == {})
|
|
|
|
|
|
|
|
result = utils.parse_url('http://hostname/')
|
|
|
|
assert(result['schema'] == 'http')
|
|
|
|
assert(result['host'] == 'hostname')
|
|
|
|
assert(result['port'] is None)
|
|
|
|
assert(result['user'] is None)
|
|
|
|
assert(result['password'] is None)
|
|
|
|
assert(result['fullpath'] == '/')
|
|
|
|
assert(result['path'] == '/')
|
|
|
|
assert(result['query'] is None)
|
|
|
|
assert(result['url'] == 'http://hostname/')
|
|
|
|
assert(result['qsd'] == {})
|
|
|
|
|
|
|
|
result = utils.parse_url('hostname')
|
|
|
|
assert(result['schema'] == 'http')
|
|
|
|
assert(result['host'] == 'hostname')
|
|
|
|
assert(result['port'] is None)
|
|
|
|
assert(result['user'] is None)
|
|
|
|
assert(result['password'] is None)
|
|
|
|
assert(result['fullpath'] is None)
|
|
|
|
assert(result['path'] is None)
|
|
|
|
assert(result['query'] is None)
|
|
|
|
assert(result['url'] == 'http://hostname')
|
|
|
|
assert(result['qsd'] == {})
|
|
|
|
|
|
|
|
result = utils.parse_url('http://hostname////')
|
|
|
|
assert(result['schema'] == 'http')
|
|
|
|
assert(result['host'] == 'hostname')
|
|
|
|
assert(result['port'] is None)
|
|
|
|
assert(result['user'] is None)
|
|
|
|
assert(result['password'] is None)
|
|
|
|
assert(result['fullpath'] == '/')
|
|
|
|
assert(result['path'] == '/')
|
|
|
|
assert(result['query'] is None)
|
|
|
|
assert(result['url'] == 'http://hostname/')
|
|
|
|
assert(result['qsd'] == {})
|
|
|
|
|
|
|
|
result = utils.parse_url('http://hostname:40////')
|
|
|
|
assert(result['schema'] == 'http')
|
|
|
|
assert(result['host'] == 'hostname')
|
|
|
|
assert(result['port'] == 40)
|
|
|
|
assert(result['user'] is None)
|
|
|
|
assert(result['password'] is None)
|
|
|
|
assert(result['fullpath'] == '/')
|
|
|
|
assert(result['path'] == '/')
|
|
|
|
assert(result['query'] is None)
|
|
|
|
assert(result['url'] == 'http://hostname:40/')
|
|
|
|
assert(result['qsd'] == {})
|
|
|
|
|
|
|
|
result = utils.parse_url('HTTP://HoStNaMe:40/test.php')
|
|
|
|
assert(result['schema'] == 'http')
|
|
|
|
assert(result['host'] == 'HoStNaMe')
|
|
|
|
assert(result['port'] == 40)
|
|
|
|
assert(result['user'] is None)
|
|
|
|
assert(result['password'] is None)
|
|
|
|
assert(result['fullpath'] == '/test.php')
|
|
|
|
assert(result['path'] == '/')
|
|
|
|
assert(result['query'] == 'test.php')
|
|
|
|
assert(result['url'] == 'http://HoStNaMe:40/test.php')
|
|
|
|
assert(result['qsd'] == {})
|
|
|
|
|
|
|
|
result = utils.parse_url('HTTPS://user@hostname/test.py')
|
|
|
|
assert(result['schema'] == 'https')
|
|
|
|
assert(result['host'] == 'hostname')
|
|
|
|
assert(result['port'] is None)
|
|
|
|
assert(result['user'] == 'user')
|
|
|
|
assert(result['password'] is None)
|
|
|
|
assert(result['fullpath'] == '/test.py')
|
|
|
|
assert(result['path'] == '/')
|
|
|
|
assert(result['query'] == 'test.py')
|
|
|
|
assert(result['url'] == 'https://user@hostname/test.py')
|
|
|
|
assert(result['qsd'] == {})
|
|
|
|
|
|
|
|
result = utils.parse_url(' HTTPS://///user@@@hostname///test.py ')
|
|
|
|
assert(result['schema'] == 'https')
|
|
|
|
assert(result['host'] == 'hostname')
|
|
|
|
assert(result['port'] is None)
|
|
|
|
assert(result['user'] == 'user')
|
|
|
|
assert(result['password'] is None)
|
|
|
|
assert(result['fullpath'] == '/test.py')
|
|
|
|
assert(result['path'] == '/')
|
|
|
|
assert(result['query'] == 'test.py')
|
|
|
|
assert(result['url'] == 'https://user@hostname/test.py')
|
|
|
|
assert(result['qsd'] == {})
|
|
|
|
|
|
|
|
result = utils.parse_url(
|
|
|
|
'HTTPS://user:password@otherHost/full///path/name/',
|
|
|
|
)
|
|
|
|
assert(result['schema'] == 'https')
|
|
|
|
assert(result['host'] == 'otherHost')
|
|
|
|
assert(result['port'] is None)
|
|
|
|
assert(result['user'] == 'user')
|
|
|
|
assert(result['password'] == 'password')
|
|
|
|
assert(result['fullpath'] == '/full/path/name/')
|
|
|
|
assert(result['path'] == '/full/path/name/')
|
|
|
|
assert(result['query'] is None)
|
|
|
|
assert(result['url'] == 'https://user:password@otherHost/full/path/name/')
|
|
|
|
assert(result['qsd'] == {})
|
|
|
|
|
|
|
|
# Handle garbage
|
|
|
|
assert(utils.parse_url(None) is None)
|
|
|
|
|
|
|
|
result = utils.parse_url(
|
|
|
|
'mailto://user:password@otherHost/lead2gold@gmail.com' +
|
|
|
|
'?from=test@test.com&name=Chris%20Caron&format=text'
|
|
|
|
)
|
|
|
|
assert(result['schema'] == 'mailto')
|
|
|
|
assert(result['host'] == 'otherHost')
|
|
|
|
assert(result['port'] is None)
|
|
|
|
assert(result['user'] == 'user')
|
|
|
|
assert(result['password'] == 'password')
|
|
|
|
assert(unquote(result['fullpath']) == '/lead2gold@gmail.com')
|
|
|
|
assert(result['path'] == '/')
|
|
|
|
assert(unquote(result['query']) == 'lead2gold@gmail.com')
|
|
|
|
assert(unquote(
|
|
|
|
result['url']) ==
|
|
|
|
'mailto://user:password@otherHost/lead2gold@gmail.com')
|
|
|
|
assert(len(result['qsd']) == 3)
|
|
|
|
assert('name' in result['qsd'])
|
|
|
|
assert(unquote(result['qsd']['name']) == 'Chris Caron')
|
|
|
|
assert('from' in result['qsd'])
|
|
|
|
assert(unquote(result['qsd']['from']) == 'test@test.com')
|
|
|
|
assert('format' in result['qsd'])
|
|
|
|
assert(unquote(result['qsd']['format']) == 'text')
|
|
|
|
|
|
|
|
# Test Passwords with question marks ?; not supported
|
|
|
|
result = utils.parse_url(
|
|
|
|
'http://user:pass.with.?question@host'
|
|
|
|
)
|
|
|
|
assert(result is None)
|
|
|
|
|
2017-12-03 08:00:23 +01:00
|
|
|
# just hostnames
|
|
|
|
result = utils.parse_url(
|
|
|
|
'nuxref.com'
|
|
|
|
)
|
|
|
|
assert(result['schema'] == 'http')
|
|
|
|
assert(result['host'] == 'nuxref.com')
|
|
|
|
assert(result['port'] is None)
|
|
|
|
assert(result['user'] is None)
|
|
|
|
assert(result['password'] is None)
|
|
|
|
assert(result['fullpath'] is None)
|
|
|
|
assert(result['path'] is None)
|
|
|
|
assert(result['query'] is None)
|
|
|
|
assert(result['url'] == 'http://nuxref.com')
|
|
|
|
assert(result['qsd'] == {})
|
|
|
|
|
|
|
|
# just host and path
|
|
|
|
result = utils.parse_url(
|
|
|
|
'invalid/host'
|
|
|
|
)
|
|
|
|
assert(result['schema'] == 'http')
|
|
|
|
assert(result['host'] == 'invalid')
|
|
|
|
assert(result['port'] is None)
|
|
|
|
assert(result['user'] is None)
|
|
|
|
assert(result['password'] is None)
|
|
|
|
assert(result['fullpath'] == '/host')
|
|
|
|
assert(result['path'] == '/')
|
|
|
|
assert(result['query'] == 'host')
|
|
|
|
assert(result['url'] == 'http://invalid/host')
|
|
|
|
assert(result['qsd'] == {})
|
|
|
|
|
|
|
|
# just all out invalid
|
|
|
|
assert(utils.parse_url('?') is None)
|
|
|
|
assert(utils.parse_url('/') is None)
|
|
|
|
|
|
|
|
# A default port of zero is still considered valid, but
|
|
|
|
# is removed in the response.
|
|
|
|
result = utils.parse_url('http://nuxref.com:0')
|
|
|
|
assert(result['schema'] == 'http')
|
|
|
|
assert(result['host'] == 'nuxref.com')
|
|
|
|
assert(result['port'] is None)
|
|
|
|
assert(result['user'] is None)
|
|
|
|
assert(result['password'] is None)
|
|
|
|
assert(result['fullpath'] is None)
|
|
|
|
assert(result['path'] is None)
|
|
|
|
assert(result['query'] is None)
|
|
|
|
assert(result['url'] == 'http://nuxref.com')
|
|
|
|
assert(result['qsd'] == {})
|
|
|
|
|
2017-11-29 05:14:51 +01:00
|
|
|
|
|
|
|
def test_parse_bool():
|
|
|
|
"utils: parse_bool() testing """
|
|
|
|
|
|
|
|
assert(utils.parse_bool('Enabled', None) is True)
|
|
|
|
assert(utils.parse_bool('Disabled', None) is False)
|
|
|
|
assert(utils.parse_bool('Allow', None) is True)
|
|
|
|
assert(utils.parse_bool('Deny', None) is False)
|
|
|
|
assert(utils.parse_bool('Yes', None) is True)
|
|
|
|
assert(utils.parse_bool('YES', None) is True)
|
|
|
|
assert(utils.parse_bool('Always', None) is True)
|
|
|
|
assert(utils.parse_bool('No', None) is False)
|
|
|
|
assert(utils.parse_bool('NO', None) is False)
|
|
|
|
assert(utils.parse_bool('NEVER', None) is False)
|
|
|
|
assert(utils.parse_bool('TrUE', None) is True)
|
|
|
|
assert(utils.parse_bool('tRUe', None) is True)
|
|
|
|
assert(utils.parse_bool('FAlse', None) is False)
|
|
|
|
assert(utils.parse_bool('F', None) is False)
|
|
|
|
assert(utils.parse_bool('T', None) is True)
|
|
|
|
assert(utils.parse_bool('0', None) is False)
|
|
|
|
assert(utils.parse_bool('1', None) is True)
|
|
|
|
assert(utils.parse_bool('True', None) is True)
|
|
|
|
assert(utils.parse_bool('Yes', None) is True)
|
|
|
|
assert(utils.parse_bool(1, None) is True)
|
|
|
|
assert(utils.parse_bool(0, None) is False)
|
|
|
|
assert(utils.parse_bool(True, None) is True)
|
|
|
|
assert(utils.parse_bool(False, None) is False)
|
|
|
|
|
|
|
|
# only the int of 0 will return False since the function
|
|
|
|
# casts this to a boolean
|
|
|
|
assert(utils.parse_bool(2, None) is True)
|
|
|
|
# An empty list is still false
|
|
|
|
assert(utils.parse_bool([], None) is False)
|
|
|
|
# But a list that contains something is True
|
|
|
|
assert(utils.parse_bool(['value', ], None) is True)
|
|
|
|
|
|
|
|
# Use Default (which is False)
|
|
|
|
assert(utils.parse_bool('OhYeah') is False)
|
|
|
|
# Adjust Default and get a different result
|
|
|
|
assert(utils.parse_bool('OhYeah', True) is True)
|
|
|
|
|
|
|
|
|
2017-12-06 06:35:03 +01:00
|
|
|
def test_is_hostname():
|
|
|
|
"""
|
|
|
|
API: is_hostname() function
|
|
|
|
|
|
|
|
"""
|
|
|
|
# Valid Hostnames
|
|
|
|
assert utils.is_hostname('yahoo.ca') is True
|
|
|
|
assert utils.is_hostname('yahoo.ca.') is True
|
|
|
|
assert utils.is_hostname('valid-dashes-in-host.ca') is True
|
|
|
|
assert utils.is_hostname('valid-underscores_in_host.ca') is True
|
|
|
|
|
|
|
|
# Invalid Hostnames
|
|
|
|
assert utils.is_hostname('invalid-characters_#^.ca') is False
|
|
|
|
assert utils.is_hostname(' spaces ') is False
|
|
|
|
assert utils.is_hostname(' ') is False
|
|
|
|
assert utils.is_hostname('') is False
|
|
|
|
|
|
|
|
|
2017-11-29 05:14:51 +01:00
|
|
|
def test_parse_list():
|
|
|
|
"utils: parse_list() testing """
|
|
|
|
|
|
|
|
# A simple single array entry (As str)
|
|
|
|
results = utils.parse_list(
|
|
|
|
'.mkv,.avi,.divx,.xvid,.mov,.wmv,.mp4,.mpg,.mpeg,.vob,.iso')
|
|
|
|
|
2017-12-03 08:00:23 +01:00
|
|
|
assert(results == sorted([
|
2017-11-29 05:14:51 +01:00
|
|
|
'.divx', '.iso', '.mkv', '.mov', '.mpg', '.avi', '.mpeg', '.vob',
|
|
|
|
'.xvid', '.wmv', '.mp4',
|
2017-12-03 08:00:23 +01:00
|
|
|
]))
|
2017-11-29 05:14:51 +01:00
|
|
|
|
2017-12-03 08:00:23 +01:00
|
|
|
class StrangeObject(object):
|
|
|
|
def __str__(self):
|
|
|
|
return '.avi'
|
2017-11-29 05:14:51 +01:00
|
|
|
# Now 2 lists with lots of duplicates and other delimiters
|
|
|
|
results = utils.parse_list(
|
|
|
|
'.mkv,.avi,.divx,.xvid,.mov,.wmv,.mp4,.mpg .mpeg,.vob,,; ;',
|
2017-12-03 08:00:23 +01:00
|
|
|
('.mkv,.avi,.divx,.xvid,.mov ', ' .wmv,.mp4;.mpg,.mpeg,'),
|
|
|
|
'.vob,.iso', ['.vob', ['.vob', '.mkv', StrangeObject(), ], ],
|
|
|
|
StrangeObject())
|
2017-11-29 05:14:51 +01:00
|
|
|
|
2017-12-03 08:00:23 +01:00
|
|
|
assert(results == sorted([
|
2017-11-29 05:14:51 +01:00
|
|
|
'.divx', '.iso', '.mkv', '.mov', '.mpg', '.avi', '.mpeg', '.vob',
|
|
|
|
'.xvid', '.wmv', '.mp4',
|
2017-12-03 08:00:23 +01:00
|
|
|
]))
|
2017-11-29 05:14:51 +01:00
|
|
|
|
|
|
|
# Now a list with extras we want to add as strings
|
|
|
|
# empty entries are removed
|
|
|
|
results = utils.parse_list([
|
|
|
|
'.divx', '.iso', '.mkv', '.mov', '', ' ', '.avi', '.mpeg', '.vob',
|
|
|
|
'.xvid', '.mp4'], '.mov,.wmv,.mp4,.mpg')
|
|
|
|
|
2017-12-03 08:00:23 +01:00
|
|
|
assert(results == sorted([
|
2017-11-29 05:14:51 +01:00
|
|
|
'.divx', '.wmv', '.iso', '.mkv', '.mov', '.mpg', '.avi', '.vob',
|
|
|
|
'.xvid', '.mpeg', '.mp4',
|
2017-12-03 08:00:23 +01:00
|
|
|
]))
|