diff --git a/README.md b/README.md index f1231cb..6283284 100644 --- a/README.md +++ b/README.md @@ -13,7 +13,7 @@ A tool for downloading Japanese subtitles for anime from Jimaku-DL Demo

- + ## Features @@ -26,7 +26,6 @@ A tool for downloading Japanese subtitles for anime from
Logger: @@ -1519,7 +1519,8 @@ class JimakuDownloader: elif play and is_directory: print("Cannot play media with MPV when input is a directory. Skipping.") self.logger.warning( - "Cannot play media with MPV when input is a directory. Skipping." + "Cannot play media with MPV when input is a directory. " + "Skipping playback." ) self.logger.info("Subtitle download process completed successfully") diff --git a/tests/test_downloader.py b/tests/test_downloader.py index 64975c6..854cfa1 100644 --- a/tests/test_downloader.py +++ b/tests/test_downloader.py @@ -96,9 +96,16 @@ class TestJimakuDownloader: # Make sure the response object has a working raise_for_status method mock_requests["response"].raise_for_status = MagicMock() + # Test with special characters in the title + result = downloader.query_anilist( + "KonoSuba – God’s blessing on this wonderful world!! (2016)", season=3 + ) + assert result == 123456 # Patch requests.post directly to use our mock - with patch("jimaku_dl.downloader.requests_post", return_value=mock_requests["response"]): + with patch( + "jimaku_dl.downloader.requests_post", return_value=mock_requests["response"] + ): # Test the function with title and season result = downloader.query_anilist("Test Anime", season=1) assert result == 123456 @@ -152,7 +159,9 @@ class TestJimakuDownloader: mock_requests["response"].raise_for_status = MagicMock() # Patch requests.post directly to use our mock - with patch("jimaku_dl.downloader.requests_post", return_value=mock_requests["response"]): + with patch( + "jimaku_dl.downloader.requests_post", return_value=mock_requests["response"] + ): # Test the function with title and season - should work even without API token result = downloader.query_anilist("Test Anime", season=1) assert result == 123456 @@ -315,16 +324,18 @@ class TestJimakuDownloader: mock_requests["response"].json.side_effect = None mock_requests["response"].json.return_value = mock_jimaku_entries_response mock_requests["get"].return_value = mock_requests["response"] - + # Make sure the response object has a working raise_for_status method mock_requests["response"].raise_for_status = MagicMock() # Patch the requests.get function directly to use our mock - with patch("jimaku_dl.downloader.requests_get", return_value=mock_requests["response"]): + with patch( + "jimaku_dl.downloader.requests_get", return_value=mock_requests["response"] + ): # Call the function and check the result result = downloader.query_jimaku_entries(123456) assert result == mock_jimaku_entries_response - + # We won't assert on mock_requests["get"] here since it's not reliable # due to the patching approach @@ -335,22 +346,24 @@ class TestJimakuDownloader: # Set the mock response mock_requests["response"].json.side_effect = None mock_requests["response"].json.return_value = mock_jimaku_files_response - + # Create a direct mock for requests_get to verify it's called correctly mock_get = MagicMock(return_value=mock_requests["response"]) - + # Patch the requests_get function directly with patch("jimaku_dl.downloader.requests_get", mock_get): # Call the function and check the result result = downloader.get_entry_files(1) assert result == mock_jimaku_files_response - + # Verify proper headers were set in the API call mock_get.assert_called_once() url = mock_get.call_args[0][0] assert "entries/1/files" in url - headers = mock_get.call_args[1].get('headers', {}) - assert headers.get('Authorization') == 'test_token' # Changed from 'Bearer test_token' + headers = mock_get.call_args[1].get("headers", {}) + assert ( + headers.get("Authorization") == "test_token" + ) # Changed from 'Bearer test_token' def test_get_entry_files_no_token(self, monkeypatch): """Test getting entry files without API token.""" diff --git a/tests/test_parse_filename.py b/tests/test_parse_filename.py index 56df7cc..0c4aa56 100644 --- a/tests/test_parse_filename.py +++ b/tests/test_parse_filename.py @@ -110,6 +110,36 @@ class TestParseFilename: # Simple number in season directory file_path = os.path.join("path", "to", "My Anime", "Season 2", "5.mkv") title, season, episode = downloader.parse_filename(file_path) + # Mock _prompt_for_title_info to avoid reading from stdin for the entire test function + with patch.object(self.downloader, "_prompt_for_title_info") as mock_prompt: + # Configure mock to return appropriate values for different test cases + mock_prompt.side_effect = [ + ("Show Name", 1, 2), # First call return value + ("Show Name", 3, 4), # Second call return value + ("My Anime", 2, 5), # Third call return value + ("Long Anime Title With Spaces", 1, 3), # Fourth call return value + ] + + # Standard Season-## format + title, season, episode = self.downloader.parse_filename( + "/path/to/Show Name/Season-1/Show Name - 02 [1080p].mkv" + ) + assert title == "Show Name" + assert season == 1 + assert episode == 2 + + # Season ## format + title, season, episode = self.downloader.parse_filename( + "/path/to/Show Name/Season 03/Episode 4.mkv" + ) + assert title == "Show Name" + assert season == 3 + assert episode == 4 + + # Simple number in season directory + title, season, episode = self.downloader.parse_filename( + "/path/to/My Anime/Season 2/5.mkv" + ) assert title == "My Anime" assert season == 2 assert episode == 5 @@ -124,6 +154,9 @@ class TestParseFilename: "Long Anime Title With Spaces - 03.mkv", ) title, season, episode = downloader.parse_filename(file_path) + title, season, episode = self.downloader.parse_filename( + "/media/user/Anime/Long Anime Title With Spaces/Season-1/Long Anime Title With Spaces - 03.mkv" + ) assert title == "Long Anime Title With Spaces" assert season == 1 assert episode == 3