Improve cast HLS detection (#72787)

pull/72799/head^2
Erik Montnemery 2022-06-01 05:35:56 +02:00 committed by GitHub
parent 0df9cc907a
commit 44f332ed5f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 20 additions and 7 deletions

View File

@ -266,10 +266,8 @@ async def parse_m3u(hass, url):
hls_content_types = (
# https://tools.ietf.org/html/draft-pantos-http-live-streaming-19#section-10
"application/vnd.apple.mpegurl",
# Some sites serve these as the informal HLS m3u type.
"application/x-mpegurl",
"audio/mpegurl",
"audio/x-mpegurl",
# Additional informal types used by Mozilla gecko not included as they
# don't reliably indicate HLS streams
)
m3u_data = await _fetch_playlist(hass, url, hls_content_types)
m3u_lines = m3u_data.splitlines()
@ -292,6 +290,9 @@ async def parse_m3u(hass, url):
elif line.startswith("#EXT-X-VERSION:"):
# HLS stream, supported by cast devices
raise PlaylistSupported("HLS")
elif line.startswith("#EXT-X-STREAM-INF:"):
# HLS stream, supported by cast devices
raise PlaylistSupported("HLS")
elif line.startswith("#"):
# Ignore other extensions
continue

View File

@ -27,6 +27,11 @@ from tests.common import load_fixture
"rthkaudio2.m3u8",
"application/vnd.apple.mpegurl",
),
(
"https://rthkaudio2-lh.akamaihd.net/i/radio2_1@355865/master.m3u8",
"rthkaudio2.m3u8",
None,
),
),
)
async def test_hls_playlist_supported(hass, aioclient_mock, url, fixture, content_type):
@ -38,11 +43,12 @@ async def test_hls_playlist_supported(hass, aioclient_mock, url, fixture, conten
@pytest.mark.parametrize(
"url,fixture,expected_playlist",
"url,fixture,content_type,expected_playlist",
(
(
"https://sverigesradio.se/topsy/direkt/209-hi-mp3.m3u",
"209-hi-mp3.m3u",
"audio/x-mpegurl",
[
PlaylistItem(
length=["-1"],
@ -54,6 +60,7 @@ async def test_hls_playlist_supported(hass, aioclient_mock, url, fixture, conten
(
"https://sverigesradio.se/topsy/direkt/209-hi-mp3.m3u",
"209-hi-mp3_bad_extinf.m3u",
"audio/x-mpegurl",
[
PlaylistItem(
length=None,
@ -65,6 +72,7 @@ async def test_hls_playlist_supported(hass, aioclient_mock, url, fixture, conten
(
"https://sverigesradio.se/topsy/direkt/209-hi-mp3.m3u",
"209-hi-mp3_no_extinf.m3u",
"audio/x-mpegurl",
[
PlaylistItem(
length=None,
@ -76,6 +84,7 @@ async def test_hls_playlist_supported(hass, aioclient_mock, url, fixture, conten
(
"http://sverigesradio.se/topsy/direkt/164-hi-aac.pls",
"164-hi-aac.pls",
"audio/x-mpegurl",
[
PlaylistItem(
length="-1",
@ -86,9 +95,12 @@ async def test_hls_playlist_supported(hass, aioclient_mock, url, fixture, conten
),
),
)
async def test_parse_playlist(hass, aioclient_mock, url, fixture, expected_playlist):
async def test_parse_playlist(
hass, aioclient_mock, url, fixture, content_type, expected_playlist
):
"""Test playlist parsing of HLS playlist."""
aioclient_mock.get(url, text=load_fixture(fixture, "cast"))
headers = {"content-type": content_type}
aioclient_mock.get(url, text=load_fixture(fixture, "cast"), headers=headers)
playlist = await parse_playlist(hass, url)
assert expected_playlist == playlist