1d1363e2bb
Ran: - git format-patch v9.2.2..v9.2.5 --stdout > patchfile.patch - git checkout -b 9-2-5-security-patch origin/v9.2.2 - git apply patchfile.patch - git commit - [Got the sha ref for the commit] - git checkout -b upstream-9-2-security master - git cherry-pick <SHA of the patchfile commit> - [Resolved conflicts] - git cherry-pick --continue
226 lines
6.4 KiB
Ruby
226 lines
6.4 KiB
Ruby
class Spinach::Features::Profile < Spinach::FeatureSteps
|
|
include SharedAuthentication
|
|
include SharedPaths
|
|
|
|
step 'I should see my profile info' do
|
|
expect(page).to have_content "This information will appear on your profile"
|
|
end
|
|
|
|
step 'I change my profile info' do
|
|
fill_in 'user_skype', with: 'testskype'
|
|
fill_in 'user_linkedin', with: 'testlinkedin'
|
|
fill_in 'user_twitter', with: 'testtwitter'
|
|
fill_in 'user_website_url', with: 'testurl'
|
|
fill_in 'user_location', with: 'Ukraine'
|
|
fill_in 'user_bio', with: 'I <3 GitLab'
|
|
fill_in 'user_organization', with: 'GitLab'
|
|
click_button 'Update profile settings'
|
|
@user.reload
|
|
end
|
|
|
|
step 'I should see new profile info' do
|
|
expect(@user.skype).to eq 'testskype'
|
|
expect(@user.linkedin).to eq 'testlinkedin'
|
|
expect(@user.twitter).to eq 'testtwitter'
|
|
expect(@user.website_url).to eq 'testurl'
|
|
expect(@user.bio).to eq 'I <3 GitLab'
|
|
expect(@user.organization).to eq 'GitLab'
|
|
expect(find('#user_location').value).to eq 'Ukraine'
|
|
end
|
|
|
|
step 'I change my avatar' do
|
|
attach_file(:user_avatar, File.join(Rails.root, 'spec', 'fixtures', 'banana_sample.gif'))
|
|
click_button "Update profile settings"
|
|
@user.reload
|
|
end
|
|
|
|
step 'I should see new avatar' do
|
|
expect(@user.avatar).to be_instance_of AvatarUploader
|
|
expect(@user.avatar.url).to eq "/uploads/system/user/avatar/#{@user.id}/banana_sample.gif"
|
|
end
|
|
|
|
step 'I should see the "Remove avatar" button' do
|
|
expect(page).to have_link("Remove avatar")
|
|
end
|
|
|
|
step 'I have an avatar' do
|
|
attach_file(:user_avatar, File.join(Rails.root, 'spec', 'fixtures', 'banana_sample.gif'))
|
|
click_button "Update profile settings"
|
|
@user.reload
|
|
end
|
|
|
|
step 'I remove my avatar' do
|
|
click_link "Remove avatar"
|
|
@user.reload
|
|
end
|
|
|
|
step 'I should see my gravatar' do
|
|
expect(@user.avatar?).to eq false
|
|
end
|
|
|
|
step 'I should not see the "Remove avatar" button' do
|
|
expect(page).not_to have_link("Remove avatar")
|
|
end
|
|
|
|
step 'I should see the gravatar host link' do
|
|
expect(page).to have_link("gravatar.com")
|
|
end
|
|
|
|
step 'I try change my password w/o old one' do
|
|
page.within '.update-password' do
|
|
fill_in "user_password", with: "22233344"
|
|
fill_in "user_password_confirmation", with: "22233344"
|
|
click_button "Save password"
|
|
end
|
|
end
|
|
|
|
step 'I change my password' do
|
|
page.within '.update-password' do
|
|
fill_in "user_current_password", with: "12345678"
|
|
fill_in "user_password", with: "22233344"
|
|
fill_in "user_password_confirmation", with: "22233344"
|
|
click_button "Save password"
|
|
end
|
|
end
|
|
|
|
step 'I unsuccessfully change my password' do
|
|
page.within '.update-password' do
|
|
fill_in "user_current_password", with: "12345678"
|
|
fill_in "user_password", with: "password"
|
|
fill_in "user_password_confirmation", with: "confirmation"
|
|
click_button "Save password"
|
|
end
|
|
end
|
|
|
|
step "I should see a missing password error message" do
|
|
page.within ".flash-container" do
|
|
expect(page).to have_content "You must provide a valid current password"
|
|
end
|
|
end
|
|
|
|
step "I should see a password error message" do
|
|
page.within '.alert-danger' do
|
|
expect(page).to have_content "Password confirmation doesn't match"
|
|
end
|
|
end
|
|
|
|
step 'I have activity' do
|
|
create(:closed_issue_event, author: current_user)
|
|
end
|
|
|
|
step 'I should see my activity' do
|
|
expect(page).to have_content "Signed in with standard authentication"
|
|
end
|
|
|
|
step 'my password is expired' do
|
|
current_user.update_attributes(password_expires_at: Time.now - 1.hour)
|
|
end
|
|
|
|
step "I am not an ldap user" do
|
|
current_user.identities.delete
|
|
expect(current_user.ldap_user?).to eq false
|
|
end
|
|
|
|
step 'I redirected to expired password page' do
|
|
expect(current_path).to eq new_profile_password_path
|
|
end
|
|
|
|
step 'I submit new password' do
|
|
fill_in :user_current_password, with: '12345678'
|
|
fill_in :user_password, with: '12345678'
|
|
fill_in :user_password_confirmation, with: '12345678'
|
|
click_button "Set new password"
|
|
end
|
|
|
|
step 'I redirected to sign in page' do
|
|
expect(current_path).to eq new_user_session_path
|
|
end
|
|
|
|
step 'I should be redirected to password page' do
|
|
expect(current_path).to eq edit_profile_password_path
|
|
end
|
|
|
|
step 'I should be redirected to account page' do
|
|
expect(current_path).to eq profile_account_path
|
|
end
|
|
|
|
step 'I click on my profile picture' do
|
|
find(:css, '.header-user-dropdown-toggle').click
|
|
|
|
page.within ".header-user" do
|
|
click_link "Profile"
|
|
end
|
|
end
|
|
|
|
step 'I should see my user page' do
|
|
page.within ".cover-block" do
|
|
expect(page).to have_content current_user.name
|
|
expect(page).to have_content current_user.username
|
|
end
|
|
end
|
|
|
|
step 'I have group with projects' do
|
|
@group = create(:group)
|
|
@group.add_owner(current_user)
|
|
@project = create(:project, :repository, namespace: @group)
|
|
@event = create(:closed_issue_event, project: @project)
|
|
|
|
@project.team << [current_user, :master]
|
|
end
|
|
|
|
step 'I should see groups I belong to' do
|
|
page.within ".content" do
|
|
click_link "Groups"
|
|
end
|
|
|
|
page.within "#groups" do
|
|
expect(page).to have_content @group.name
|
|
end
|
|
end
|
|
|
|
step 'I should see application form' do
|
|
expect(page).to have_content "Add new application"
|
|
end
|
|
|
|
step 'I fill application form out and submit' do
|
|
fill_in :doorkeeper_application_name, with: 'test'
|
|
fill_in :doorkeeper_application_redirect_uri, with: 'https://test.com'
|
|
click_on "Save application"
|
|
end
|
|
|
|
step 'I see application' do
|
|
expect(page).to have_content "Application: test"
|
|
expect(page).to have_content "Application Id"
|
|
expect(page).to have_content "Secret"
|
|
end
|
|
|
|
step 'I click edit' do
|
|
click_on "Edit"
|
|
end
|
|
|
|
step 'I see edit application form' do
|
|
expect(page).to have_content "Edit application"
|
|
end
|
|
|
|
step 'I change name of application and submit' do
|
|
expect(page).to have_content "Edit application"
|
|
fill_in :doorkeeper_application_name, with: 'test_changed'
|
|
click_on "Save application"
|
|
end
|
|
|
|
step 'I see that application was changed' do
|
|
expect(page).to have_content "test_changed"
|
|
expect(page).to have_content "Application Id"
|
|
expect(page).to have_content "Secret"
|
|
end
|
|
|
|
step 'I click to remove application' do
|
|
page.within '.oauth-applications' do
|
|
click_on "Destroy"
|
|
end
|
|
end
|
|
|
|
step "I see that application is removed" do
|
|
expect(page.find(".oauth-applications")).not_to have_content "test_changed"
|
|
end
|
|
end
|