Mnho229

Mnho229

Elixir in Action - ch07 - implementing a cache help

Pretty new to Elixir and I’ve been going through Elixir in Action. I sense this issue could be solved if I drop down to a previous Elixir version but any advice to be able to do this on 1.11 would be very nice.

In 7.2.1 it talks about implementing a cache to manage multiple to-do lists.

Code from the book’s repo: https://github.com/sasa1977/elixir-in-action/tree/master/code_samples/ch07/todo_cache/lib/todo

The problem is, when I run these commands after iex -S mix

{:ok, cache} = Todo.Cache.start()
{:ok, #PID<0.154.0>}
Todo.Cache.server_process(cache, "Bob's List")
#PID<0.156.0>
Todo.Cache.server_process(cache, "Alice's Lists")

I receive the following error:

21:28:33.353 [error] GenServer #PID<0.154.0> terminating
** (MatchError) no match of right hand side value: {:error, {:already_started, #PID<0.156.0>}}
    (todo_cache 0.1.0) lib/todo/cache.ex:29: Todo.Cache.handle_call/3
    (stdlib 3.13.2) gen_server.erl:706: :gen_server.try_handle_call/4
    (stdlib 3.13.2) gen_server.erl:735: :gen_server.handle_msg/6
    (stdlib 3.13.2) proc_lib.erl:226: :proc_lib.init_p_do_apply/3
Last message (from #PID<0.152.0>): {:server_process, "Bob's Lists"}
State: %{"Bob's List" => #PID<0.156.0>}
Client #PID<0.152.0> is alive

    (stdlib 3.13.2) gen.erl:208: :gen.do_call/4
    (elixir 1.11.2) lib/gen_server.ex:1024: GenServer.call/3
    (stdlib 3.13.2) erl_eval.erl:680: :erl_eval.do_apply/6
    (elixir 1.11.2) src/elixir.erl:280: :elixir.recur_eval/3
    (elixir 1.11.2) src/elixir.erl:265: :elixir.eval_forms/3
    (iex 1.11.2) lib/iex/evaluator.ex:261: IEx.Evaluator.handle_eval/5
    (iex 1.11.2) lib/iex/evaluator.ex:242: IEx.Evaluator.do_eval/3
    (iex 1.11.2) lib/iex/evaluator.ex:220: IEx.Evaluator.eval/3
** (exit) exited in: GenServer.call(#PID<0.154.0>, {:server_process, "Bob's Lists"}, 5000)
    ** (EXIT) an exception was raised:
        ** (MatchError) no match of right hand side value: {:error, {:already_started, #PID<0.156.0>}}
            (todo_cache 0.1.0) lib/todo/cache.ex:29: Todo.Cache.handle_call/3
            (stdlib 3.13.2) gen_server.erl:706: :gen_server.try_handle_call/4
            (stdlib 3.13.2) gen_server.erl:735: :gen_server.handle_msg/6
            (stdlib 3.13.2) proc_lib.erl:226: :proc_lib.init_p_do_apply/3
    (elixir 1.11.2) lib/gen_server.ex:1027: GenServer.call/3

This seems to only happen when I change the string in the second parameter. Adding another clause for the case statement didn’t stop the error. How do I get past this?

Marked As Solved

APB9785

APB9785

Creator of ECSx

I just downloaded the files and compiled them with Elixir 1.11.3.

iex(1)> c("server.ex")
warning: ...
[Todo.Server]
iex(2)> c("cache.ex")
[Todo.Cache]
iex(3)> c("list.ex")
warning: ...
[Todo.List]
iex(4)> {:ok, cache} = Todo.Cache.start
{:ok, #PID<0.129.0>}
iex(5)> Todo.Cache.server_process(cache, "Bob's List")
#PID<0.132.0>
iex(6)> Todo.Cache.server_process(cache, "Alice's Lists")
#PID<0.134.0>

No errors. So there must be some differences, either between your code and the repo code, or in the commands you’re running. Glancing at the code, that string in the second parameter is only used as a map key. You should be able to pass any string as the name.

Also Liked

Mnho229

Mnho229

It did work when I cloned the code over. So I took another look, and then it turns out my server.ex had its name parameter filled in. And the files I was meticulously looking over might have been in a different folder.

This is embarrassing.

Thank you all for replying.

Where Next?

Popular in Questions Top

chokchit
** (DBConnection.ConnectionError) connection not available and request was dropped from queue after 2733ms. You can configure how long re...
New
vertexbuffer
Hello, can anybody help here..? I have a list of players and I what to delete an element, but every for loop the list is reverting to ori...
New
senggen
Erlang/OTP 25 [erts-13.2.2] [source] [64-bit] [smp:8:8] [ds:8:8:10] [async-threads:1] 15:22:35.803 [error] gen_event {lager_file_backend...
New
Patoshizzle
After calling mix ecto.create I get this error: 17:00:32.162 [error] GenServer #PID&lt;0.412.0&gt; terminating ** (Postgrex.Error) FATAL...
New
myronmarston
The Elixir Typespec docs show the following syntax for keyword lists in typespecs: # ... | [key: type] # keyword lists...
New
nobody
How to bind a phoenix app to a specific ip address? could not find anything about that, nowhere, unfortunately, but for me this is quite...
New
jaysoifer
Is there a way to rollback a specific migration and only that one (“skipping” all the other ones)? Would mix ecto.rollback -v 200809061...
New
beno
I will often find my self writing things similar to: case some_value do nil -&gt; something() "" -&gt; something() _ -&gt; somethi...
New
komlanvi
Hi everyone, I was playing with phoenix liveView but I run into an issue. I have a form and want to validate each input text when the te...
New
vonH
In asking this question I am more interested about the expressiveness of the language itself and less concerned about the availability of...
New

Other popular topics Top

sen
Hi All, I set a environment variables in dev.exs , like below code. when i start server, how can i set the ${enable} value? thanks. d...
New
albydarned
Hello all! I am typing this post from my new MacBook Pro with the M1 chip. I’m loving it so far, and will probably use it as my daily dr...
New
Nvim
Anybody knows a comprehensive comparison of Django and Phoenix, thanks for the help. Where are they similar? Where do they differ the m...
New
Patoshizzle
After calling mix ecto.create I get this error: 17:00:32.162 [error] GenServer #PID&lt;0.412.0&gt; terminating ** (Postgrex.Error) FATAL...
New
Qqwy
Original source of discussion: This topic on the Pragmatic Programmers’ Functional Web Development with Elixir, OTP, and Phoenix forum. ...
New
shijith.k
I am trying to start a new phoenix project with elixir 1.9, but mix phx.new does not work. It says that ** (Mix) The task "phx.new" could...
New
AstonJ
We’ve put together this wiki for Phoenix LiveView - please feel free to add any info you feel is worth including. What is Phoenix LiveV...
New
hariharasudhan94
I would like to know what is the best IDE for elixir development?
New
AstonJ
Seen any cool LiveView demos, sample apps or examples? Please post them here! :003:
New
jononomo
For some reason my phoenix channels are working for me in my local dev environment, but as soon as I deploy via Docker, I get a 403 error...
New

We're in Beta

About us Mission Statement