diff --git a/test/test_compat.py b/test/test_compat.py
index 1eb454e068..431e6bdf18 100644
--- a/test/test_compat.py
+++ b/test/test_compat.py
@@ -14,6 +14,7 @@
from youtube_dl.compat import (
compat_getenv,
compat_expanduser,
+ compat_urllib_parse_unquote,
)
@@ -42,5 +43,24 @@ def test_all_present(self):
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')],
+ ['''
+%%a''',
+ '''
+%%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()