我看文档设置cookie 是这么写的
var request = require('supertest')
, should = require('should')
, express = require('express')
, cookieParser = require('cookie-parser');
describe('request.agent(app)', function(){
var app = express();
app.use(cookieParser());
app.get('/', function(req, res){
res.cookie('cookie', 'hey');
res.send();
});
app.get('/return', function(req, res){
if (req.cookies.cookie) res.send(req.cookies.cookie);
else res.send(':(')
});
var agent = request.agent(app);
it('should save cookies', function(done){
agent
.get('/')
.expect('set-cookie', 'cookie=hey; Path=/', done);
})
it('should send cookies', function(done){
agent
.get('/return')
.expect('hey', done);
})
})
这里的
expect('set-cookie', 'cookie=hey; Path=/', done)
'set-cookie'是指操作,然后'cookie=hey; Path=/'这个是cookie值的样子,但是我看api,并没有这种说明,也同样没有说能获取
expect('hey', done);
cookie值的说明
https://github.com/visionmedia/supertest#api
那么session又该如何设置呢?
cookie
的hey
是在這裡設定的:expect('hey', done);
這個斷言之所以能成功是因為,按照你測試用例的書寫順序,肯定先跑過了前一個should save cookies
的case,那cookie
就設定成功了,然後再跑第二個case的時候,服務端部分:至於如何設定
session
,你首先需要一個對應的中間件session補充:
supertest對斷言的部分描述的還是相對比較清晰的:
還有“我不知道supertest能不能直接對cookie和session進行操作”,當然不是,我就看了一眼你的測試用例,就發現
supertest
其實是個模擬客戶端發請求的工具,既然是客戶端,當然不能設定session
。session
是後端處理的,所以我才說是你的後端部分需要增加中間件處理。 (關於session
是什麼,仍然是基礎,這個不是問題,我就算給你說個1000字,也看不見能說的完全清楚,你更不見的有興趣讀完。基礎是必須的,群裡沒有一個「大牛」是基礎不存在的情況下,突然成神的)關於
session
,前幾天剛好回答過一個express-session和passportjs各自都做了哪些事情實現了自動登入?