summaryrefslogtreecommitdiff
path: root/spec/controllers/registrations/experience_levels_controller_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/controllers/registrations/experience_levels_controller_spec.rb')
-rw-r--r--spec/controllers/registrations/experience_levels_controller_spec.rb143
1 files changed, 143 insertions, 0 deletions
diff --git a/spec/controllers/registrations/experience_levels_controller_spec.rb b/spec/controllers/registrations/experience_levels_controller_spec.rb
new file mode 100644
index 00000000000..1fc728f5de8
--- /dev/null
+++ b/spec/controllers/registrations/experience_levels_controller_spec.rb
@@ -0,0 +1,143 @@
+# frozen_string_literal: true
+
+require 'spec_helper'
+
+describe Registrations::ExperienceLevelsController do
+ let_it_be(:namespace) { create(:group, path: 'group-path' ) }
+ let_it_be(:user) { create(:user) }
+
+ let(:params) { { namespace_path: namespace.to_param } }
+
+ describe 'GET #show' do
+ subject { get :show, params: params }
+
+ context 'with an unauthenticated user' do
+ it { is_expected.to have_gitlab_http_status(:redirect) }
+ it { is_expected.to redirect_to(new_user_session_path) }
+ end
+
+ context 'with an authenticated user' do
+ before do
+ sign_in(user)
+ stub_experiment_for_user(onboarding_issues: true)
+ end
+
+ it { is_expected.to have_gitlab_http_status(:ok) }
+ it { is_expected.to render_template(:show) }
+
+ context 'when not part of the onboarding issues experiment' do
+ before do
+ stub_experiment_for_user(onboarding_issues: false)
+ end
+
+ it { is_expected.to have_gitlab_http_status(:not_found) }
+ end
+ end
+ end
+
+ describe 'PUT/PATCH #update' do
+ subject { patch :update, params: params }
+
+ context 'with an unauthenticated user' do
+ it { is_expected.to have_gitlab_http_status(:redirect) }
+ it { is_expected.to redirect_to(new_user_session_path) }
+ end
+
+ context 'with an authenticated user' do
+ before do
+ sign_in(user)
+ stub_experiment_for_user(onboarding_issues: true)
+ end
+
+ context 'when not part of the onboarding issues experiment' do
+ before do
+ stub_experiment_for_user(onboarding_issues: false)
+ end
+
+ it { is_expected.to have_gitlab_http_status(:not_found) }
+ end
+
+ context 'when user is successfully updated' do
+ it { is_expected.to set_flash[:message].to('Welcome! You have signed up successfully.') }
+
+ context 'when no experience_level is sent' do
+ before do
+ user.user_preference.update_attribute(:experience_level, :novice)
+ end
+
+ it 'will unset the user’s experience level' do
+ expect { subject }.to change { user.reload.experience_level }.to(nil)
+ end
+ end
+
+ context 'when an expected experience level is sent' do
+ let(:params) { super().merge(experience_level: :novice) }
+
+ it 'sets the user’s experience level' do
+ expect { subject }.to change { user.reload.experience_level }.from(nil).to('novice')
+ end
+ end
+
+ context 'when an unexpected experience level is sent' do
+ let(:params) { super().merge(experience_level: :nonexistent) }
+
+ it 'raises an exception' do
+ expect { subject }.to raise_error(ArgumentError, "'nonexistent' is not a valid experience_level")
+ end
+ end
+
+ context 'when a namespace_path is sent' do
+ it { is_expected.to have_gitlab_http_status(:redirect) }
+ it { is_expected.to redirect_to(group_path(namespace)) }
+ end
+
+ context 'when no namespace_path is sent' do
+ let(:params) { super().merge(namespace_path: nil) }
+
+ it { is_expected.to have_gitlab_http_status(:redirect) }
+ it { is_expected.to redirect_to(root_path) }
+ end
+
+ describe 'applying the chosen level' do
+ context "when an 'onboarding_issues_settings' cookie does not exist" do
+ let(:params) { super().merge(experience_level: :novice) }
+
+ it 'does not change the cookie' do
+ expect { subject }.not_to change { cookies[:onboarding_issues_settings] }
+ end
+ end
+
+ context "when an 'onboarding_issues_settings' cookie does exist" do
+ before do
+ request.cookies[:onboarding_issues_settings] = '{}'
+ end
+
+ context 'when novice' do
+ let(:params) { super().merge(experience_level: :novice) }
+
+ it "adds a 'hideAdvanced' setting to the cookie" do
+ expect { subject }.to change { Gitlab::Json.parse(cookies[:onboarding_issues_settings])['hideAdvanced'] }.from(nil).to(true)
+ end
+ end
+
+ context 'when experienced' do
+ let(:params) { super().merge(experience_level: :experienced) }
+
+ it 'does not change the cookie' do
+ expect { subject }.not_to change { cookies[:onboarding_issues_settings] }
+ end
+ end
+ end
+ end
+ end
+
+ context 'when user update fails' do
+ before do
+ allow_any_instance_of(User).to receive(:save).and_return(false)
+ end
+
+ it { is_expected.to render_template(:show) }
+ end
+ end
+ end
+end