]> git.openstreetmap.org Git - rails.git/blobdiff - test/models/changeset_comment_test.rb
Merge remote-tracking branch 'openstreetmap/pull/1036'
[rails.git] / test / models / changeset_comment_test.rb
index 5f8efdbbdef8bf65262aafb8c8003d7f61e4d14f..10901f70171f75381a6ea4959e21eaac433c0d87 100644 (file)
@@ -1,4 +1,5 @@
-require 'test_helper'
+# -*- coding: utf-8 -*-
+require "test_helper"
 
 class ChangesetCommentTest < ActiveSupport::TestCase
   fixtures :changesets, :changeset_comments
@@ -10,7 +11,7 @@ class ChangesetCommentTest < ActiveSupport::TestCase
   # validations
   def test_does_not_accept_invalid_author
     comment = changeset_comments(:normal_comment_1)
-    
+
     comment.author = nil
     assert !comment.valid?
 
@@ -36,6 +37,25 @@ class ChangesetCommentTest < ActiveSupport::TestCase
   end
 
   def test_comments_of_changeset_count
-    assert_equal 3, Changeset.find(changesets(:normal_user_closed_change)).comments.count
+    assert_equal 3, Changeset.find(changesets(:normal_user_closed_change).id).comments.count
+  end
+
+  def test_body_valid
+    ok = %W(Name vergrößern foo\nbar
+            ルシステムにも対応します 輕觸搖晃的遊戲)
+    bad = ["foo\x00bar", "foo\x08bar", "foo\x1fbar", "foo\x7fbar",
+           "foo\ufffebar", "foo\uffffbar"]
+
+    ok.each do |body|
+      changeset_comment = changeset_comments(:normal_comment_1)
+      changeset_comment.body = body
+      assert changeset_comment.valid?, "#{body} is invalid, when it should be"
+    end
+
+    bad.each do |body|
+      changeset_comment = changeset_comments(:normal_comment_1)
+      changeset_comment.body = body
+      assert !changeset_comment.valid?, "#{body} is valid when it shouldn't be"
+    end
   end
 end