2015-05-29 23:02:11 +00:00
|
|
|
require 'spec_helper'
|
|
|
|
|
2015-06-28 20:19:52 +00:00
|
|
|
feature 'Group', feature: true do
|
2016-07-12 19:40:05 +00:00
|
|
|
before do
|
|
|
|
login_as(:admin)
|
|
|
|
end
|
|
|
|
|
2016-08-25 16:48:08 +00:00
|
|
|
matcher :have_namespace_error_message do
|
|
|
|
match do |page|
|
|
|
|
page.has_content?("Path can contain only letters, digits, '_', '-' and '.'. Cannot start with '-' or end in '.', '.git' or '.atom'.")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-07-12 19:40:05 +00:00
|
|
|
describe 'creating a group with space in group path' do
|
|
|
|
it 'renders new group form with validation errors' do
|
|
|
|
visit new_group_path
|
|
|
|
fill_in 'Group path', with: 'space group'
|
|
|
|
|
|
|
|
click_button 'Create group'
|
|
|
|
|
|
|
|
expect(current_path).to eq(groups_path)
|
2016-08-25 16:48:08 +00:00
|
|
|
expect(page).to have_namespace_error_message
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'creating a group with .atom at end of group path' do
|
|
|
|
it 'renders new group form with validation errors' do
|
|
|
|
visit new_group_path
|
|
|
|
fill_in 'Group path', with: 'atom_group.atom'
|
|
|
|
|
|
|
|
click_button 'Create group'
|
|
|
|
|
|
|
|
expect(current_path).to eq(groups_path)
|
|
|
|
expect(page).to have_namespace_error_message
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'creating a group with .git at end of group path' do
|
|
|
|
it 'renders new group form with validation errors' do
|
|
|
|
visit new_group_path
|
|
|
|
fill_in 'Group path', with: 'git_group.git'
|
|
|
|
|
|
|
|
click_button 'Create group'
|
|
|
|
|
|
|
|
expect(current_path).to eq(groups_path)
|
|
|
|
expect(page).to have_namespace_error_message
|
2016-07-12 19:40:05 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-10-14 07:06:44 +00:00
|
|
|
describe 'Group Edit' do
|
|
|
|
let(:group) { create(:group) }
|
|
|
|
let(:path) { edit_group_path(group) }
|
|
|
|
|
|
|
|
it 'saves new settings' do
|
|
|
|
expect(group.request_access_enabled).to be_truthy
|
|
|
|
visit path
|
|
|
|
|
|
|
|
find('#group_request_access_enabled').set(false)
|
|
|
|
|
|
|
|
click_button 'Save group'
|
|
|
|
|
|
|
|
expect(page).to have_content 'successfully updated'
|
|
|
|
group.reload
|
|
|
|
expect(group.request_access_enabled).to be_falsey
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'removes group' do
|
|
|
|
visit path
|
|
|
|
|
|
|
|
click_link 'Remove Group'
|
|
|
|
|
|
|
|
expect(page).to have_content "scheduled for deletion"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2015-05-29 23:02:11 +00:00
|
|
|
describe 'description' do
|
|
|
|
let(:group) { create(:group) }
|
|
|
|
let(:path) { group_path(group) }
|
|
|
|
|
|
|
|
it 'parses Markdown' do
|
|
|
|
group.update_attribute(:description, 'This is **my** group')
|
|
|
|
visit path
|
|
|
|
expect(page).to have_css('.description > p > strong')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'passes through html-pipeline' do
|
|
|
|
group.update_attribute(:description, 'This group is the :poop:')
|
|
|
|
visit path
|
|
|
|
expect(page).to have_css('.description > p > img')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'sanitizes unwanted tags' do
|
|
|
|
group.update_attribute(:description, '# Group Description')
|
|
|
|
visit path
|
|
|
|
expect(page).not_to have_css('.description h1')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'permits `rel` attribute on links' do
|
|
|
|
group.update_attribute(:description, 'https://google.com/')
|
|
|
|
visit path
|
|
|
|
expect(page).to have_css('.description a[rel]')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|