X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/f2d13c075660efb9582d7fb600bd6798d7a382ca..3a8a997fb86219e2e11dc76c837d5a237db80019:/test/models/relation_tag_test.rb diff --git a/test/models/relation_tag_test.rb b/test/models/relation_tag_test.rb index 0b5bedb05..2e5e1503c 100644 --- a/test/models/relation_tag_test.rb +++ b/test/models/relation_tag_test.rb @@ -1,81 +1,60 @@ -require 'test_helper' +require "test_helper" class RelationTagTest < ActiveSupport::TestCase - api_fixtures - - def test_relation_tag_count - assert_equal 9, RelationTag.count - end - def test_length_key_valid - key = "k" - (0..255).each do |i| - tag = RelationTag.new - tag.relation_id = 1 - tag.k = key*i - tag.v = "v" - assert tag.valid? + tag = create(:relation_tag) + [0, 255].each do |i| + tag.k = "k" * i + assert_predicate tag, :valid? end end - + def test_length_value_valid - val = "v" - (0..255).each do |i| - tag = RelationTag.new - tag.relation_id = 1 - tag.k = "k" - tag.v = val*i - assert tag.valid? + tag = create(:relation_tag) + [0, 255].each do |i| + tag.v = "v" * i + assert_predicate tag, :valid? end end - + def test_length_key_invalid - ["k"*256].each do |i| - tag = RelationTag.new - tag.relation_id = 1 - tag.k = i - tag.v = "v" - assert !tag.valid?, "Key #{i} should be too long" - assert tag.errors[:k].any? - end + tag = create(:relation_tag) + tag.k = "k" * 256 + assert_not_predicate tag, :valid?, "Key should be too long" + assert_predicate tag.errors[:k], :any? end - + def test_length_value_invalid - ["v"*256].each do |i| - tag = RelationTag.new - tag.relation_id = 1 - tag.k = "k" - tag.v = i - assert !tag.valid?, "Value #{i} should be too long" - assert tag.errors[:v].any? - end + tag = create(:relation_tag) + tag.v = "v" * 256 + assert_not_predicate tag, :valid?, "Value should be too long" + assert_predicate tag.errors[:v], :any? end - - def test_empty_tag_invalid - tag = RelationTag.new - assert !tag.valid?, "Empty relation tag should be invalid" - assert tag.errors[:relation].any? + + def test_orphaned_tag_invalid + tag = create(:relation_tag) + tag.relation = nil + assert_not_predicate tag, :valid?, "Orphaned tag should be invalid" + assert_predicate tag.errors[:relation], :any? end - - def test_uniquness - tag = RelationTag.new - tag.relation_id = current_relation_tags(:t1).relation_id - tag.k = current_relation_tags(:t1).k - tag.v = current_relation_tags(:t1).v - assert tag.new_record? - assert !tag.valid? - assert_raise(ActiveRecord::RecordInvalid) {tag.save!} - assert tag.new_record? + + def test_uniqueness + existing = create(:relation_tag) + tag = build(:relation_tag, :relation => existing.relation, :k => existing.k, :v => existing.v) + assert_predicate tag, :new_record? + assert_not_predicate tag, :valid? + assert_raise(ActiveRecord::RecordInvalid) { tag.save! } + assert_predicate tag, :new_record? end ## # test that tags can be updated and saved uniquely, i.e: tag.save! - # only affects the single tag that the activerecord object + # only affects the single tag that the activerecord object # represents. this amounts to testing that the primary key is # unique. # # Commenting this out - I attempted to fix it, but composite primary keys - # wasn't playing nice with the column already called :id. Seemed to be + # wasn't playing nice with the column already called :id. Seemed to be # impossible to have validations on the :id column. If someone knows better # please fix, otherwise this test is shelved. #