|
| 1 | +# frozen_string_literal: true |
| 2 | + |
| 3 | +require "cases/helper_sqlserver" |
| 4 | + |
| 5 | +class ViewTestSQLServer < ActiveRecord::TestCase |
| 6 | + let(:connection) { ActiveRecord::Base.connection } |
| 7 | + |
| 8 | + describe 'view with default values' do |
| 9 | + before do |
| 10 | + connection.drop_table :view_casing_table rescue nil |
| 11 | + connection.create_table :view_casing_table, force: true do |t| |
| 12 | + t.boolean :Default_Falsey, null: false, default: false |
| 13 | + t.boolean :Default_Truthy, null: false, default: true |
| 14 | + end |
| 15 | + |
| 16 | + connection.execute("DROP VIEW IF EXISTS view_casing_table_view;") |
| 17 | + connection.execute("CREATE VIEW view_casing_table_view AS SELECT id AS id, default_falsey AS falsey, default_truthy AS truthy FROM view_casing_table") |
| 18 | + end |
| 19 | + |
| 20 | + it "default values are correct when column casing used in tables and views are different" do |
| 21 | + klass = Class.new(ActiveRecord::Base) do |
| 22 | + self.table_name = "view_casing_table_view" |
| 23 | + end |
| 24 | + |
| 25 | + obj = klass.new |
| 26 | + assert_equal false, obj.falsey |
| 27 | + assert_equal true, obj.truthy |
| 28 | + assert_equal 0, klass.count |
| 29 | + |
| 30 | + obj.save! |
| 31 | + assert_equal false, obj.falsey |
| 32 | + assert_equal true, obj.truthy |
| 33 | + assert_equal 1, klass.count |
| 34 | + end |
| 35 | + end |
| 36 | +end |
0 commit comments