From cd5b0074e457e8c8656153d2946e1c7aaa88accb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20=C5=9Aled=C5=BA?= Date: Mon, 20 Nov 2023 15:30:30 +0100 Subject: [PATCH] Log messages in default handle_info implementation (#680) --- CHANGELOG.md | 1 + lib/membrane/bin.ex | 12 ++++++++++-- lib/membrane/element/base.ex | 12 ++++++++++-- lib/membrane/pipeline.ex | 12 ++++++++++-- 4 files changed, 31 insertions(+), 6 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 497bc85f5..796459fa6 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,6 +3,7 @@ ## 1.0.1 * Specify the order in which state fields will be printed in the error logs. [#614](https://github.com/membraneframework/membrane_core/pull/614) * Fix clock selection [#626](https://github.com/membraneframework/membrane_core/pull/626) + * Log messages in the default handle_info implementation [#680](https://github.com/membraneframework/membrane_core/pull/680) ## 1.0.0 * Introduce `:remove_link` action in pipelines and bins. diff --git a/lib/membrane/bin.ex b/lib/membrane/bin.ex index 3937eeb38..d13151fd4 100644 --- a/lib/membrane/bin.ex +++ b/lib/membrane/bin.ex @@ -135,7 +135,7 @@ defmodule Membrane.Bin do as an internal membrane message. Can be used for receiving data from non-membrane processes. - By default, it ignores the received message. + By default, it logs and ignores the received message. """ @callback handle_info( message :: any, @@ -317,6 +317,7 @@ defmodule Membrane.Bin do only: [def_input_pad: 2, def_output_pad: 2, def_options: 1, def_clock: 0, def_clock: 1] require Membrane.Core.Child.PadsSpecs + require Membrane.Logger Membrane.Core.Child.PadsSpecs.ensure_default_membrane_pads() @@ -344,7 +345,14 @@ defmodule Membrane.Bin do def handle_playing(_ctx, state), do: {[], state} @impl true - def handle_info(message, _ctx, state), do: {[], state} + def handle_info(message, _ctx, state) do + Membrane.Logger.warning(""" + Received message but no handle_info callback has been specified. Ignoring. + Message: #{inspect(message)}\ + """) + + {[], state} + end @impl true def handle_spec_started(new_children, _ctx, state), do: {[], state} diff --git a/lib/membrane/element/base.ex b/lib/membrane/element/base.ex index ef49ae086..b205ca676 100644 --- a/lib/membrane/element/base.ex +++ b/lib/membrane/element/base.ex @@ -78,7 +78,7 @@ defmodule Membrane.Element.Base do as an internal membrane message. Useful for receiving ticks from timer, data sent from NIFs or other stuff. - By default, it ignores the received message. + By default, it logs and ignores the received message. """ @callback handle_info( message :: any(), @@ -251,6 +251,7 @@ defmodule Membrane.Element.Base do import unquote(__MODULE__), only: [def_clock: 0, def_clock: 1, def_options: 1] require Membrane.Core.Child.PadsSpecs + require Membrane.Logger Membrane.Core.Child.PadsSpecs.ensure_default_membrane_pads() @@ -274,7 +275,14 @@ defmodule Membrane.Element.Base do def handle_playing(_context, state), do: {[], state} @impl true - def handle_info(_message, _context, state), do: {[], state} + def handle_info(message, _context, state) do + Membrane.Logger.warning(""" + Received message but no handle_info callback has been specified. Ignoring. + Message: #{inspect(message)}\ + """) + + {[], state} + end @impl true def handle_pad_added(_pad, _context, state), do: {[], state} diff --git a/lib/membrane/pipeline.ex b/lib/membrane/pipeline.ex index 7f3b783e7..0031861ee 100644 --- a/lib/membrane/pipeline.ex +++ b/lib/membrane/pipeline.ex @@ -170,7 +170,7 @@ defmodule Membrane.Pipeline do as an internal membrane message. Useful for receiving data sent from NIFs or other stuff. - By default, it ignores the received message. + By default, it logs and ignores the received message. """ @callback handle_info( message :: any, @@ -457,6 +457,7 @@ defmodule Membrane.Pipeline do # credo:disable-for-next-line Credo.Check.Refactor.LongQuoteBlocks quote do alias unquote(__MODULE__) + require Membrane.Logger @behaviour unquote(__MODULE__) unquote(bring_spec) @@ -492,7 +493,14 @@ defmodule Membrane.Pipeline do def handle_playing(_ctx, state), do: {[], state} @impl true - def handle_info(message, _ctx, state), do: {[], state} + def handle_info(message, _ctx, state) do + Membrane.Logger.warning(""" + Received message but no handle_info callback has been specified. Ignoring. + Message: #{inspect(message)}\ + """) + + {[], state} + end @impl true def handle_spec_started(new_children, _ctx, state), do: {[], state}