-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #4 from sheriferson/misc/improve-tests-and-misc
Improve tests and other quality of life/code changes
- Loading branch information
Showing
8 changed files
with
132 additions
and
38 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,8 @@ | ||
*egg-info | ||
.DS_Store | ||
.coverage | ||
.idea | ||
__pycache__ | ||
build | ||
coverage.xml | ||
dist | ||
.DS_Store |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
from scrobble.pushover import send_notification | ||
from scrobble.utils import Config | ||
from scrobble.musicbrainz import CD, UserAgent, init_musicbrainz | ||
import importlib.metadata | ||
from urllib.parse import quote_plus | ||
|
||
import unittest | ||
from unittest.mock import patch, Mock | ||
|
||
USERAGENT = UserAgent('scrobble (PyPI) (tests)', | ||
importlib.metadata.version('scrobble'), # scrobble version | ||
'https://github.com/sheriferson' | ||
) | ||
|
||
init_musicbrainz(USERAGENT) | ||
|
||
TEST_CD = CD.find_cd(7277017746006, choice=False) | ||
|
||
|
||
class TestSendNotification(unittest.TestCase): | ||
|
||
@patch('http.client.HTTPSConnection') | ||
def test_send_notification(self, mock_https_connection): | ||
# Mocking the connection | ||
mock_conn_instance = Mock() | ||
mock_https_connection.return_value = mock_conn_instance | ||
|
||
# Mocking the response | ||
mock_response = Mock() | ||
mock_conn_instance.getresponse.return_value = mock_response | ||
|
||
# Example CD and Config objects | ||
config = Config(config_path='tests/resources/scrobble_complete_valid.toml') | ||
config.pushover_token = 'test_token' | ||
config.pushover_user = 'test_user' | ||
|
||
# Call the function with the mocked connection | ||
response = send_notification(TEST_CD, config) | ||
|
||
# Assert that conn.request was called with the expected arguments | ||
mock_conn_instance.request.assert_called_once_with( | ||
"POST", | ||
"/1/messages.json", | ||
f"token={config.pushover_token}&user={config.pushover_user}&message={quote_plus(TEST_CD.title)}+%28{TEST_CD.year}%29+by+{quote_plus(TEST_CD.artist)}+scrobbled+to+your+account.&url=https%3A%2F%2Flast.fm%2Fuser%2F{config.lastfm_username}", | ||
{"Content-type": "application/x-www-form-urlencoded"} | ||
) | ||
|
||
# Assert that conn.getresponse was called | ||
mock_conn_instance.getresponse.assert_called_once() | ||
|
||
# Assert that the function returned the expected response | ||
self.assertEqual(response, mock_response) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters