feat: refactor ZSpace media server request handling and improve authorization headers

This commit is contained in:
jxxghp
2026-05-11 22:24:15 +08:00
parent a62b6b6fd5
commit a6ab9b76c1
2 changed files with 181 additions and 104 deletions

View File

@@ -14,17 +14,17 @@ class _FakeResponse:
class ZSpaceMediaServerTest(unittest.TestCase):
def test_reconnect_uses_username_password_login(self):
request_utils = Mock()
request_utils.post_res.return_value = _FakeResponse({
"AccessToken": "zspace-token",
"User": {"Id": "user-id"},
})
request_utils.get_res.side_effect = [
_FakeResponse([]),
_FakeResponse({"Id": "server-id"}),
]
with patch("app.modules.zspace.zspace.RequestUtils") as request_utils_cls:
request_utils = request_utils_cls.return_value
request_utils.post_res.return_value = _FakeResponse({
"AccessToken": "zspace-token",
"User": {"Id": "user-id"},
})
request_utils.get_res.side_effect = [
_FakeResponse([]),
_FakeResponse({"Id": "server-id"}),
]
with patch("app.modules.zspace.zspace.RequestUtils", return_value=request_utils):
client = ZSpace(
host="http://zspace.local",
username="admin",
@@ -34,6 +34,21 @@ class ZSpaceMediaServerTest(unittest.TestCase):
self.assertEqual(client._apikey, "zspace-token")
self.assertEqual(client.user, "user-id")
self.assertEqual(client.serverid, "server-id")
self.assertEqual(
request_utils_cls.call_args_list[0].kwargs["headers"]["X-Emby-Authorization"],
'MediaBrowser Client="MoviePilot", Device="requests", DeviceId="1", Version="1.0.0"',
)
self.assertEqual(
request_utils_cls.call_args_list[1].kwargs["headers"]["X-Emby-Token"],
"zspace-token",
)
self.assertIsNone(
request_utils_cls.call_args_list[1].kwargs["headers"].get("Authorization")
)
self.assertEqual(
request_utils.get_res.call_args_list[1].args[0],
"http://zspace.local/emby/System/Info",
)
def test_get_user_falls_back_to_current_login_user(self):
client = ZSpace.__new__(ZSpace)
@@ -48,6 +63,14 @@ class ZSpaceMediaServerTest(unittest.TestCase):
user_id = client.get_user("admin")
self.assertEqual(user_id, "current-user-id")
self.assertEqual(
request_utils_cls.return_value.get_res.call_args.args[0],
"http://zspace.local/emby/Users",
)
self.assertEqual(
request_utils_cls.call_args.kwargs["headers"]["X-Emby-Token"],
"zspace-token",
)
def test_authenticate_does_not_require_existing_api_key(self):
with patch("app.modules.zspace.zspace.RequestUtils") as request_utils_cls:
@@ -68,6 +91,57 @@ class ZSpaceMediaServerTest(unittest.TestCase):
headers.get("X-Emby-Authorization"),
'MediaBrowser Client="MoviePilot", Device="requests", DeviceId="1", Version="1.0.0"',
)
self.assertIsNone(headers.get("X-Emby-Token"))
def test_get_resume_uses_emby_path_and_login_token_headers(self):
client = ZSpace.__new__(ZSpace)
client._host = "http://zspace.local/"
client._apikey = "zspace-token"
client.user = "user-id"
client._sync_libraries = []
client.get_user_library_folders = Mock(return_value=[])
with patch("app.modules.zspace.zspace.RequestUtils") as request_utils_cls:
request_utils_cls.return_value.get_res.return_value = _FakeResponse({"Items": []})
items = client.get_resume()
self.assertEqual(items, [])
self.assertEqual(
request_utils_cls.return_value.get_res.call_args.args[0],
"http://zspace.local/emby/Users/user-id/Items/Resume",
)
self.assertEqual(
request_utils_cls.return_value.get_res.call_args.kwargs["params"],
{
"Limit": 100,
"MediaTypes": "Video",
"Fields": "ProductionYear,Path",
},
)
self.assertEqual(
request_utils_cls.call_args.kwargs["headers"]["X-Emby-Token"],
"zspace-token",
)
def test_image_urls_use_emby_compatible_paths(self):
client = ZSpace.__new__(ZSpace)
client._host = "http://zspace.local/"
client._playhost = "http://play.zspace.local/"
client._apikey = "zspace-token"
self.assertEqual(
client.get_backdrop_url("item-id", "tag-id"),
"http://zspace.local/emby/Items/item-id/Images/Backdrop?tag=tag-id&api_key=zspace-token",
)
self.assertEqual(
client.get_backdrop_url("item-id", "tag-id", remote=True),
"http://play.zspace.local/emby/Items/item-id/Images/Backdrop?tag=tag-id&api_key=zspace-token",
)
self.assertEqual(
client._ZSpace__get_local_image_by_id("item-id"),
"http://zspace.local/emby/Items/item-id/Images/Primary?api_key=zspace-token",
)
if __name__ == "__main__":