Skip to content

Commit

Permalink
Make sure state of the pipeline is updated after handle_call (#526)
Browse files Browse the repository at this point in the history
  • Loading branch information
varsill authored Feb 13, 2023
1 parent e50ada5 commit 443c7d3
Show file tree
Hide file tree
Showing 2 changed files with 38 additions and 7 deletions.
15 changes: 8 additions & 7 deletions lib/membrane/core/pipeline.ex
Original file line number Diff line number Diff line change
Expand Up @@ -132,13 +132,14 @@ defmodule Membrane.Core.Pipeline do
def handle_call(message, from, state) do
context = &CallbackContext.Call.from_state(&1, from: from)

CallbackHandler.exec_and_handle_callback(
:handle_call,
Membrane.Core.Pipeline.ActionHandler,
%{context: context},
[message],
state
)
state =
CallbackHandler.exec_and_handle_callback(
:handle_call,
Membrane.Core.Pipeline.ActionHandler,
%{context: context},
[message],
state
)

{:noreply, state}
end
Expand Down
30 changes: 30 additions & 0 deletions test/membrane/integration/synchronous_pipeline_call_test.exs
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
defmodule PipelineSynchronousCallTest do
use ExUnit.Case, async: false

import Membrane.Testing.Assertions

alias Membrane.Pipeline

@msg "Some message"
Expand Down Expand Up @@ -46,4 +48,32 @@ defmodule PipelineSynchronousCallTest do
reply = Pipeline.call(pid, {:instant_reply, @msg})
assert reply == @msg
end

defmodule PipelineSpawningChildrenOnCall do
use Membrane.Pipeline

@impl true
def handle_init(_ctx, _options) do
{[], %{}}
end

@impl true
def handle_call(:spawn_children, _ctx, state) do
spec =
child(:source, %Membrane.Testing.Source{output: [1, 2, 3]})
|> child(:sink, Membrane.Testing.Sink)

{[spec: spec, playback: :playing, reply: nil], state}
end
end

test "Pipeline should be able to perform actions before replying on handle_call" do
{:ok, _supervisor, pipeline_pid} =
Membrane.Testing.Pipeline.start(module: PipelineSpawningChildrenOnCall)

Membrane.Pipeline.call(pipeline_pid, :spawn_children)
assert_pipeline_play(pipeline_pid)
assert_end_of_stream(pipeline_pid, :sink)
Pipeline.terminate(pipeline_pid, blocking?: true)
end
end

0 comments on commit 443c7d3

Please sign in to comment.