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