2011-10-09 00:36:38 +03:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe "Issues" do
|
|
|
|
let(:project) { Factory :project }
|
|
|
|
|
2011-10-26 18:46:25 +05:00
|
|
|
before do
|
2011-10-09 00:36:38 +03:00
|
|
|
login_as :user
|
2011-11-01 22:51:20 +02:00
|
|
|
@user2 = Factory :user
|
|
|
|
|
2011-10-09 00:36:38 +03:00
|
|
|
project.add_access(@user, :read, :write)
|
2011-11-01 22:51:20 +02:00
|
|
|
project.add_access(@user2, :read, :write)
|
2011-10-09 00:36:38 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
describe "GET /issues" do
|
2011-10-26 18:46:25 +05:00
|
|
|
before do
|
2011-10-09 00:36:38 +03:00
|
|
|
@issue = Factory :issue,
|
|
|
|
:author => @user,
|
|
|
|
:assignee => @user,
|
|
|
|
:project => project
|
|
|
|
|
|
|
|
visit project_issues_path(project)
|
|
|
|
end
|
|
|
|
|
|
|
|
subject { page }
|
|
|
|
|
|
|
|
it { should have_content(@issue.title) }
|
|
|
|
it { should have_content(@issue.project.name) }
|
|
|
|
it { should have_content(@issue.assignee.name) }
|
|
|
|
|
2011-11-11 13:29:58 +04:00
|
|
|
it "should render atom feed" do
|
|
|
|
visit project_issues_path(project, :atom)
|
|
|
|
|
|
|
|
page.response_headers['Content-Type'].should have_content("application/atom+xml")
|
|
|
|
page.body.should have_selector("title", :text => "#{project.name} issues")
|
|
|
|
page.body.should have_selector("author email", :text => @issue.author_email)
|
2011-11-15 11:25:26 +04:00
|
|
|
page.body.should have_selector("entry summary", :text => @issue.title)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should render atom feed via private token" do
|
|
|
|
logout
|
|
|
|
visit project_issues_path(project, :atom, :private_token => @user.private_token)
|
|
|
|
|
|
|
|
page.response_headers['Content-Type'].should have_content("application/atom+xml")
|
|
|
|
page.body.should have_selector("title", :text => "#{project.name} issues")
|
|
|
|
page.body.should have_selector("author email", :text => @issue.author_email)
|
2011-11-11 13:29:58 +04:00
|
|
|
page.body.should have_selector("entry summary", :text => @issue.title)
|
|
|
|
end
|
|
|
|
|
2011-10-26 18:46:25 +05:00
|
|
|
describe "Destroy" do
|
|
|
|
before do
|
2011-10-09 00:36:38 +03:00
|
|
|
# admin access to remove issue
|
|
|
|
@user.users_projects.destroy_all
|
|
|
|
project.add_access(@user, :read, :write, :admin)
|
|
|
|
visit project_issues_path(project)
|
|
|
|
end
|
|
|
|
|
2011-10-26 18:46:25 +05:00
|
|
|
it "should remove entry" do
|
2011-10-09 00:36:38 +03:00
|
|
|
expect {
|
|
|
|
click_link "destroy_issue_#{@issue.id}"
|
|
|
|
}.to change { Issue.count }.by(-1)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-10-26 18:46:25 +05:00
|
|
|
describe "statuses", :js => true do
|
|
|
|
before do
|
2011-10-09 00:36:38 +03:00
|
|
|
@closed_issue = Factory :issue,
|
|
|
|
:author => @user,
|
|
|
|
:assignee => @user,
|
|
|
|
:project => project,
|
|
|
|
:closed => true
|
|
|
|
end
|
|
|
|
|
2011-10-26 18:46:25 +05:00
|
|
|
it "should show only open" do
|
2011-11-01 22:51:20 +02:00
|
|
|
should have_content(@issue.title[0..25])
|
2011-10-09 00:36:38 +03:00
|
|
|
should have_no_content(@closed_issue.title)
|
|
|
|
end
|
|
|
|
|
2011-10-26 18:46:25 +05:00
|
|
|
it "should show only closed" do
|
2011-10-09 00:36:38 +03:00
|
|
|
choose "closed_issues"
|
|
|
|
should have_no_content(@issue.title)
|
2011-11-01 22:51:20 +02:00
|
|
|
should have_content(@closed_issue.title[0..25])
|
2011-10-09 00:36:38 +03:00
|
|
|
end
|
|
|
|
|
2011-10-26 18:46:25 +05:00
|
|
|
it "should show all" do
|
2011-10-09 00:36:38 +03:00
|
|
|
choose "all_issues"
|
2011-11-01 22:51:20 +02:00
|
|
|
should have_content(@issue.title[0..25])
|
|
|
|
should have_content(@closed_issue.title[0..25])
|
2011-10-09 00:36:38 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-10-26 18:46:25 +05:00
|
|
|
describe "New issue", :js => true do
|
|
|
|
before do
|
2011-10-09 00:36:38 +03:00
|
|
|
visit project_issues_path(project)
|
|
|
|
click_link "New Issue"
|
|
|
|
end
|
|
|
|
|
2011-10-26 18:46:25 +05:00
|
|
|
it "should open new issue popup" do
|
2011-10-09 00:36:38 +03:00
|
|
|
page.should have_content("Add new issue")
|
|
|
|
end
|
|
|
|
|
2011-10-26 18:46:25 +05:00
|
|
|
describe "fill in" do
|
2011-11-11 13:29:58 +04:00
|
|
|
describe 'assign to me' do
|
2011-11-01 22:51:20 +02:00
|
|
|
before do
|
|
|
|
fill_in "issue_title", :with => "bug 345"
|
|
|
|
click_link "Select user"
|
|
|
|
within "#issue_assignee_id-menu" do
|
|
|
|
click_link @user.name
|
2011-11-11 13:29:58 +04:00
|
|
|
end
|
2011-11-01 22:51:20 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it { expect { click_button "Save" }.to change {Issue.count}.by(1) }
|
|
|
|
|
|
|
|
it "should add new issue to table" do
|
|
|
|
click_button "Save"
|
|
|
|
|
|
|
|
page.should_not have_content("Add new issue")
|
|
|
|
page.should have_content @user.name
|
|
|
|
page.should have_content "bug 345"
|
|
|
|
page.should have_content project.name
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should call send mail" do
|
|
|
|
Notify.should_not_receive(:new_issue_email)
|
|
|
|
click_button "Save"
|
|
|
|
end
|
2011-10-09 00:36:38 +03:00
|
|
|
end
|
|
|
|
|
2011-11-11 13:29:58 +04:00
|
|
|
describe 'assign to other' do
|
2011-11-01 22:51:20 +02:00
|
|
|
before do
|
|
|
|
fill_in "issue_title", :with => "bug 345"
|
|
|
|
click_link "Select user"
|
|
|
|
within "#issue_assignee_id-menu" do
|
|
|
|
click_link @user2.name
|
2011-11-11 13:29:58 +04:00
|
|
|
end
|
2011-11-01 22:51:20 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it { expect { click_button "Save" }.to change {Issue.count}.by(1) }
|
|
|
|
|
|
|
|
it "should add new issue to table" do
|
|
|
|
click_button "Save"
|
|
|
|
|
|
|
|
page.should_not have_content("Add new issue")
|
|
|
|
page.should have_content @user2.name
|
|
|
|
page.should have_content "bug 345"
|
|
|
|
page.should have_content project.name
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should call send mail" do
|
|
|
|
Notify.should_receive(:new_issue_email).and_return(stub(:deliver => true))
|
|
|
|
click_button "Save"
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should send valid email to user with email & password" do
|
|
|
|
click_button "Save"
|
|
|
|
issue = Issue.last
|
|
|
|
email = ActionMailer::Base.deliveries.last
|
|
|
|
email.subject.should have_content("New Issue was created")
|
|
|
|
email.body.should have_content(issue.title)
|
|
|
|
email.body.should have_content(issue.assignee.name)
|
|
|
|
end
|
2011-10-09 00:36:38 +03:00
|
|
|
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-11-11 13:29:58 +04:00
|
|
|
describe "Show issue" do
|
2011-10-28 12:22:09 +03:00
|
|
|
before do
|
|
|
|
@issue = Factory :issue,
|
|
|
|
:author => @user,
|
|
|
|
:assignee => @user,
|
|
|
|
:project => project
|
|
|
|
|
|
|
|
visit project_issue_path(project, @issue)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should have valid show page for issue" do
|
|
|
|
page.should have_content @issue.title
|
|
|
|
page.should have_content @user.name
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-10-26 18:46:25 +05:00
|
|
|
describe "Edit issue", :js => true do
|
|
|
|
before do
|
2011-10-09 00:36:38 +03:00
|
|
|
@issue = Factory :issue,
|
|
|
|
:author => @user,
|
|
|
|
:assignee => @user,
|
|
|
|
:project => project
|
|
|
|
visit project_issues_path(project)
|
2011-11-07 22:31:51 +02:00
|
|
|
page.execute_script("$('.action-links').css('display', 'block');")
|
2011-10-09 00:36:38 +03:00
|
|
|
click_link "Edit"
|
|
|
|
end
|
|
|
|
|
2011-10-26 18:46:25 +05:00
|
|
|
it "should open new issue popup" do
|
2011-10-09 00:36:38 +03:00
|
|
|
page.should have_content("Issue ##{@issue.id}")
|
|
|
|
end
|
|
|
|
|
2011-10-26 18:46:25 +05:00
|
|
|
describe "fill in" do
|
2011-10-09 00:36:38 +03:00
|
|
|
before do
|
|
|
|
fill_in "issue_title", :with => "bug 345"
|
|
|
|
end
|
|
|
|
|
|
|
|
it { expect { click_button "Save" }.to_not change {Issue.count} }
|
|
|
|
|
2011-10-26 18:46:25 +05:00
|
|
|
it "should update issue fields" do
|
2011-10-09 00:36:38 +03:00
|
|
|
click_button "Save"
|
|
|
|
|
|
|
|
page.should_not have_content("Issue ##{@issue.id}")
|
|
|
|
page.should have_content @user.name
|
|
|
|
page.should have_content "bug 345"
|
|
|
|
page.should have_content project.name
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2011-10-22 00:06:38 -04:00
|
|
|
|
|
|
|
describe "Search issue", :js => true do
|
|
|
|
before do
|
|
|
|
['foobar', 'foobar2', 'gitlab'].each do |title|
|
|
|
|
@issue = Factory :issue,
|
2011-10-25 20:15:11 -04:00
|
|
|
:author => @user,
|
2011-10-22 00:06:38 -04:00
|
|
|
:assignee => @user,
|
2011-10-25 20:15:11 -04:00
|
|
|
:project => project,
|
|
|
|
:title => title
|
2011-10-22 00:06:38 -04:00
|
|
|
@issue.save
|
|
|
|
end
|
|
|
|
end
|
2011-11-11 13:29:58 +04:00
|
|
|
|
2011-10-25 20:15:11 -04:00
|
|
|
it "should be able to search on different statuses" do
|
|
|
|
@issue = Issue.first
|
|
|
|
@issue.closed = true
|
|
|
|
@issue.save
|
|
|
|
|
2011-10-22 00:06:38 -04:00
|
|
|
visit project_issues_path(project)
|
2011-10-25 20:15:11 -04:00
|
|
|
choose 'closed_issues'
|
|
|
|
fill_in 'issue_search', :with => 'foobar'
|
2011-11-11 13:29:58 +04:00
|
|
|
|
2011-10-25 20:15:11 -04:00
|
|
|
page.should have_content 'foobar'
|
|
|
|
page.should_not have_content 'foobar2'
|
|
|
|
page.should_not have_content 'gitlab'
|
|
|
|
end
|
|
|
|
|
2011-11-11 13:29:58 +04:00
|
|
|
it "should search for term and return the correct results" do
|
2011-10-25 20:15:11 -04:00
|
|
|
visit project_issues_path(project)
|
|
|
|
fill_in 'issue_search', :with => 'foobar'
|
|
|
|
|
2011-10-22 00:06:38 -04:00
|
|
|
page.should have_content 'foobar'
|
|
|
|
page.should have_content 'foobar2'
|
|
|
|
page.should_not have_content 'gitlab'
|
|
|
|
end
|
|
|
|
|
2011-10-25 20:15:11 -04:00
|
|
|
it "should return all results if term has been cleared" do
|
|
|
|
visit project_issues_path(project)
|
|
|
|
fill_in "issue_search", :with => "foobar"
|
|
|
|
# Because fill_in, :with => "" triggers nothing we need to trigger a keyup event
|
|
|
|
page.execute_script("$('.issue_search').val('').keyup();");
|
|
|
|
|
|
|
|
page.should have_content 'foobar'
|
|
|
|
page.should have_content 'foobar2'
|
|
|
|
page.should have_content 'gitlab'
|
|
|
|
end
|
|
|
|
end
|
2011-10-09 00:36:38 +03:00
|
|
|
end
|