about summary refs log tree commit diff
path: root/test/test_compat.py
diff options
context:
space:
mode:
authorfnord <fnord@fnord.mobi>2015-07-17 09:46:08 -0500
committerfnord <fnord@fnord.mobi>2015-07-17 09:46:08 -0500
commit4a632911443f0dbc2384fb82ade85382aeecc8dc (patch)
tree059d53f6fd8e0dace1414301ba55d9ac1df25f03 /test/test_compat.py
parent593b77064c51c411071e310578b542017b9b2ec8 (diff)
downloadyoutube-dl-4a632911443f0dbc2384fb82ade85382aeecc8dc.tar.gz
youtube-dl-4a632911443f0dbc2384fb82ade85382aeecc8dc.tar.xz
youtube-dl-4a632911443f0dbc2384fb82ade85382aeecc8dc.zip
Add tests for compat_urllib_parse_unquote
Diffstat (limited to 'test/test_compat.py')
-rw-r--r--test/test_compat.py20
1 files changed, 20 insertions, 0 deletions
diff --git a/test/test_compat.py b/test/test_compat.py
index 1eb454e06..431e6bdf1 100644
--- a/test/test_compat.py
+++ b/test/test_compat.py
@@ -14,6 +14,7 @@ from youtube_dl.utils import get_filesystem_encoding
 from youtube_dl.compat import (
     compat_getenv,
     compat_expanduser,
+    compat_urllib_parse_unquote,
 )
 
 
@@ -42,5 +43,24 @@ class TestCompat(unittest.TestCase):
             dir(youtube_dl.compat))) - set(['unicode_literals'])
         self.assertEqual(all_names, sorted(present_names))
 
+    def test_compat_urllib_parse_unquote(self):
+        test_strings = [
+            ['''''', ''''''],
+            ['''津波''', '''%E6%B4%A5%E6%B3%A2'''],
+            ['''津波''', str('%E6%B4%A5%E6%B3%A2')],
+            ['''<meta property="og:description" content="▁▂▃▄%▅▆▇█" />
+%<a href="https://ar.wikipedia.org/wiki/تسونامي">%a''',
+             '''<meta property="og:description" content="%E2%96%81%E2%96%82%E2%96%83%E2%96%84%25%E2%96%85%E2%96%86%E2%96%87%E2%96%88" />
+%<a href="https://ar.wikipedia.org/wiki/%D8%AA%D8%B3%D9%88%D9%86%D8%A7%D9%85%D9%8A">%a'''],
+            ['''(^◣_◢^)っ︻デ═一    ⇀    ⇀    ⇀    ⇀    ⇀    ↶%I%Break%Things%''',
+             '''%28%5E%E2%97%A3_%E2%97%A2%5E%29%E3%81%A3%EF%B8%BB%E3%83%87%E2%95%90%E4%B8%80    %E2%87%80    %E2%87%80    %E2%87%80    %E2%87%80    %E2%87%80    %E2%86%B6%I%Break%25Things%''']
+        ]
+        for test in test_strings:
+            strutf = test[0]
+            strurlenc = test[1]
+            strurldec = compat_urllib_parse_unquote(strurlenc)
+            self.assertEqual(strutf, strurldec)
+            self.assertEqual(strutf, compat_urllib_parse_unquote(strurlenc))
+
 if __name__ == '__main__':
     unittest.main()