about summary refs log tree commit diff
path: root/spec/controllers/settings/sessions_controller_spec.rb
diff options
context:
space:
mode:
authorDavid Yip <yipdw@member.fsf.org>2018-06-08 00:33:09 -0500
committerGitHub <noreply@github.com>2018-06-08 00:33:09 -0500
commita9515f3186b49df63436b98d382ee6a6b755387d (patch)
treed771e65a58d3c69ba1c08c3fc145f24b5b806274 /spec/controllers/settings/sessions_controller_spec.rb
parentf8d50a40701f344ea7c2a0e5475bbcbc727ef930 (diff)
parent8142bd2553e7819722fdfc401e06cb10eeddd230 (diff)
Merge pull request #535 from glitch-soc/merge-upstream
Merge upstream
Diffstat (limited to 'spec/controllers/settings/sessions_controller_spec.rb')
-rw-r--r--spec/controllers/settings/sessions_controller_spec.rb30
1 files changed, 30 insertions, 0 deletions
diff --git a/spec/controllers/settings/sessions_controller_spec.rb b/spec/controllers/settings/sessions_controller_spec.rb
new file mode 100644
index 000000000..52b204a6a
--- /dev/null
+++ b/spec/controllers/settings/sessions_controller_spec.rb
@@ -0,0 +1,30 @@
+require 'rails_helper'
+
+describe Settings::SessionsController do
+  render_views
+
+  let(:user) { Fabricate(:user) }
+  let(:session_activation) { Fabricate(:session_activation, user: user) }
+  before { sign_in user, scope: :user }
+
+  describe 'DELETE #destroy' do
+    subject { delete :destroy, params: { id: id } }
+
+    context 'when session activation exists' do
+      let(:id) { session_activation.id }
+
+      it 'destroys session activation' do
+        is_expected.to redirect_to edit_user_registration_path
+        expect(SessionActivation.find_by(id: id)).to be_nil
+      end
+    end
+
+    context 'when session activation does not exist' do
+      let(:id) { session_activation.id + 1000 }
+
+      it 'destroys session activation' do
+        is_expected.to have_http_status :not_found
+      end
+    end
+  end
+end