summaryrefslogtreecommitdiffstats
path: root/test/integration/api_test/issues_test.rb
diff options
context:
space:
mode:
Diffstat (limited to 'test/integration/api_test/issues_test.rb')
-rw-r--r--test/integration/api_test/issues_test.rb51
1 files changed, 51 insertions, 0 deletions
diff --git a/test/integration/api_test/issues_test.rb b/test/integration/api_test/issues_test.rb
index 3917f8618..176c18105 100644
--- a/test/integration/api_test/issues_test.rb
+++ b/test/integration/api_test/issues_test.rb
@@ -453,6 +453,21 @@ class Redmine::ApiTest::IssuesTest < Redmine::ApiTest::Base
end
end
+ test "GET /issues/:id.xml?include=watchers should include watchers" do
+ Watcher.create!(:user_id => 3, :watchable => Issue.find(1))
+
+ get '/issues/1.xml?include=watchers', {}, credentials('jsmith')
+
+ assert_response :ok
+ assert_equal 'application/xml', response.content_type
+ assert_select 'issue' do
+ assert_select 'watchers', Issue.find(1).watchers.count
+ assert_select 'watchers' do
+ assert_select 'user[id=3]'
+ end
+ end
+ end
+
context "POST /issues.xml" do
should_allow_api_authentication(
:post,
@@ -478,6 +493,18 @@ class Redmine::ApiTest::IssuesTest < Redmine::ApiTest::Base
end
end
+ test "POST /issues.xml with watcher_user_ids should create issue with watchers" do
+ assert_difference('Issue.count') do
+ post '/issues.xml',
+ {:issue => {:project_id => 1, :subject => 'Watchers',
+ :tracker_id => 2, :status_id => 3, :watcher_user_ids => [3, 1]}}, credentials('jsmith')
+ assert_response :created
+ end
+ issue = Issue.order('id desc').first
+ assert_equal 2, issue.watchers.size
+ assert_equal [1, 3], issue.watcher_user_ids.sort
+ end
+
context "POST /issues.xml with failure" do
should "have an errors tag" do
assert_no_difference('Issue.count') do
@@ -720,6 +747,30 @@ class Redmine::ApiTest::IssuesTest < Redmine::ApiTest::Base
end
end
+ test "POST /issues/:id/watchers.xml should add watcher" do
+ assert_difference 'Watcher.count' do
+ post '/issues/1/watchers.xml', {:user_id => 3}, credentials('jsmith')
+
+ assert_response :ok
+ assert_equal '', response.body
+ end
+ watcher = Watcher.order('id desc').first
+ assert_equal Issue.find(1), watcher.watchable
+ assert_equal User.find(3), watcher.user
+ end
+
+ test "DELETE /issues/:id/watchers/:user_id.xml should remove watcher" do
+ Watcher.create!(:user_id => 3, :watchable => Issue.find(1))
+
+ assert_difference 'Watcher.count', -1 do
+ delete '/issues/1/watchers/3.xml', {}, credentials('jsmith')
+
+ assert_response :ok
+ assert_equal '', response.body
+ end
+ assert_equal false, Issue.find(1).watched_by?(User.find(3))
+ end
+
def test_create_issue_with_uploaded_file
set_tmp_attachments_directory
# upload the file