Merge pull request #1815 from beetbox/more_tests

Add more test coverage for mpdstats
This commit is contained in:
Adrian Sampson 2016-01-16 10:13:06 -08:00
commit f0818919ac

View file

@ -17,7 +17,7 @@ from __future__ import (division, absolute_import, print_function,
unicode_literals)
from mock import Mock
from mock import Mock, patch, call, ANY
from test._common import unittest
from test.helper import TestHelper
@ -44,6 +44,44 @@ class MPDStatsTest(unittest.TestCase, TestHelper):
self.assertFalse(mpdstats.update_rating(item, True))
self.assertFalse(mpdstats.update_rating(None, True))
def test_get_item(self):
ITEM_PATH = '/foo/bar.flac'
item = Item(title='title', path=ITEM_PATH, id=1)
item.add(self.lib)
log = Mock()
mpdstats = MPDStats(self.lib, log)
self.assertEqual(str(mpdstats.get_item(ITEM_PATH)), str(item))
self.assertIsNone(mpdstats.get_item('/some/non-existing/path'))
self.assertIn('item not found:', log.info.call_args[0][0])
FAKE_UNKNOWN_STATE = 'some-unknown-one'
STATUSES = [{'state': FAKE_UNKNOWN_STATE},
{'state': 'pause'},
{'state': 'play', 'songid': 1, 'time': '0:1'},
{'state': 'stop'}]
EVENTS = [["player"]] * (len(STATUSES) - 1) + [KeyboardInterrupt]
ITEM_PATH = '/foo/bar.flac'
@patch("beetsplug.mpdstats.MPDClientWrapper", return_value=Mock(**{
"events.side_effect": EVENTS, "status.side_effect": STATUSES,
"playlist.return_value": {1: ITEM_PATH}}))
def test_run_MPDStats(self, mpd_mock):
item = Item(title='title', path=self.ITEM_PATH, id=1)
item.add(self.lib)
log = Mock()
try:
MPDStats(self.lib, log).run()
except KeyboardInterrupt:
pass
log.debug.assert_has_calls(
[call(u'unhandled status "{0}"', ANY)])
log.info.assert_has_calls(
[call(u'pause'), call(u'playing {0}', ANY), call(u'stop')])
def suite():
return unittest.TestLoader().loadTestsFromName(__name__)