X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/b095b59d5e0ee805e49980af80b21bd1acff1345..9badc45929af8a187a36bddfc965c32135dbb16b:/test/models/way_tag_test.rb diff --git a/test/models/way_tag_test.rb b/test/models/way_tag_test.rb index 4d6116159..ae8be73b3 100644 --- a/test/models/way_tag_test.rb +++ b/test/models/way_tag_test.rb @@ -1,70 +1,53 @@ -require 'test_helper' +require "test_helper" class WayTagTest < ActiveSupport::TestCase api_fixtures - - def test_way_tag_count - assert_equal 5, WayTag.count - end - + def test_length_key_valid - key = "k" + tag = create(:way_tag) (0..255).each do |i| - tag = WayTag.new - tag.way_id = current_way_tags(:t1).way_id - tag.k = key*i - tag.v = current_way_tags(:t1).v + tag.k = "k" * i assert tag.valid? end end - + def test_length_value_valid - val = "v" + tag = create(:way_tag) (0..255).each do |i| - tag = WayTag.new - tag.way_id = current_way_tags(:t1).way_id - tag.k = "k" - tag.v = val*i + tag.v = "v" * i assert tag.valid? end end - + def test_length_key_invalid - ["k"*256].each do |i| - tag = WayTag.new - tag.way_id = current_way_tags(:t1).way_id - tag.k = i - tag.v = "v" - assert !tag.valid?, "Key #{i} should be too long" - assert tag.errors[:k].any? - end + tag = create(:way_tag) + tag.k = "k" * 256 + assert !tag.valid?, "Key should be too long" + assert tag.errors[:k].any? end - + def test_length_value_invalid - ["v"*256].each do |i| - tag = WayTag.new - tag.way_id = current_way_tags(:t1).way_id - tag.k = "k" - tag.v = i - assert !tag.valid?, "Value #{i} should be too long" - assert tag.errors[:v].any? - end + tag = create(:way_tag) + tag.v = "v" * 256 + assert !tag.valid?, "Value should be too long" + assert tag.errors[:v].any? end - + def test_empty_tag_invalid tag = WayTag.new assert !tag.valid?, "Empty way tag should be invalid" assert tag.errors[:way].any? end - + def test_uniqueness + existing = create(:way_tag) tag = WayTag.new - tag.way_id = current_way_tags(:t1).way_id - tag.k = current_way_tags(:t1).k - tag.v = current_way_tags(:t1).v + tag.way_id = existing.way_id + tag.k = existing.k + tag.v = existing.v assert tag.new_record? assert !tag.valid? - assert_raise(ActiveRecord::RecordInvalid) {tag.save!} + assert_raise(ActiveRecord::RecordInvalid) { tag.save! } assert tag.new_record? end end