88 lines
2.4 KiB
Ruby
88 lines
2.4 KiB
Ruby
require 'rails_helper'
|
||
require 'shared_account_spec'
|
||
|
||
RSpec.describe "Account request", :type => :request do
|
||
|
||
describe "注册用户" do
|
||
include_context "create user"
|
||
it "正常注册可以成功" do
|
||
shared_register
|
||
expect(response).to redirect_to(my_account_url)
|
||
end
|
||
|
||
it "修改用户资料" do
|
||
shared_register
|
||
shared_update_user
|
||
expect(response).to redirect_to(user_url(session[:user_id]))
|
||
end
|
||
end
|
||
|
||
describe "用户登录" do
|
||
let(:user){FactoryGirl.create(:user)}
|
||
|
||
it "未登录访问需要登录页面会自动跳入登录页" do
|
||
get 'my/page'
|
||
expect(response).to redirect_to(signin_path)
|
||
end
|
||
|
||
context "正常登录" do
|
||
before{ post signin_path, username: user.login, password: user.password }
|
||
it "登录成功,正常跳转" do
|
||
expect(response).to redirect_to(my_account_url)
|
||
end
|
||
|
||
it "登录成功,session正确" do
|
||
expect(user.id).to eq(session[:user_id])
|
||
end
|
||
|
||
it "正常登录后可以访问需要认证的页面" do
|
||
get 'my/account'
|
||
expect(response).to have_http_status(:success)
|
||
expect(response.body).to include(user.login)
|
||
end
|
||
end
|
||
|
||
context "登录失败" do
|
||
before{post signin_path, username: user.login, password: 'wrong password'}
|
||
it {expect(response).to render_template('account/login')}
|
||
it "跳加登录页面" do
|
||
get 'my/page'
|
||
expect(response).to redirect_to(signin_path)
|
||
end
|
||
end
|
||
|
||
context "自动登录" do
|
||
before{
|
||
post signin_path, username: user.login, password: user.password, autologin: 1
|
||
}
|
||
it "登录成功跳转到个人首页" do
|
||
expect(response).to redirect_to(my_account_url)
|
||
end
|
||
|
||
it "验证token" do
|
||
token = Token.first
|
||
expect(token).not_to be_nil
|
||
expect(user.id).to eq(token.user.id)
|
||
expect(token.action).to eq('autologin')
|
||
expect(user.id).to eq(session[:user_id])
|
||
expect(token.value).to eq(cookies['autologin'])
|
||
end
|
||
|
||
it 'session 失效后,可以用token自动重新登录' do
|
||
token = Token.first
|
||
reset!
|
||
User.current = nil
|
||
get my_account_url
|
||
expect(response).to redirect_to(signin_url)
|
||
cookies[:autologin] = token.value
|
||
get my_account_url
|
||
expect(response).to have_http_status(:success)
|
||
expect(response.body).to include(user.login)
|
||
end
|
||
|
||
end
|
||
|
||
end
|
||
end
|
||
|