Skip to content

Commit

Permalink
test(duckdb): test that column name case is preserved when inserting
Browse files Browse the repository at this point in the history
  • Loading branch information
cpcloud authored and kszucs committed Feb 2, 2024
1 parent 2022201 commit af54a18
Showing 1 changed file with 18 additions and 3 deletions.
21 changes: 18 additions & 3 deletions ibis/backends/duckdb/tests/test_client.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
from __future__ import annotations

import duckdb
import pandas as pd
import pyarrow as pa
import pytest
from pytest import param
Expand Down Expand Up @@ -162,11 +163,10 @@ def test_config_options_bad_option(con):


def test_insert(con):
import pandas as pd

name = ibis.util.guid()

t = con.create_table(name, schema=ibis.schema({"a": "int64"}))
t = con.create_table(name, schema=ibis.schema({"a": "int64"}), temp=True)

con.insert(name, obj=pd.DataFrame({"a": [1, 2]}))
assert t.count().execute() == 2

Expand Down Expand Up @@ -196,3 +196,18 @@ def test_to_other_sql(con, snapshot):

sql = ibis.to_sql(t, dialect="snowflake")
snapshot.assert_match(sql, "out.sql")


def test_insert_preserves_column_case(con):
name1 = ibis.util.guid()
name2 = ibis.util.guid()

df1 = pd.DataFrame([[1], [2], [3], [4]], columns=["FTHG"])
df2 = pd.DataFrame([[5], [6], [7], [8]], columns=["FTHG"])

t1 = con.create_table(name1, df1, temp=True)
assert t1.count().execute() == 4

t2 = con.create_table(name2, df2, temp=True)
con.insert(name1, t2)
assert t1.count().execute() == 8

0 comments on commit af54a18

Please sign in to comment.