X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/721dd9c27d299455b9159457a095716f797389f1..535bc8f1d87fe9aa5388006da463b667cb553339:/test/unit/relation_tag_test.rb diff --git a/test/unit/relation_tag_test.rb b/test/unit/relation_tag_test.rb index f93e689ca..de31c8da8 100644 --- a/test/unit/relation_tag_test.rb +++ b/test/unit/relation_tag_test.rb @@ -1,11 +1,10 @@ require File.dirname(__FILE__) + '/../test_helper' class RelationTagTest < Test::Unit::TestCase - fixtures :current_relation_tags - set_fixture_class :current_relation_tags => RelationTag + api_fixtures def test_relation_tag_count - assert_equal 3, RelationTag.count + assert_equal 7, RelationTag.count end def test_length_key_valid @@ -68,4 +67,28 @@ class RelationTagTest < Test::Unit::TestCase assert_raise(ActiveRecord::RecordInvalid) {tag.save!} assert 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 + # 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 + # impossible to have validations on the :id column. If someone knows better + # please fix, otherwise this test is shelved. + # + # def test_update + # v = "probably unique string here 3142592654" + # assert_equal 0, RelationTag.count(:conditions => ['v=?', v]) + + # # make sure we select a tag on a relation which has more than one tag + # id = current_relations(:multi_tag_relation).id + # tag = RelationTag.find(:first, :conditions => ["id = ?", id]) + # tag.v = v + # tag.save! + + # assert_equal 1, RelationTag.count(:conditions => ['v=?', v]) + # end end