Enviando mensagens client-> server-> client em socket.io em node.js

Estou usando o NodeJS + Socket.IO para um jogo web simples. Funciona. Por quê?

Aqui é meuserver.js

var app = require('express').createServer();
var io = require('socket.io').listen(app);

io.sockets.on('connection', function (socket) {
socket.on('set nickname' , function (nickname) {
socket.nickname = nickname;
console.log(nickname + ' just connected!');

});

socket.on('msg' , function (msg) {
socket.msg = msg;
io.sockets.emit('response', msg);
});

socket.on('updatePlayer' , function (updatePlayer) {
console.log("Someone just moved on the map!");
});

});

app.listen(8080);

A razão pela qual eu sei que funciona é porque, quando eu carrego a página e este script executa:

// SERVER STUFF
socket.on('connect', function () {
    console.log('We are connected!');
    name = $(".name").val();
    this.emit('set nickname', name, function (success) {});
    msg = name + "|" + currX + "|" + currY + "|" + currentMap;
    this.emit('msg', msg, function (success) {});

    socket.on('response', function (data) {
        var theMsg = data.split("|");
        sayDialog("New player! " + theMsg[0] + " connected on map " + theMsg[3] + " on coordinates (" + theMsg[1] + "," + theMsg[2] + ")");
    });
});

Eu entro na minha caixa de diálogo ("CSS div") algo comoNew player! weka connected on map 4 on coordinates (10,5)

OK, legal, então funciona! No entanto, quando eu "movo" tento enviar uma mensagem para o servidor usando este

  socket.on('updatePlayer', function () {
    console.log("Testing...");
  }); 

Eu nem vejoconsole diga teste. Eu não sei porque.

questionAnswers(2)

yourAnswerToTheQuestion