belongs_to :node, :foreign_key => 'id'
validates_presence_of :id
- validates_length_of :k, :v, :within => 0..255, :allow_blank => true
+ validates_length_of :k, :v, :maximum => 255, :allow_blank => true
end
set_table_name 'node_tags'
validates_presence_of :id, :version
- validates_length_of :k, :v, :within => 0..255, :allow_blank => true
+ validates_length_of :k, :v, :maximum => 255, :allow_blank => true
end
set_table_name 'way_tags'
+ validates_presence_of :id
+ validates_length_of :k, :v, :maximum => 255, :allow_blank => true
+ validates_uniqueness_of :id, :scope => [:k, :version]
+ validates_numericality_of :id, :version, :only_integer => true
end
# FIXME add a real multipart key to waytags so that we can do eager loadin
belongs_to :way, :foreign_key => 'id'
+
+ validates_presence_of :id
+ validates_length_of :k, :v, :maximum => 255, :allow_blank => true
+ validates_uniqueness_of :id, :scope => :k
+ validates_numericality_of :id, :only_integer => true
end
tag = NodeTag.new
tag.id = current_node_tags(:t1).id
tag.k = i
- tag.v = "v", "Key should be too long"
- assert !tag.valid?
+ tag.v = "v"
+ assert !tag.valid?, "Key should be too long"
assert tag.errors.invalid?(:k)
end
end
--- /dev/null
+require File.dirname(__FILE__) + '/../test_helper'
+
+class WayTagTest < Test::Unit::TestCase
+ fixtures :way_tags
+ set_fixture_class :way_tags => OldWayTag
+
+ def test_tag_count
+ assert_equal 3, OldWayTag.count
+ end
+
+ def test_length_key_valid
+ key = "k"
+ (0..255).each do |i|
+ tag = OldWayTag.new
+ tag.id = way_tags(:t1).id
+ tag.version = 1
+ tag.k = key*i
+ tag.v = "v"
+ assert_valid tag
+ end
+ end
+
+ def test_length_value_valid
+ val = "v"
+ (0..255).each do |i|
+ tag = OldWayTag.new
+ tag.id = way_tags(:t1).id
+ tag.version = 1
+ tag.k = "k"
+ tag.v = val*i
+ assert_valid tag
+ end
+ end
+
+ def test_length_key_invalid
+ ["k"*256].each do |i|
+ tag = OldWayTag.new
+ tag.id = way_tags(:t1).id
+ tag.version = 1
+ tag.k = i
+ tag.v = "v"
+ assert !tag.valid?, "Key should be too long"
+ assert tag.errors.invalid?(:k)
+ end
+ end
+
+ def test_length_value_invalid
+ ["k"*256].each do |i|
+ tag = OldWayTag.new
+ tag.id = way_tags(:t1).id
+ tag.version = 1
+ tag.k = "k"
+ tag.v = i
+ assert !tag.valid?, "Value should be too long"
+ assert tag.errors.invalid?(:v)
+ end
+ end
+
+ def test_empty_node_tag_invalid
+ tag = OldNodeTag.new
+ assert !tag.valid?, "Empty tag should be invalid"
+ assert tag.errors.invalid?(:id)
+ end
+
+ def test_uniqueness
+ tag = OldWayTag.new
+ tag.id = way_tags(:t1).id
+ tag.version = way_tags(:t1).version
+ tag.k = way_tags(:t1).k
+ tag.v = way_tags(:t1).v
+ assert tag.new_record?
+ assert !tag.valid?
+ assert_raise(ActiveRecord::RecordInvalid) {tag.save!}
+ assert tag.new_record?
+ end
+end
assert_equal 3, WayTag.count
end
+ def test_length_key_valid
+ key = "k"
+ (0..255).each do |i|
+ tag = WayTag.new
+ tag.id = current_way_tags(:t1).id
+ tag.k = key*i
+ tag.v = current_way_tags(:t1).v
+ assert_valid tag
+ end
+ end
+
+ def test_length_value_valid
+ val = "v"
+ (0..255).each do |i|
+ tag = WayTag.new
+ tag.id = current_way_tags(:t1).id
+ tag.k = "k"
+ tag.v = val*i
+ assert_valid tag
+ end
+ end
+
+ def test_length_key_invalid
+ ["k"*256].each do |i|
+ tag = WayTag.new
+ tag.id = current_way_tags(:t1).id
+ tag.k = i
+ tag.v = "v"
+ assert !tag.valid?, "Key #{i} should be too long"
+ assert tag.errors.invalid?(:k)
+ end
+ end
+
+ def test_length_value_invalid
+ ["k"*256].each do |i|
+ tag = WayTag.new
+ tag.id = current_way_tags(:t1).id
+ tag.k = "k"
+ tag.v = i
+ assert !tag.valid?, "Value #{i} should be too long"
+ end
+ end
+
+ def test_empty_tag_invalid
+ tag = WayTag.new
+ assert !tag.valid?, "Empty way tag should be invalid"
+ assert tag.errors.invalid?(:id)
+ end
+
+ def test_uniquess
+ tag = WayTag.new
+ tag.id = current_way_tags(:t1).id
+ tag.k = current_way_tags(:t1).k
+ tag.v = current_way_tags(:t1).v
+ assert tag.new_record?
+ assert !tag.valid?
+ assert_raise(ActiveRecord::RecordInvalid) {tag.save!}
+ assert tag.new_record?
+ end
end