]> git.openstreetmap.org Git - rails.git/blobdiff - test/models/changeset_comment_test.rb
Merge remote-tracking branch 'openstreetmap/pull/1004'
[rails.git] / test / models / changeset_comment_test.rb
index c13fde8e28e31734c7ae755deba6388e46b88d4c..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?
 
@@ -38,4 +39,23 @@ class ChangesetCommentTest < ActiveSupport::TestCase
   def test_comments_of_changeset_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