forked from openlp/openlp
Change song lyrics selector to fetch link via class name
And get copyrights via lyrics page where the list has a class name
This commit is contained in:
parent
c7112a1f78
commit
81dc52110d
@ -182,7 +182,7 @@ class SongSelectImport(object):
|
||||
except (TypeError, URLError) as error:
|
||||
log.exception('Could not get song from SongSelect, {error}'.format(error=error))
|
||||
return None
|
||||
lyrics_link = song_page.find('a', title='View song lyrics')['href']
|
||||
lyrics_link = song_page.find('section', 'page-section').find('a')['href']
|
||||
if callback:
|
||||
callback()
|
||||
try:
|
||||
@ -192,15 +192,13 @@ class SongSelectImport(object):
|
||||
return None
|
||||
if callback:
|
||||
callback()
|
||||
copyright_elements = []
|
||||
theme_elements = []
|
||||
copyrights_regex = re.compile(r'\bCopyrights\b')
|
||||
# Themes regex only works if the ccli site is in english.
|
||||
themes_regex = re.compile(r'\bThemes\b')
|
||||
for ul in song_page.find_all('ul', 'song-meta-list'):
|
||||
if ul.find('li', string=copyrights_regex):
|
||||
copyright_elements.extend(ul.find_all('li')[1:])
|
||||
if ul.find('li', string=themes_regex):
|
||||
theme_elements.extend(ul.find_all('li')[1:])
|
||||
copyright_elements = lyrics_page.find('ul', 'copyright').find_all('li')
|
||||
author_elements = song_page.find('div', 'content-title').find('ul', 'authors').find_all('li')
|
||||
song['title'] = unescape(song_page.find('div', 'content-title').find('h1').string.strip())
|
||||
song['authors'] = [unescape(li.find('a').string).strip() for li in author_elements]
|
||||
|
@ -314,13 +314,12 @@ class TestSongSelectImport(TestCase, TestMixin):
|
||||
</ul>
|
||||
</div>
|
||||
<div class="song-content-data"><ul><li><strong>1234_cclinumber_5678</strong></li></ul></div>
|
||||
<a title="View song lyrics" href="pretend link"></a>
|
||||
<section class="page-section">
|
||||
<a title="View song lyrics" href="pretend link"></a>
|
||||
</section>
|
||||
<ul class="song-meta-list">
|
||||
<li>Themes</li><li><a>theme1</a></li><li><a>theme2</a></li>
|
||||
</ul>
|
||||
<ul class="song-meta-list">
|
||||
<li>Copyrights</li><li>Copy thing</li><li>Copy thing 2</li>
|
||||
</ul>
|
||||
</body></html>
|
||||
'''
|
||||
fake_lyrics_page = '''<!DOCTYPE html><html><body>
|
||||
@ -330,6 +329,9 @@ class TestSongSelectImport(TestCase, TestMixin):
|
||||
<h3>Verse 2</h3>
|
||||
<p>verse thing 2</p>
|
||||
</div>
|
||||
<ul class="copyright">
|
||||
<li>Copy thing</li><li>Copy thing 2</li>
|
||||
</ul>
|
||||
</body></html>
|
||||
'''
|
||||
mocked_get_page.side_effect = [fake_song_page, fake_lyrics_page]
|
||||
|
Loading…
Reference in New Issue
Block a user