about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--app/controllers/auth/sessions_controller.rb8
-rw-r--r--app/models/user.rb4
-rw-r--r--spec/controllers/auth/sessions_controller_spec.rb31
3 files changed, 39 insertions, 4 deletions
diff --git a/app/controllers/auth/sessions_controller.rb b/app/controllers/auth/sessions_controller.rb
index 42b1d4ead..fe0adc9bb 100644
--- a/app/controllers/auth/sessions_controller.rb
+++ b/app/controllers/auth/sessions_controller.rb
@@ -1,3 +1,11 @@
 class Auth::SessionsController < Devise::SessionsController
+  include Devise::Controllers::Rememberable
+
   layout 'auth'
+
+  def create
+    super do |resource|
+      remember_me(resource)
+    end
+  end
 end
diff --git a/app/models/user.rb b/app/models/user.rb
index 8b2cd22e0..a80efb50d 100644
--- a/app/models/user.rb
+++ b/app/models/user.rb
@@ -11,8 +11,4 @@ class User < ActiveRecord::Base
   def admin?
     self.admin
   end
-
-  def remember_me
-    (super == nil) ? '1' : super
-  end
 end
diff --git a/spec/controllers/auth/sessions_controller_spec.rb b/spec/controllers/auth/sessions_controller_spec.rb
new file mode 100644
index 000000000..004a44fba
--- /dev/null
+++ b/spec/controllers/auth/sessions_controller_spec.rb
@@ -0,0 +1,31 @@
+require 'rails_helper'
+
+RSpec.describe Auth::SessionsController, type: :controller do
+  describe 'GET #new' do
+    before do
+      request.env["devise.mapping"] = Devise.mappings[:user]
+    end
+
+    it 'returns http success' do
+      get :new
+      expect(response).to have_http_status(:success)
+    end
+  end
+
+  describe 'POST #create' do
+    let(:user) { Fabricate(:user, email: 'foo@bar.com', password: 'abcdefgh') }
+
+    before do
+      request.env["devise.mapping"] = Devise.mappings[:user]
+      post :create, user: { email: user.email, password: user.password }
+    end
+
+    it 'redirects to home page' do
+      expect(response).to redirect_to(root_path)
+    end
+
+    it 'logs the user in' do
+      expect(controller.current_user).to eq user
+    end
+  end
+end