59 lines
2.0 KiB
Python
59 lines
2.0 KiB
Python
import multiprocessing
|
|
import unittest
|
|
|
|
from mopidy.utils import path_to_uri
|
|
from mopidy.process import pickle_connection
|
|
from mopidy.outputs.gstreamer import GStreamerOutput
|
|
|
|
from tests import data_folder, SkipTest
|
|
|
|
class GStreamerOutputTest(unittest.TestCase):
|
|
def setUp(self):
|
|
self.song_uri = path_to_uri(data_folder('song1.wav'))
|
|
self.output_queue = multiprocessing.Queue()
|
|
self.core_queue = multiprocessing.Queue()
|
|
self.output = GStreamerOutput(self.core_queue, self.output_queue)
|
|
|
|
def tearDown(self):
|
|
self.output.destroy()
|
|
|
|
def send_recv(self, message):
|
|
(my_end, other_end) = multiprocessing.Pipe()
|
|
message.update({'reply_to': pickle_connection(other_end)})
|
|
self.output_queue.put(message)
|
|
my_end.poll(None)
|
|
return my_end.recv()
|
|
|
|
def send(self, message):
|
|
self.output_queue.put(message)
|
|
|
|
@SkipTest
|
|
def test_play_uri_existing_file(self):
|
|
message = {'command': 'play_uri', 'uri': self.song_uri}
|
|
self.assertEqual(True, self.send_recv(message))
|
|
|
|
@SkipTest
|
|
def test_play_uri_non_existing_file(self):
|
|
message = {'command': 'play_uri', 'uri': self.song_uri + 'bogus'}
|
|
self.assertEqual(False, self.send_recv(message))
|
|
|
|
def test_default_get_volume_result(self):
|
|
message = {'command': 'get_volume'}
|
|
self.assertEqual(100, self.send_recv(message))
|
|
|
|
def test_set_volume(self):
|
|
self.send({'command': 'set_volume', 'volume': 50})
|
|
self.assertEqual(50, self.send_recv({'command': 'get_volume'}))
|
|
|
|
def test_set_volume_to_zero(self):
|
|
self.send({'command': 'set_volume', 'volume': 0})
|
|
self.assertEqual(0, self.send_recv({'command': 'get_volume'}))
|
|
|
|
def test_set_volume_to_one_hundred(self):
|
|
self.send({'command': 'set_volume', 'volume': 100})
|
|
self.assertEqual(100, self.send_recv({'command': 'get_volume'}))
|
|
|
|
@SkipTest
|
|
def test_set_state(self):
|
|
raise NotImplementedError
|