|
16 | 16 | // under the License. |
17 | 17 | #include "arrow/flight/sql/odbc/tests/odbc_test_suite.h" |
18 | 18 |
|
19 | | -#ifdef _WIN32 |
20 | | -# include <windows.h> |
21 | | -#endif |
| 19 | +#include "arrow/flight/sql/odbc/odbc_impl/platform.h" |
22 | 20 |
|
23 | 21 | #include <sql.h> |
24 | 22 | #include <sqltypes.h> |
25 | 23 | #include <sqlucode.h> |
26 | 24 |
|
27 | | -#include "gmock/gmock.h" |
28 | | -#include "gtest/gtest.h" |
| 25 | +#include <gtest/gtest.h> |
29 | 26 |
|
30 | 27 | namespace arrow::flight::sql::odbc { |
31 | 28 |
|
| 29 | +template <typename T> |
| 30 | +class ConnectionTest : public T { |
| 31 | + public: |
| 32 | + using List = std::list<T>; |
| 33 | +}; |
| 34 | + |
| 35 | +class ConnectionRemoteTest : public FlightSQLODBCRemoteTestBase {}; |
| 36 | +using TestTypes = ::testing::Types<FlightSQLODBCMockTestBase, ConnectionRemoteTest>; |
| 37 | +TYPED_TEST_SUITE(ConnectionTest, TestTypes); |
| 38 | + |
32 | 39 | TEST(SQLGetEnvAttr, TestSQLGetEnvAttrODBCVersion) { |
33 | | - // ODBC Environment |
34 | 40 | SQLHENV env; |
35 | 41 |
|
36 | 42 | SQLINTEGER version; |
37 | 43 |
|
38 | 44 | // Allocate an environment handle |
39 | | - SQLRETURN return_env = SQLAllocEnv(&env); |
40 | | - |
41 | | - EXPECT_EQ(SQL_SUCCESS, return_env); |
| 45 | + ASSERT_EQ(SQL_SUCCESS, SQLAllocEnv(&env)); |
42 | 46 |
|
43 | | - SQLRETURN return_get = SQLGetEnvAttr(env, SQL_ATTR_ODBC_VERSION, &version, 0, 0); |
| 47 | + ASSERT_EQ(SQL_SUCCESS, SQLGetEnvAttr(env, SQL_ATTR_ODBC_VERSION, &version, 0, 0)); |
44 | 48 |
|
45 | | - EXPECT_EQ(SQL_SUCCESS, return_get); |
| 49 | + ASSERT_EQ(SQL_OV_ODBC2, version); |
46 | 50 |
|
47 | | - EXPECT_EQ(SQL_OV_ODBC2, version); |
| 51 | + ASSERT_EQ(SQL_SUCCESS, SQLFreeEnv(env)); |
48 | 52 | } |
49 | 53 |
|
50 | 54 | TEST(SQLSetEnvAttr, TestSQLSetEnvAttrODBCVersionValid) { |
51 | | - // ODBC Environment |
52 | 55 | SQLHENV env; |
53 | 56 |
|
54 | 57 | // Allocate an environment handle |
55 | | - SQLRETURN return_env = SQLAllocEnv(&env); |
| 58 | + ASSERT_EQ(SQL_SUCCESS, SQLAllocEnv(&env)); |
56 | 59 |
|
57 | | - EXPECT_EQ(SQL_SUCCESS, return_env); |
| 60 | + // Attempt to set to supported version |
| 61 | + ASSERT_EQ(SQL_SUCCESS, SQLSetEnvAttr(env, SQL_ATTR_ODBC_VERSION, |
| 62 | + reinterpret_cast<void*>(SQL_OV_ODBC2), 0)); |
58 | 63 |
|
59 | | - // Attempt to set to unsupported version |
60 | | - SQLRETURN return_set = |
61 | | - SQLSetEnvAttr(env, SQL_ATTR_ODBC_VERSION, reinterpret_cast<void*>(SQL_OV_ODBC2), 0); |
| 64 | + SQLINTEGER version; |
| 65 | + // Check ODBC version is set |
| 66 | + ASSERT_EQ(SQL_SUCCESS, SQLGetEnvAttr(env, SQL_ATTR_ODBC_VERSION, &version, 0, 0)); |
62 | 67 |
|
63 | | - EXPECT_EQ(SQL_SUCCESS, return_set); |
| 68 | + ASSERT_EQ(SQL_OV_ODBC2, version); |
| 69 | + |
| 70 | + ASSERT_EQ(SQL_SUCCESS, SQLFreeEnv(env)); |
64 | 71 | } |
65 | 72 |
|
66 | 73 | TEST(SQLSetEnvAttr, TestSQLSetEnvAttrODBCVersionInvalid) { |
67 | | - // ODBC Environment |
68 | 74 | SQLHENV env; |
69 | 75 |
|
70 | 76 | // Allocate an environment handle |
71 | | - SQLRETURN return_env = SQLAllocEnv(&env); |
72 | | - |
73 | | - EXPECT_EQ(SQL_SUCCESS, return_env); |
| 77 | + ASSERT_EQ(SQL_SUCCESS, SQLAllocEnv(&env)); |
74 | 78 |
|
75 | 79 | // Attempt to set to unsupported version |
76 | | - SQLRETURN return_set = |
77 | | - SQLSetEnvAttr(env, SQL_ATTR_ODBC_VERSION, reinterpret_cast<void*>(1), 0); |
| 80 | + ASSERT_EQ(SQL_ERROR, |
| 81 | + SQLSetEnvAttr(env, SQL_ATTR_ODBC_VERSION, reinterpret_cast<void*>(1), 0)); |
| 82 | + |
| 83 | + ASSERT_EQ(SQL_SUCCESS, SQLFreeEnv(env)); |
| 84 | +} |
| 85 | + |
| 86 | +TYPED_TEST(ConnectionTest, TestSQLGetEnvAttrOutputNTS) { |
| 87 | + SQLINTEGER output_nts; |
| 88 | + |
| 89 | + ASSERT_EQ(SQL_SUCCESS, |
| 90 | + SQLGetEnvAttr(this->env, SQL_ATTR_OUTPUT_NTS, &output_nts, 0, 0)); |
| 91 | + |
| 92 | + ASSERT_EQ(SQL_TRUE, output_nts); |
| 93 | +} |
| 94 | + |
| 95 | +TYPED_TEST(ConnectionTest, DISABLED_TestSQLGetEnvAttrGetLength) { |
| 96 | + // Test is disabled because call to SQLGetEnvAttr is handled by the driver manager on |
| 97 | + // Windows. Windows driver manager ignores the length pointer. |
| 98 | + // This test case can be potentially used on macOS/Linux |
| 99 | + SQLINTEGER length; |
| 100 | + ASSERT_EQ(SQL_SUCCESS, |
| 101 | + SQLGetEnvAttr(this->env, SQL_ATTR_ODBC_VERSION, nullptr, 0, &length)); |
| 102 | + |
| 103 | + EXPECT_EQ(sizeof(SQLINTEGER), length); |
| 104 | +} |
| 105 | + |
| 106 | +TYPED_TEST(ConnectionTest, DISABLED_TestSQLGetEnvAttrNullValuePointer) { |
| 107 | + // Test is disabled because call to SQLGetEnvAttr is handled by the driver manager on |
| 108 | + // Windows. The Windows driver manager doesn't error out when null pointer is passed. |
| 109 | + // This test case can be potentially used on macOS/Linux |
| 110 | + ASSERT_EQ(SQL_ERROR, |
| 111 | + SQLGetEnvAttr(this->env, SQL_ATTR_ODBC_VERSION, nullptr, 0, nullptr)); |
| 112 | +} |
| 113 | + |
| 114 | +TEST(SQLSetEnvAttr, TestSQLSetEnvAttrOutputNTSValid) { |
| 115 | + SQLHENV env; |
| 116 | + |
| 117 | + // Allocate an environment handle |
| 118 | + ASSERT_EQ(SQL_SUCCESS, SQLAllocEnv(&env)); |
| 119 | + |
| 120 | + // Attempt to set to output nts to supported version |
| 121 | + ASSERT_EQ(SQL_SUCCESS, SQLSetEnvAttr(env, SQL_ATTR_OUTPUT_NTS, |
| 122 | + reinterpret_cast<void*>(SQL_TRUE), 0)); |
| 123 | + |
| 124 | + ASSERT_EQ(SQL_SUCCESS, SQLFreeEnv(env)); |
| 125 | +} |
| 126 | + |
| 127 | +TEST(SQLSetEnvAttr, TestSQLSetEnvAttrOutputNTSInvalid) { |
| 128 | + SQLHENV env; |
| 129 | + |
| 130 | + // Allocate an environment handle |
| 131 | + ASSERT_EQ(SQL_SUCCESS, SQLAllocEnv(&env)); |
| 132 | + |
| 133 | + // Attempt to set to output nts to unsupported false |
| 134 | + ASSERT_EQ(SQL_ERROR, SQLSetEnvAttr(env, SQL_ATTR_OUTPUT_NTS, |
| 135 | + reinterpret_cast<void*>(SQL_FALSE), 0)); |
| 136 | + |
| 137 | + ASSERT_EQ(SQL_SUCCESS, SQLFreeEnv(env)); |
| 138 | +} |
| 139 | + |
| 140 | +TEST(SQLSetEnvAttr, TestSQLSetEnvAttrNullValuePointer) { |
| 141 | + SQLHENV env; |
| 142 | + |
| 143 | + // Allocate an environment handle |
| 144 | + ASSERT_EQ(SQL_SUCCESS, SQLAllocEnv(&env)); |
| 145 | + |
| 146 | + // Attempt to set using bad data pointer |
| 147 | + ASSERT_EQ(SQL_ERROR, SQLSetEnvAttr(env, SQL_ATTR_ODBC_VERSION, nullptr, 0)); |
78 | 148 |
|
79 | | - EXPECT_EQ(SQL_ERROR, return_set); |
| 149 | + ASSERT_EQ(SQL_SUCCESS, SQLFreeEnv(env)); |
80 | 150 | } |
81 | 151 |
|
82 | 152 | } // namespace arrow::flight::sql::odbc |
0 commit comments