O retorno de chamada do Passport-Google-OAuth não está funcionando

Eu tenho o seguinte código de nó usando passport-google-oauth ...

app.get('/auth/google', passport.authenticate('google', { scope : ['profile', 'email'] }));

app.get('/auth/google/callback', function(req,res) {
    console.log("callback");
    passport.authenticate('google', {
                successRedirect : '/signin',
                failureRedirect : '/signin'
    });
});

e...

passport.serializeUser(function(user, done) {
    console.log("ser");
    done(null, user.id);
});

passport.deserializeUser(function(id, done) {
    console.log("des");
    User.findById(id, function(err, user) {
        done(err, user);
    });
});

passport.use(new GoogleStrategy({

    clientID        : 'id',
    clientSecret    : 'key',
    callbackURL     : 'http://host/auth/google/callback',
},
function(token, rtoken, profile, done) {
   console.log("proc");
   console.log(profile);
   done(null, profile);
}));

O problema é que o retorno de chamada está sendo chamado, mas nada mais acontece. A função de processamento nunca é acessada. O retorno de chamada acaba atingindo o tempo limite. Alguma idéia de onde eu errei?

questionAnswers(2)

yourAnswerToTheQuestion