X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/fe45b1b66c730f2546d78a7899375707c0816518..e838828374ceed5ef6da260939251e86f72b6f27:/services/api/test/unit/arvados_model_test.rb diff --git a/services/api/test/unit/arvados_model_test.rb b/services/api/test/unit/arvados_model_test.rb index d83f583bf3..7d9da1e561 100644 --- a/services/api/test/unit/arvados_model_test.rb +++ b/services/api/test/unit/arvados_model_test.rb @@ -1,3 +1,7 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + require 'test_helper' class ArvadosModelTest < ActiveSupport::TestCase @@ -78,24 +82,13 @@ class ArvadosModelTest < ActiveSupport::TestCase end end - test "Stringify symbols coming from serialized attribute in database" do - set_user_from_auth :admin_trustedclient - fixed = Link.find_by_uuid(links(:has_symbol_keys_in_database_somehow).uuid) - assert_equal(["baz", "foo"], fixed.properties.keys.sort, - "Hash symbol keys from DB did not get stringified.") - assert_equal(['waz', 'waz', 'waz', 1, nil, false, true], - fixed.properties['baz'], - "Array symbol values from DB did not get stringified.") - assert_equal true, fixed.save, "Failed to save fixed model back to db." - end - test "No HashWithIndifferentAccess in database" do set_user_from_auth :admin_trustedclient link = Link.create!(link_class: 'test', properties: {'foo' => 'bar'}.with_indifferent_access) raw = ActiveRecord::Base.connection. select_value("select properties from links where uuid='#{link.uuid}'") - assert_equal '{"foo":"bar"}', raw + assert_equal '{"foo": "bar"}', raw end test "store long string" do @@ -135,6 +128,8 @@ class ArvadosModelTest < ActiveSupport::TestCase test "search index exists on models that go into projects" do all_tables = ActiveRecord::Base.connection.tables all_tables.delete 'schema_migrations' + all_tables.delete 'permission_refresh_lock' + all_tables.delete 'ar_internal_metadata' all_tables.each do |table| table_class = table.classify.constantize @@ -147,7 +142,10 @@ class ArvadosModelTest < ActiveSupport::TestCase indexes = ActiveRecord::Base.connection.indexes(table) search_index_by_columns = indexes.select do |index| - index.columns.sort == search_index_columns.sort + # After rails 5.0 upgrade, AR::Base.connection.indexes() started to include + # GIN indexes, with its 'columns' attribute being a String like + # 'to_tsvector(...)' + index.columns.is_a?(Array) ? index.columns.sort == search_index_columns.sort : false end search_index_by_name = indexes.select do |index| index.name == "#{table}_search_index" @@ -253,4 +251,24 @@ class ArvadosModelTest < ActiveSupport::TestCase assert_equal true, (updated_at_2 > updated_at_1), "Expected updated time 2 to be newer than 1" end + + test 'jsonb column' do + set_user_from_auth :active + + c = Collection.create!(properties: {}) + assert_equal({}, c.properties) + + c.update_attributes(properties: {'foo' => 'foo'}) + c.reload + assert_equal({'foo' => 'foo'}, c.properties) + + c.update_attributes(properties: nil) + c.reload + assert_equal({}, c.properties) + + c.update_attributes(properties: {foo: 'bar'}) + assert_equal({'foo' => 'bar'}, c.properties) + c.reload + assert_equal({'foo' => 'bar'}, c.properties) + end end