Estrategia local de pasaporte y cURL

Me gustaría probar mi aplicación de prueba node.js + express + passport.js (RESTful) con CURL. Mi código:

var express = require('express');
var routes = require('./routes');
var http = require('http');
var path = require('path');
var passport = require('passport');
var LocalStrategy = require('passport-local').Strategy;

// Define the strategy to be used by PassportJS
passport.use(new LocalStrategy(
    function(username, password, done) {
        if (username === "admin" && password === "admin") // stupid example
            return done(null, {name: "admin"});

        return done(null, false, { message: 'Incorrect username.' });
    }
));

// Serialized and deserialized methods when got from session
passport.serializeUser(function(user, done) {
    done(null, user);
});

passport.deserializeUser(function(user, done) {
    done(null, user);
});

// Define a middleware function to b,e used for every secured routes
var auth = function(req, res, next){
    if (!req.isAuthenticated())
        res.send(401);
    else
        next();
};

var app = express();

// all environments
app.set('port', process.env.PORT || 3000);
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.json());
app.use(express.urlencoded());
app.use(express.methodOverride());
app.use(passport.initialize());
app.use(passport.session());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));

// development only
if ('development' == app.get('env')) {
    app.use(express.errorHandler());
}

app.get('/test', auth, function(req, res){
    res.send([{name: "user1"}, {name: "user2"}]);
});

app.post('/login', passport.authenticate('local'), function(req, res) {
    res.send(req.user);
});

Llamada / prueba con rizo y

curl "http://localhost:3000/test"

devuelve "No autorizado" (esto es correcto hasta ahora).

Llamar / iniciar sesión (POST) con curl y

curl --data "username=admin&password=admin" http://localhost:3000/login

trabajos. Pero en la siguiente solicitud, mi inicio de sesión fue "olvidado". ¿Es esto porque curl no puede manejar sesiones? ¿Hay algún trabajo alrededor? ¿Es correcto mi procedimiento para una aplicación RESTful?

Respuestas a la pregunta(1)

Su respuesta a la pregunta