1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48
|
import json
import logging
import unittest
from requests import Response, Request
from streamlink.compat import urlencode
from streamlink.plugins.bbciplayer import BBCiPlayer
class TestPluginBBCiPlayer(unittest.TestCase):
def test_can_handle_url(self):
# should match
self.assertTrue(
BBCiPlayer.can_handle_url("http://www.bbc.co.uk/iplayer/episode/b00ymh67/madagascar-1-island-of-marvels"))
self.assertTrue(BBCiPlayer.can_handle_url("http://www.bbc.co.uk/iplayer/live/bbcone"))
# shouldn't match
self.assertFalse(BBCiPlayer.can_handle_url("http://www.tvcatchup.com/"))
self.assertFalse(BBCiPlayer.can_handle_url("http://www.sportal.bg/sportal_live_tv.php?str=15"))
self.assertFalse(BBCiPlayer.can_handle_url("http://www.bbc.co.uk/iplayer/"))
def test_vpid_hash(self):
self.assertEqual(
"71c345435589c6ddeea70d6f252e2a52281ecbf3",
BBCiPlayer._hash_vpid("1234567890")
)
def test_extract_nonce(self):
mock_nonce = "mock-nonce-nse"
last_response = Response()
last_response.request = Request('GET', "http://example.com/?" + urlencode(dict(
goto="http://example.com/?" + urlencode(dict(
state=json.dumps(dict(nonce=mock_nonce))
))
)))
mock_response = Response()
mock_response.history = [
Response(), # Add some extra dummy responses in to make sure we always get the last
Response(),
last_response
]
self.assertEqual(BBCiPlayer._extract_nonce(mock_response), mock_nonce)
|