forked from openlp/openlp
Implemented a workaround for bug1251437
Fixes: https://launchpad.net/bugs/1251437
This commit is contained in:
parent
04bafa62fa
commit
62811d660f
@ -109,6 +109,22 @@ class VersionThread(QtCore.QThread):
|
|||||||
Registry().execute('openlp_version_check', '%s' % version)
|
Registry().execute('openlp_version_check', '%s' % version)
|
||||||
|
|
||||||
|
|
||||||
|
class HTTPRedirectHandlerFixed(urllib.request.HTTPRedirectHandler):
|
||||||
|
"""
|
||||||
|
Special HTTPRedirectHandler used to work around http://bugs.python.org/issue22248
|
||||||
|
(Redirecting to urls with special chars)
|
||||||
|
"""
|
||||||
|
def redirect_request(self, req, fp, code, msg, headers, newurl):
|
||||||
|
# Test if the newurl can be decoded to ascii
|
||||||
|
try:
|
||||||
|
test_url = newurl.encode('latin1').decode('ascii')
|
||||||
|
fixed_url = newurl
|
||||||
|
except Exception:
|
||||||
|
# The url could not be decoded to ascii, so we do some url encoding
|
||||||
|
fixed_url = urllib.parse.quote(newurl.encode('latin1').decode('utf-8', 'replace'), safe='/:')
|
||||||
|
return super(HTTPRedirectHandlerFixed, self).redirect_request(req, fp, code, msg, headers, fixed_url)
|
||||||
|
|
||||||
|
|
||||||
def get_application_version():
|
def get_application_version():
|
||||||
"""
|
"""
|
||||||
Returns the application version of the running instance of OpenLP::
|
Returns the application version of the running instance of OpenLP::
|
||||||
@ -341,6 +357,9 @@ def get_web_page(url, header=None, update_openlp=False):
|
|||||||
# http://docs.python.org/library/urllib2.html
|
# http://docs.python.org/library/urllib2.html
|
||||||
if not url:
|
if not url:
|
||||||
return None
|
return None
|
||||||
|
# This is needed to work around http://bugs.python.org/issue22248 and https://bugs.launchpad.net/openlp/+bug/1251437
|
||||||
|
opener = urllib.request.build_opener(HTTPRedirectHandlerFixed())
|
||||||
|
urllib.request.install_opener(opener)
|
||||||
req = urllib.request.Request(url)
|
req = urllib.request.Request(url)
|
||||||
if not header or header[0].lower() != 'user-agent':
|
if not header or header[0].lower() != 'user-agent':
|
||||||
user_agent = _get_user_agent()
|
user_agent = _get_user_agent()
|
||||||
|
@ -32,7 +32,6 @@ The :mod:`http` module enables OpenLP to retrieve scripture from bible websites.
|
|||||||
import logging
|
import logging
|
||||||
import re
|
import re
|
||||||
import socket
|
import socket
|
||||||
import urllib.request
|
|
||||||
import urllib.parse
|
import urllib.parse
|
||||||
import urllib.error
|
import urllib.error
|
||||||
from html.parser import HTMLParseError
|
from html.parser import HTMLParseError
|
||||||
|
@ -59,6 +59,19 @@ class TestBibleHTTP(TestCase):
|
|||||||
# THEN: We should get back a valid service item
|
# THEN: We should get back a valid service item
|
||||||
assert len(books) == 66, 'The bible should not have had any books added or removed'
|
assert len(books) == 66, 'The bible should not have had any books added or removed'
|
||||||
|
|
||||||
|
def bible_gateway_extract_books_support_redirect_test(self):
|
||||||
|
"""
|
||||||
|
Test the Bible Gateway retrieval of book list for DN1933 bible with redirect (bug 1251437)
|
||||||
|
"""
|
||||||
|
# GIVEN: A new Bible Gateway extraction class
|
||||||
|
handler = BGExtract()
|
||||||
|
|
||||||
|
# WHEN: The Books list is called
|
||||||
|
books = handler.get_books_from_http('DN1933')
|
||||||
|
|
||||||
|
# THEN: We should get back a valid service item
|
||||||
|
assert len(books) == 66, 'This bible should have 66 books'
|
||||||
|
|
||||||
def bible_gateway_extract_verse_test(self):
|
def bible_gateway_extract_verse_test(self):
|
||||||
"""
|
"""
|
||||||
Test the Bible Gateway retrieval of verse list for NIV bible John 3
|
Test the Bible Gateway retrieval of verse list for NIV bible John 3
|
||||||
|
Loading…
Reference in New Issue
Block a user