X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/0814b4096c443e2ab3c09baa058aa81a00d205d1..5c2cb9e96fdc00c7efd72ba4186308127e45855c:/test/models/node_tag_test.rb diff --git a/test/models/node_tag_test.rb b/test/models/node_tag_test.rb index f1d8750a0..d927b5fea 100644 --- a/test/models/node_tag_test.rb +++ b/test/models/node_tag_test.rb @@ -1,53 +1,49 @@ require "test_helper" class NodeTagTest < ActiveSupport::TestCase - api_fixtures - def test_length_key_valid tag = create(:node_tag) - (0..255).each do |i| + [0, 255].each do |i| tag.k = "k" * i - assert tag.valid? + assert_predicate tag, :valid? end end def test_length_value_valid tag = create(:node_tag) - (0..255).each do |i| + [0, 255].each do |i| tag.v = "v" * i - assert tag.valid? + assert_predicate tag, :valid? end end def test_length_key_invalid tag = create(:node_tag) tag.k = "k" * 256 - assert !tag.valid?, "Key should be too long" - assert tag.errors[:k].any? + assert_not tag.valid?, "Key should be too long" + assert_predicate tag.errors[:k], :any? end def test_length_value_invalid tag = create(:node_tag) tag.v = "v" * 256 - assert !tag.valid?, "Value should be too long" - assert tag.errors[:v].any? + assert_not tag.valid?, "Value should be too long" + assert_predicate tag.errors[:v], :any? end - def test_empty_node_tag_invalid - tag = NodeTag.new - assert !tag.valid?, "Empty tag should be invalid" - assert tag.errors[:node].any? + def test_orphaned_node_tag_invalid + tag = create(:node_tag) + tag.node = nil + assert_not tag.valid?, "Orphaned tag should be invalid" + assert_predicate tag.errors[:node], :any? end def test_uniqueness existing = create(:node_tag) - tag = NodeTag.new - tag.node_id = existing.node_id - tag.k = existing.k - tag.v = existing.v - assert tag.new_record? - assert !tag.valid? + tag = build(:node_tag, :node => existing.node, :k => existing.k, :v => existing.v) + 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