debian-mirror-gitlab/spec/features/projects_spec.rb

79 lines
2.3 KiB
Ruby
Raw Normal View History

2014-09-02 18:07:02 +05:30
require 'spec_helper'
2015-09-11 14:41:01 +05:30
feature 'Project', feature: true do
describe 'description' do
let(:project) { create(:project) }
let(:path) { namespace_project_path(project.namespace, project) }
2014-09-02 18:07:02 +05:30
before do
2015-09-11 14:41:01 +05:30
login_as(:admin)
2014-09-02 18:07:02 +05:30
end
2015-09-11 14:41:01 +05:30
it 'parses Markdown' do
project.update_attribute(:description, 'This is **my** project')
visit path
expect(page).to have_css('.project-home-desc > p > strong')
end
it 'passes through html-pipeline' do
project.update_attribute(:description, 'This project is the :poop:')
visit path
expect(page).to have_css('.project-home-desc > p > img')
end
it 'sanitizes unwanted tags' do
project.update_attribute(:description, "```\ncode\n```")
visit path
expect(page).not_to have_css('.project-home-desc code')
end
it 'permits `rel` attribute on links' do
project.update_attribute(:description, 'https://google.com/')
visit path
expect(page).to have_css('.project-home-desc a[rel]')
2014-09-02 18:07:02 +05:30
end
2015-09-11 14:41:01 +05:30
end
2015-11-26 14:37:03 +05:30
describe 'remove forked relationship', js: true do
let(:user) { create(:user) }
let(:project) { create(:project, namespace: user.namespace) }
before do
login_with user
create(:forked_project_link, forked_to_project: project)
visit edit_namespace_project_path(project.namespace, project)
end
it 'should remove fork' do
expect(page).to have_content 'Remove fork relationship'
remove_with_confirm('Remove fork relationship', project.path)
expect(page).to have_content 'The fork relationship has been removed.'
expect(project.forked?).to be_falsey
expect(page).not_to have_content 'Remove fork relationship'
end
end
2015-09-11 14:41:01 +05:30
describe 'removal', js: true do
let(:user) { create(:user) }
let(:project) { create(:project, namespace: user.namespace) }
2015-04-26 12:48:37 +05:30
2015-09-11 14:41:01 +05:30
before do
login_with(user)
project.team << [user, :master]
visit edit_namespace_project_path(project.namespace, project)
end
2015-04-26 12:48:37 +05:30
2015-09-11 14:41:01 +05:30
it 'should remove project' do
2015-11-26 14:37:03 +05:30
expect { remove_with_confirm('Remove project', project.path) }.to change {Project.count}.by(-1)
2015-04-26 12:48:37 +05:30
end
end
2015-11-26 14:37:03 +05:30
def remove_with_confirm(button_text, confirm_with)
click_button button_text
fill_in 'confirm_name_input', with: confirm_with
2015-04-26 12:48:37 +05:30
click_button 'Confirm'
2014-09-02 18:07:02 +05:30
end
end