Codename-404
Elixir function doesn't continue if takes too long
def func do
convert_video.(1280)
IO.puts(“Conversion done, starting to upload”)
end
I have this function, but problem is, if convert_video.(1280) takes too long, IO.puts(“Conversion done, starting to upload”) line does not execute, infact nothing after executes.
However if convert_video.(1280) takes short time, all the codes below executes.
How to make sure function always executes fully?
Marked As Solved
lud
Also what you can do is register your process to give it a name:
def func do
Process.register(self(), :hello)
convert_video.(1280)
IO.puts("Conversion done, starting to upload")
end
Then start your app with iex (like iex -S mix phx.server if using Phoenix) and run a single long conversion (otherwise process registration will clash), and once you see in the OS that it is finished, you can call this in IEx:
pid = Process.whereis(:hello)
This will return a pid, or nil. If it returns nil it means that your function either crashed silently, for some reason, or completed but you could not see the output of IO.puts for some reason (but it was executed as Robert says).
If you get a pid, then your process is still awaiting something, or looping forever somewhere. You can then call this in IEx shell:
Process.info(pid, :current_stacktrace)
This will show what is that process doing at the moment.
For instance if for some reason the process is still awaiting a return from a system command, you may see this:
iex(7)> pid = spawn(fn -> System.cmd("watch", ["sleep", "1000"]) end)
#PID<0.116.0>
iex(8)> Process.info(pid, :current_stacktrace)
{:current_stacktrace,
[
{System, :do_port_byte, 3, [file: ~c"lib/system.ex", line: 1118]},
{System, :do_cmd, 3, [file: ~c"lib/system.ex", line: 1107]},
{:elixir, :eval_external_handler, 3, [file: ~c"src/elixir.erl", line: 396]}
]}
Also Liked
rvirding
A function always executes until it is completed.
Codename-404
That was really helpful, Thank you very much ~
So, I found out, the process was returing nil after a while, then I realized it was the phoenix timeout after 60 seconds by default.
So I increased the default timeout behaviour, and now it works. Alhamdulillah ~
Thanks again, May Allah return the favour upon you in a greater way ~







