]> git.openstreetmap.org Git - rails.git/blobdiff - test/models/changeset_tag_test.rb
Rework 'empty' tag tests
[rails.git] / test / models / changeset_tag_test.rb
index 90a8518b431bf1befe77dae90d260f9fe483e150..6846f90b455e73256c24b1908e386df564d18f1a 100644 (file)
@@ -1,27 +1,29 @@
 require "test_helper"
 
 class ChangesetTagTest < ActiveSupport::TestCase
-  api_fixtures
-
   def test_length_key_valid
+    changeset = create(:changeset)
+
     key = "k"
-    (0..255).each do |i|
+    [0, 255].each do |i|
       tag = ChangesetTag.new
-      tag.changeset_id = 1
+      tag.changeset_id = changeset.id
       tag.k = key * i
       tag.v = "v"
-      assert tag.valid?
+      assert_predicate tag, :valid?
     end
   end
 
   def test_length_value_valid
+    changeset = create(:changeset)
+
     val = "v"
-    (0..255).each do |i|
+    [0, 255].each do |i|
       tag = ChangesetTag.new
-      tag.changeset_id = 1
+      tag.changeset_id = changeset.id
       tag.k = "k"
       tag.v = val * i
-      assert tag.valid?
+      assert_predicate tag, :valid?
     end
   end
 
@@ -31,8 +33,8 @@ class ChangesetTagTest < ActiveSupport::TestCase
       tag.changeset_id = 1
       tag.k = k
       tag.v = "v"
-      assert !tag.valid?, "Key #{k} should be too long"
-      assert tag.errors[:k].any?
+      assert_not tag.valid?, "Key #{k} should be too long"
+      assert_predicate tag.errors[:k], :any?
     end
   end
 
@@ -42,15 +44,16 @@ class ChangesetTagTest < ActiveSupport::TestCase
       tag.changeset_id = 1
       tag.k = "k"
       tag.v = v
-      assert !tag.valid?, "Value #{v} should be too long"
-      assert tag.errors[:v].any?
+      assert_not tag.valid?, "Value #{v} should be too long"
+      assert_predicate tag.errors[:v], :any?
     end
   end
 
-  def test_empty_tag_invalid
-    tag = ChangesetTag.new
-    assert !tag.valid?, "Empty tag should be invalid"
-    assert tag.errors[:changeset].any?
+  def test_orphaned_tag_invalid
+    tag = create(:changeset_tag)
+    tag.changeset = nil
+    assert_not tag.valid?, "Orphaned tag should be invalid"
+    assert_predicate tag.errors[:changeset], :any?
   end
 
   def test_uniqueness
@@ -59,9 +62,9 @@ class ChangesetTagTest < ActiveSupport::TestCase
     tag.changeset_id = existing.changeset_id
     tag.k = existing.k
     tag.v = existing.v
-    assert tag.new_record?
-    assert !tag.valid?
+    assert_predicate tag, :new_record?
+    assert_not tag.valid?
     assert_raise(ActiveRecord::RecordInvalid) { tag.save! }
-    assert tag.new_record?
+    assert_predicate tag, :new_record?
   end
 end