Set Timeouts

Understand the details of game processes time out when they’re inactive.

We'll cover the following

There’s another case we need to handle before we’re done with this section. What happens if a player starts a game and then abandons it somewhere along the way? We don’t want to let those processes just sit there taking up system resources.

Fortunately, GenServer gives us an automated way to have processes time out and shut themselves down if they haven’t received a new message in a given number of milliseconds. We just need to do is add a fourth element to any of the GenServer reply tuples. This will be a positive integer representing the number of milliseconds to wait before timing out {:reply, :some_reply, %{}, 1000}.

Setting a test timeout

Let’s add some modifications to the Game module so game processes time themselves out when they’re inactive. First, let’s set a module attribute to fifteen seconds—long enough to write quick commands in IEx, but short enough to wait for:

@timeout 15000

Then, let’s add it to the return tuple for Game.init/1:

{:ok, %{player1: player1, player2: player2, rules: %Rules{}}, @timeout}

Get hands-on with 1300+ tech skills courses.