Sha256: 7c7a548f3390ed5839cfeda53c56f7a61f66177f01e3d8426ca954aff982f79a

Contents?: true

Size: 1.94 KB

Versions: 6

Compression:

Stored size: 1.94 KB

Contents

require "cases/helper"

class SchemaMigrationsTest < ActiveRecord::Mysql2TestCase
  def test_renaming_index_on_foreign_key
    connection.add_index "engines", "car_id"
    connection.add_foreign_key :engines, :cars, name: "fk_engines_cars"

    connection.rename_index("engines", "index_engines_on_car_id", "idx_renamed")
    assert_equal ["idx_renamed"], connection.indexes("engines").map(&:name)
  ensure
    connection.remove_foreign_key :engines, name: "fk_engines_cars"
  end

  def test_initializes_schema_migrations_for_encoding_utf8mb4
    with_encoding_utf8mb4 do
      table_name = ActiveRecord::SchemaMigration.table_name
      connection.drop_table table_name, if_exists: true

      connection.initialize_schema_migrations_table

      assert connection.column_exists?(table_name, :version, :string, collation: 'utf8_general_ci')
    end
  end

  def test_initializes_internal_metadata_for_encoding_utf8mb4
    with_encoding_utf8mb4 do
      table_name = ActiveRecord::InternalMetadata.table_name
      connection.drop_table table_name, if_exists: true

      connection.initialize_internal_metadata_table

      assert connection.column_exists?(table_name, :key, :string, collation: 'utf8_general_ci')
    end
  end

  private

  def with_encoding_utf8mb4
    database_name = connection.current_database
    database_info = connection.select_one("SELECT * FROM information_schema.schemata WHERE schema_name = '#{database_name}'")

    original_charset = database_info["DEFAULT_CHARACTER_SET_NAME"]
    original_collation = database_info["DEFAULT_COLLATION_NAME"]

    execute("ALTER DATABASE #{database_name} DEFAULT CHARACTER SET utf8mb4")

    yield
  ensure
    execute("ALTER DATABASE #{database_name} DEFAULT CHARACTER SET #{original_charset} COLLATE #{original_collation}")
  end

  def connection
    @connection ||= ActiveRecord::Base.connection
  end

  def execute(sql)
    connection.execute(sql)
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
ibm_db-5.2.0-x86-mingw32 test/cases/adapters/mysql2/schema_migrations_test.rb
ibm_db-5.1.0-x86-mingw32 test/cases/adapters/mysql2/schema_migrations_test.rb
ibm_db-5.0.5-x86-mingw32 test/cases/adapters/mysql2/schema_migrations_test.rb
ibm_db-5.0.4-x86-mingw32 test/cases/adapters/mysql2/schema_migrations_test.rb
ibm_db-5.0.3-x86-mingw32 test/cases/adapters/mysql2/schema_migrations_test.rb
ibm_db-5.0.2-x86-mingw32 test/cases/adapters/mysql2/schema_migrations_test.rb