Skip to content

Commit

Permalink
Merge branch 'master' into feature/album-art
Browse files Browse the repository at this point in the history
  • Loading branch information
leso-kn committed Feb 16, 2023
2 parents be4776c + 8cbb441 commit a0e10f9
Show file tree
Hide file tree
Showing 6 changed files with 40 additions and 16 deletions.
1 change: 0 additions & 1 deletion mopidy_mpd/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@


class Extension(ext.Extension):

dist_name = "Mopidy-MPD"
ext_name = "mpd"
version = __version__
Expand Down
19 changes: 16 additions & 3 deletions mopidy_mpd/network.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,15 @@
CONTROL_CHARS = dict.fromkeys(range(32))


def get_systemd_socket():
"""Attempt to get a socket from systemd."""
fdnames = os.environ.get("LISTEN_FDNAMES", "").split(":")
if "mpd" not in fdnames:
return None
fd = fdnames.index("mpd") + 3 # 3 is the first systemd file handle
return socket.socket(fileno=fd)


def get_unix_socket_path(socket_path):
match = re.search("^unix:(.*)", socket_path)
if not match:
Expand All @@ -37,7 +46,7 @@ def get_socket_address(host, port):
return (host, port)


class ShouldRetrySocketCall(Exception):
class ShouldRetrySocketCallError(Exception):

"""Indicate that attempted socket call should be retried"""

Expand Down Expand Up @@ -122,6 +131,10 @@ def __init__(
self.watcher = self.register_server_socket(self.server_socket.fileno())

def create_server_socket(self, host, port):
sock = get_systemd_socket()
if sock is not None:
return sock

socket_path = get_unix_socket_path(host)
if socket_path is not None: # host is a path so use unix socket
sock = create_unix_socket()
Expand Down Expand Up @@ -157,7 +170,7 @@ def register_server_socket(self, fileno):
def handle_connection(self, fd, flags):
try:
sock, addr = self.accept_connection()
except ShouldRetrySocketCall:
except ShouldRetrySocketCallError:
return True

if self.maximum_connections_exceeded():
Expand All @@ -174,7 +187,7 @@ def accept_connection(self):
return sock, addr
except OSError as e:
if e.errno in (errno.EAGAIN, errno.EINTR):
raise ShouldRetrySocketCall
raise ShouldRetrySocketCallError
raise

def maximum_connections_exceeded(self):
Expand Down
4 changes: 2 additions & 2 deletions mopidy_mpd/protocol/current_playlist.py
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,7 @@ def delete(context, songrange):
tl_tracks = context.core.tracklist.slice(start, end).get()
if not tl_tracks:
raise exceptions.MpdArgError("Bad song index", command="delete")
for (tlid, _) in tl_tracks:
for tlid, _ in tl_tracks:
context.core.tracklist.remove({"tlid": [tlid]})


Expand Down Expand Up @@ -325,7 +325,7 @@ def plchangesposid(context, version):
# XXX Naive implementation that returns all tracks as changed
if int(version) != context.core.tracklist.get_version().get():
result = []
for (position, (tlid, _)) in enumerate(
for position, (tlid, _) in enumerate(
context.core.tracklist.get_tl_tracks().get()
):
result.append(("cpos", position))
Expand Down
29 changes: 21 additions & 8 deletions tests/dummy_audio.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,8 @@ def __init__(self, config=None, mixer=None):
self.state = audio.PlaybackState.STOPPED
self._volume = 0
self._position = 0
self._callback = None
self._source_setup_callback = None
self._about_to_finish_callback = None
self._uri = None
self._stream_changed = False
self._live_stream = False
Expand Down Expand Up @@ -58,6 +59,7 @@ def pause_playback(self):

def prepare_change(self):
self._uri = None
self._source_setup_callback = None
return True

def stop_playback(self):
Expand All @@ -76,8 +78,11 @@ def set_metadata(self, track):
def get_current_tags(self):
return self._tags

def set_source_setup_callback(self, callback):
self._source_setup_callback = callback

def set_about_to_finish_callback(self, callback):
self._callback = callback
self._about_to_finish_callback = callback

def enable_sync_handler(self):
pass
Expand All @@ -93,13 +98,13 @@ def _change_state(self, new_state):
self._stream_changed = True
self._uri = None

if self._uri is not None:
audio.AudioListener.send("position_changed", position=0)

if self._stream_changed:
self._stream_changed = False
audio.AudioListener.send("stream_changed", uri=self._uri)

if self._uri is not None:
audio.AudioListener.send("position_changed", position=0)

old_state, self.state = self.state, new_state
audio.AudioListener.send(
"state_changed",
Expand All @@ -121,14 +126,22 @@ def trigger_fake_tags_changed(self, tags):
self._tags.update(tags)
audio.AudioListener.send("tags_changed", tags=self._tags.keys())

def get_source_setup_callback(self):
# This needs to be called from outside the actor or we lock up.
def wrapper():
if self._source_setup_callback:
self._source_setup_callback()

return wrapper

def get_about_to_finish_callback(self):
# This needs to be called from outside the actor or we lock up.
def wrapper():
if self._callback:
if self._about_to_finish_callback:
self.prepare_change()
self._callback()
self._about_to_finish_callback()

if not self._uri or not self._callback:
if not self._uri or not self._about_to_finish_callback:
self._tags = {}
audio.AudioListener.send("reached_end_of_stream")
else:
Expand Down
2 changes: 1 addition & 1 deletion tests/network/test_server.py
Original file line number Diff line number Diff line change
Expand Up @@ -250,7 +250,7 @@ def test_accept_connection_recoverable_error(self):

for error in (errno.EAGAIN, errno.EINTR):
sock.accept.side_effect = socket.error(error, "")
with self.assertRaises(network.ShouldRetrySocketCall):
with self.assertRaises(network.ShouldRetrySocketCallError):
network.Server.accept_connection(self.mock)

# FIXME decide if this should be allowed to propegate
Expand Down
1 change: 0 additions & 1 deletion tests/protocol/test_regression.py
Original file line number Diff line number Diff line change
Expand Up @@ -169,7 +169,6 @@ def test(self):


class IssueGH113RegressionTest(protocol.BaseTestCase):

r"""
The issue: https://github.com/mopidy/mopidy/issues/113
Expand Down

0 comments on commit a0e10f9

Please sign in to comment.