diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md index b6fd34de2..3976436dc 100644 --- a/.github/PULL_REQUEST_TEMPLATE.md +++ b/.github/PULL_REQUEST_TEMPLATE.md @@ -12,11 +12,9 @@ ### Additional Reviewers -@affonsoBQ +@CassieLyu +@sunnie629 @alexey-temnikov -@alinaliBQ -@andiem-bq +@affonsoBQ @birschick-bq -@mitchell-elholm -@RoyZhang2022 diff --git a/.github/workflows/linux-build.yml b/.github/workflows/linux-build.yml index 4d6678e1f..d93d6d2ce 100644 --- a/.github/workflows/linux-build.yml +++ b/.github/workflows/linux-build.yml @@ -123,7 +123,7 @@ jobs: sudo make install # TODO enable clang-tidy-check - # https://bitquill.atlassian.net/browse/AD-726 + # https://github.com/aws/amazon-documentdb-odbc-driver/issues/169 # generate compile_commands.json file for clang-tidy-check, requires mongocxx and boost dependencies # - name: generate-compile-commands-file @@ -276,7 +276,7 @@ jobs: sudo make install # TODO enable clang-tidy-check - # https://bitquill.atlassian.net/browse/AD-726 + # https://github.com/aws/amazon-documentdb-odbc-driver/issues/169 # generate compile_commands.json file for clang-tidy-check, requires mongocxx and boost dependencies # - name: generate-compile-commands-file @@ -401,4 +401,4 @@ jobs: # TODO Linux build enhacements -#https://bitquill.atlassian.net/browse/AD-688 +# https://github.com/aws/amazon-documentdb-odbc-driver/issues/170 diff --git a/.github/workflows/win-build.yml b/.github/workflows/win-build.yml index 7a9ed510f..1935e5f65 100644 --- a/.github/workflows/win-build.yml +++ b/.github/workflows/win-build.yml @@ -71,7 +71,7 @@ jobs: steps: - uses: actions/checkout@v2 # TODO Reactivate cppcheck - # https://bitquill.atlassian.net/browse/AD-752 + # https://github.com/aws/amazon-documentdb-odbc-driver/issues/171 # - name: setup-cppcheck # id: setup_cppcheck # run: | @@ -300,7 +300,7 @@ jobs: role-external-id: ${{ secrets.AWS_ROLE_EXTERNAL_ID }} role-duration-seconds: 3600 # TODO Reactivate cppcheck - # https://bitquill.atlassian.net/browse/AD-752 + # https://github.com/aws/amazon-documentdb-odbc-driver/issues/171 # - name: run-cppcheck # id: setup_cppcheck # run: | diff --git a/scripts/install_dependencies_mac.sh b/scripts/install_dependencies_mac.sh index 82a394817..94b376b69 100755 --- a/scripts/install_dependencies_mac.sh +++ b/scripts/install_dependencies_mac.sh @@ -59,8 +59,8 @@ else fi # [Re-]Install mongodb server -# TODO [AD-833] make re-installing mongodb server optional -# https://bitquill.atlassian.net/browse/AD-833 +# TODO: make re-installing mongodb server optional +# https://github.com/aws/amazon-documentdb-odbc-driver/issues/172 chmod +x $MAC_SCRIPT_DIR/reinstall_mongodb_mac.sh $MAC_SCRIPT_DIR/reinstall_mongodb_mac.sh diff --git a/scripts/test_draft_linux.sh b/scripts/test_draft_linux.sh index 2709c8466..7b8c7b1bd 100755 --- a/scripts/test_draft_linux.sh +++ b/scripts/test_draft_linux.sh @@ -1,4 +1,4 @@ -# TODO: [AD-838](https://bitquill.atlassian.net/browse/AD-838) +# TODO: [Automate setting up environment variables when building driver on Linux](https://github.com/aws/amazon-documentdb-odbc-driver/issues/173) # store current directory CURRENT_DIR=$(pwd) diff --git a/src/markdown/setup/developer-guide.md b/src/markdown/setup/developer-guide.md index d7884fb62..5dc5f6883 100644 --- a/src/markdown/setup/developer-guide.md +++ b/src/markdown/setup/developer-guide.md @@ -31,7 +31,7 @@ Other Environment Variables [`Optional`] Log configurations Set these 2 variables only if you would like to set a custom log path or log level for connection tests; it is completely optional. -1. `DOC_DB_LOG_PATH`=``(e.g.:`"C:\\Users\\BitQuillUser\\Desktop\\DocumentDB ODBC Driver"`) +1. `DOC_DB_LOG_PATH`=``(e.g.:`"C:\\Users\\User\\Desktop\\DocumentDB ODBC Driver"`) The user needs to ensure that the directory mentioned in the log file path does exist, or driver will ignore user's passed value and create the log file in the default log path. Do **not** include a slash at the end of the log path. diff --git a/src/odbc-test/CMakeLists.txt b/src/odbc-test/CMakeLists.txt index dcf07890e..50e91b1b0 100644 --- a/src/odbc-test/CMakeLists.txt +++ b/src/odbc-test/CMakeLists.txt @@ -40,7 +40,6 @@ include_directories(include ../odbc/include) if (WIN32) include_directories(../odbc/os/win/include) else () - # TODO: Ensure MacOS is portable. https://bitquill.atlassian.net/browse/AD-525 include_directories(../odbc/os/linux/include) endif() @@ -187,7 +186,6 @@ if (WIN32) ../odbc/os/win/src/common/dynamic_load_os.cpp ) else() - # TODO: Ensure MacOS is portable. https://bitquill.atlassian.net/browse/AD-525 list(APPEND SOURCES ../odbc/os/linux/src/common/concurrent_os.cpp ../odbc/os/linux/src/common/platform_utils.cpp diff --git a/src/odbc-test/src/api_robustness_test.cpp b/src/odbc-test/src/api_robustness_test.cpp index 8f581668c..deca68b38 100644 --- a/src/odbc-test/src/api_robustness_test.cpp +++ b/src/odbc-test/src/api_robustness_test.cpp @@ -173,8 +173,8 @@ BOOST_AUTO_TEST_CASE(TestSQLSetStmtAttrRowArraySize) { #ifndef __APPLE__ // only enable for Windows and Linux as it crashes on Mac -// with iODBC, traced by AD-820 -// https://bitquill.atlassian.net/browse/AD-820 +// with iODBC, traced by [SPIKE] Two tests crashed on Mac with iODBC +// https://github.com/aws/amazon-documentdb-odbc-driver/issues/183 BOOST_AUTO_TEST_CASE(TestSQLDriverConnect) { // There are no checks because we do not really care what is the result of // these calls as long as they do not cause segmentation fault. @@ -1146,7 +1146,7 @@ BOOST_AUTO_TEST_CASE(TestSQLSpecialColumns) { SQLCloseCursor(stmt); } -// TODO: Memory leak, traced by https://bitquill.atlassian.net/browse/AD-813 +// TODO: Memory leak, traced by https://github.com/aws/amazon-documentdb-odbc-driver/issues/184 BOOST_AUTO_TEST_CASE(TestFetchScrollLast, *disabled()) { CheckFetchScrollUnsupportedOrientation(SQL_FETCH_LAST); } @@ -1161,8 +1161,8 @@ BOOST_AUTO_TEST_CASE(TestFetchScrollFirst, *disabled()) { #ifndef __APPLE__ // only enable for Windows and Linux as it crashes on Mac -// with iODBC, traced by AD-820 -// https://bitquill.atlassian.net/browse/AD-820 +// with iODBC, traced by [SPIKE] Two tests crashed on Mac with iODBC +// https://github.com/aws/amazon-documentdb-odbc-driver/issues/183 BOOST_AUTO_TEST_CASE(TestSQLError) { // There are no checks because we do not really care what is the result of // these calls as long as they do not cause segmentation fault. @@ -1186,10 +1186,10 @@ BOOST_AUTO_TEST_CASE(TestSQLError) { std::vector< SQLWCHAR > actualMessage; actualMessage.insert(actualMessage.end(), &message[0], &message[messageLen + 1]); - // variable actualMessage is to be used in AD-841 + // variable actualMessage is to be used in https://github.com/aws/amazon-documentdb-odbc-driver/issues/185 #if 0 - // TODO: [AD-841](https://bitquill.atlassian.net/browse/AD-841) + // TODO: https://github.com/aws/amazon-documentdb-odbc-driver/issues/185 // Check boundary condition with reduced buffer size. ret = SQLGetTypeInfo(stmt, SQL_INTERVAL_MONTH); BOOST_REQUIRE_EQUAL(ret, SQL_ERROR); diff --git a/src/odbc-test/src/attributes_test.cpp b/src/odbc-test/src/attributes_test.cpp index 82679c24d..6e14bfb97 100644 --- a/src/odbc-test/src/attributes_test.cpp +++ b/src/odbc-test/src/attributes_test.cpp @@ -163,7 +163,7 @@ BOOST_AUTO_TEST_CASE(ConnectionAttributeDefaultLoginTimeout) { // TODO investigate why the setConnectAttr are not being called before // establishing connection // enable test after fix -// https://bitquill.atlassian.net/browse/AD-848 +// https://github.com/aws/amazon-documentdb-odbc-driver/issues/186 #ifndef __APPLE__ BOOST_AUTO_TEST_CASE(ConnectionAttributeLoginTimeout) { Prepare(); diff --git a/src/odbc-test/src/meta_queries_test.cpp b/src/odbc-test/src/meta_queries_test.cpp index ec2e08c5e..45e0ba378 100644 --- a/src/odbc-test/src/meta_queries_test.cpp +++ b/src/odbc-test/src/meta_queries_test.cpp @@ -641,8 +641,9 @@ BOOST_AUTO_TEST_CASE(TestColAttributeDataTypesAndColumnNames) { SQLExecDirect(stmt, req.data(), SQL_NTS); for (int i = 1; i <= numTests; i++) { - // TODO remove below if statement when bug from JDBC (AD-765) is fixed. - // https://bitquill.atlassian.net/browse/AD-766 + // TODO remove below if statement when bug from JDBC is fixed. + // https://github.com/aws/amazon-documentdb-jdbc-driver/issues/498 + // https://github.com/aws/amazon-documentdb-odbc-driver/issues/187 // the fieldNull pair is the 13th pair if (i == 13) continue; @@ -734,8 +735,9 @@ BOOST_AUTO_TEST_CASE(TestColAttributeDescConciseType) { callSQLColAttribute(stmt, req3, SQL_DESC_CONCISE_TYPE, SQL_VARBINARY); - // TODO re-enable this test when bug from JDBC (AD-765) is fixed. - // https://bitquill.atlassian.net/browse/AD-766 + // TODO re-enable this test when bug from JDBC is fixed. + // https://github.com/aws/amazon-documentdb-jdbc-driver/issues/498 + // https://github.com/aws/amazon-documentdb-odbc-driver/issues/187 // const SQLCHAR req4[] = "select fieldNull from meta_queries_test_001"; // // callSQLColAttribute(stmt, req3, SQL_DESC_CONCISE_TYPE, SQL_TYPE_NULL); @@ -1068,8 +1070,9 @@ BOOST_AUTO_TEST_CASE(TestColAttributeDescType) { callSQLColAttribute(stmt, req3, SQL_DESC_TYPE, SQL_VARBINARY); - // TODO re-enable this test when bug from JDBC (AD-765) is fixed. - // https://bitquill.atlassian.net/browse/AD-766 + // TODO re-enable this test when bug from JDBC is fixed. + // https://github.com/aws/amazon-documentdb-jdbc-driver/issues/498 + // https://github.com/aws/amazon-documentdb-odbc-driver/issues/187 // const SQLCHAR req4[] = "select fieldNull from meta_queries_test_001"; // // callSQLColAttribute(stmt, req4, SQL_DESC_TYPE, SQL_TYPE_NULL); diff --git a/src/odbc-test/src/queries_ssl_test.cpp b/src/odbc-test/src/queries_ssl_test.cpp index 19d564565..8778bbe58 100644 --- a/src/odbc-test/src/queries_ssl_test.cpp +++ b/src/odbc-test/src/queries_ssl_test.cpp @@ -138,7 +138,7 @@ BOOST_AUTO_TEST_CASE(TestConnectionSslReject) { } // TODO fix bug on logintimeoutsec on JDBC and ODBC -// https://bitquill.atlassian.net/browse/AD-847 +// https://github.com/aws/amazon-documentdb-odbc-driver/issues/188 BOOST_AUTO_TEST_CASE(TestLoginTimeout, *disabled()) { Prepare(); diff --git a/src/odbc-test/src/queries_test.cpp b/src/odbc-test/src/queries_test.cpp index 5afc8149a..c4d032d16 100644 --- a/src/odbc-test/src/queries_test.cpp +++ b/src/odbc-test/src/queries_test.cpp @@ -749,7 +749,7 @@ BOOST_AUTO_TEST_CASE(TestTwoRowsString) { BOOST_CHECK(ret == SQL_NO_DATA); } -// TODO: Memory leak, traced by https://bitquill.atlassian.net/browse/AD-813 +// TODO: Memory leak, traced by https://github.com/aws/amazon-documentdb-odbc-driver/issues/184 BOOST_AUTO_TEST_CASE(TestOneRowObject, *disabled()) { connectToLocalServer("odbc-test"); @@ -1029,7 +1029,7 @@ BOOST_AUTO_TEST_CASE(TestExecuteAfterCursorClose) { BOOST_CHECK_EQUAL(ret, SQL_NO_DATA); } -// TODO: Memory leak, traced by https://bitquill.atlassian.net/browse/AD-813 +// TODO: Memory leak, traced by https://github.com/aws/amazon-documentdb-odbc-driver/issues/184 BOOST_AUTO_TEST_CASE(TestCloseNonFullFetch, *disabled()) { connectToLocalServer("odbc-test"); @@ -1092,7 +1092,7 @@ BOOST_AUTO_TEST_CASE(TestErrorMessage) { } // TODO fix bug on logintimeoutsec on JDBC and ODBC -// https://bitquill.atlassian.net/browse/AD-847 +// https://github.com/aws/amazon-documentdb-odbc-driver/issues/188 BOOST_AUTO_TEST_CASE(TestLoginTimeout, *disabled()) { Prepare(); @@ -1120,7 +1120,7 @@ BOOST_AUTO_TEST_CASE(TestLoginTimeout, *disabled()) { } // TODO fix bug on logintimeoutsec on JDBC and ODBC -// https://bitquill.atlassian.net/browse/AD-847 +// https://github.com/aws/amazon-documentdb-odbc-driver/issues/188 BOOST_AUTO_TEST_CASE(TestConnectionTimeoutFail, *disabled()) { Prepare(); @@ -1190,7 +1190,7 @@ BOOST_AUTO_TEST_CASE(TestManyCursors) { } } -// TODO: Memory leak, traced by https://bitquill.atlassian.net/browse/AD-813 +// TODO: Memory leak, traced by https://github.com/aws/amazon-documentdb-odbc-driver/issues/184 BOOST_AUTO_TEST_CASE(TestManyCursors2, *disabled()) { connectToLocalServer("odbc-test"); diff --git a/src/odbc/include/documentdb/odbc/log.h b/src/odbc/include/documentdb/odbc/log.h index f871b450e..6c03a049e 100644 --- a/src/odbc/include/documentdb/odbc/log.h +++ b/src/odbc/include/documentdb/odbc/log.h @@ -68,7 +68,7 @@ using documentdb::odbc::common::concurrent::CriticalSection; } // TODO replace and remove LOG_MSG -// https://bitquill.atlassian.net/browse/AD-703 +// https://github.com/aws/amazon-documentdb-odbc-driver/issues/174 // @Deprecated #define LOG_MSG(param) LOG_INFO_MSG(param) @@ -184,7 +184,7 @@ class Logger { static std::shared_ptr< Logger > GetLoggerInstance() { // TODO add locks to prevent 2 or more instances being // created at once - // [AD-716](https://bitquill.atlassian.net/browse/AD-716) + // [Add locks on getLoggerInstance](https://github.com/aws/amazon-documentdb-odbc-driver/issues/175) if (!logger_) logger_ = std::shared_ptr< Logger >(new Logger()); diff --git a/src/odbc/src/config/configuration.cpp b/src/odbc/src/config/configuration.cpp index 41d42fdff..93b5bf11a 100644 --- a/src/odbc/src/config/configuration.cpp +++ b/src/odbc/src/config/configuration.cpp @@ -559,7 +559,7 @@ void Configuration::ToJdbcOptionsMap(ArgumentMap& res) const { AddToMap(res, "refreshSchema", refreshSchema); AddToMap(res, "defaultFetchSize", defaultFetchSize); //TODO expose defaultAuthDB on the DSN config - //https://bitquill.atlassian.net/browse/AD-935 + // https://github.com/aws/amazon-documentdb-odbc-driver/issues/176 } @@ -592,7 +592,7 @@ std::string Configuration::ToMongoDbConnectionString( mongoConnectionString << "@" << host; mongoConnectionString << ":" << port; //TODO expose defaultAuthDB on the DSN config - //https://bitquill.atlassian.net/browse/AD-935 + // https://github.com/aws/amazon-documentdb-odbc-driver/issues/176 mongoConnectionString << "/admin"; mongoConnectionString << INIT_OPT << MONGO_URI_APPNAME << "=" << EncodeURIComponent(GetApplicationName()); @@ -620,10 +620,6 @@ std::string Configuration::ToMongoDbConnectionString( } mongoConnectionString << options.str(); - // tls configuration is handled using tls_options in connectionCPP - // TODO handle the other DSN configuration - // https://bitquill.atlassian.net/browse/AD-599 - return mongoConnectionString.str(); } diff --git a/src/odbc/src/connection.cpp b/src/odbc/src/connection.cpp index db2be5b53..49a9f2a76 100644 --- a/src/odbc/src/connection.cpp +++ b/src/odbc/src/connection.cpp @@ -626,7 +626,7 @@ bool Connection::ConnectCPPDocumentDB(int32_t localSSHTunnelPort, mongocxx::options::tls tls_options; if (config_.IsTls()) { // TODO: Enable use of Amazon RDS CA certificate in driver - // [AD-941](https://bitquill.atlassian.net/browse/AD-941) + // [Enable use of Amazon RDS CA certificate in driver](https://github.com/aws/amazon-documentdb-odbc-driver/issues/177) tls_options.allow_invalid_certificates(true); client_options.tls_opts(tls_options); } diff --git a/src/odbc/src/documentdb_column.cpp b/src/odbc/src/documentdb_column.cpp index 3fe4bdab0..5dd9fecec 100644 --- a/src/odbc/src/documentdb_column.cpp +++ b/src/odbc/src/documentdb_column.cpp @@ -509,7 +509,7 @@ ConversionResult::Type DocumentDbColumn::PutTime( } break; case bsoncxx::type::k_utf8: // TODO: Determine if we could support reading data as string - // https://bitquill.atlassian.net/browse/AD-680 + // https://github.com/aws/amazon-documentdb-odbc-driver/issues/178 convRes = ConversionResult::Type::AI_UNSUPPORTED_CONVERSION; break; default: @@ -544,7 +544,7 @@ ConversionResult::Type DocumentDbColumn::PutDate( } break; case bsoncxx::type::k_utf8: // TODO: Determine if we could support reading data as string - // https://bitquill.atlassian.net/browse/AD-680 + // https://github.com/aws/amazon-documentdb-odbc-driver/issues/178 convRes = ConversionResult::Type::AI_UNSUPPORTED_CONVERSION; break; default: @@ -576,7 +576,7 @@ ConversionResult::Type DocumentDbColumn::PutTimestamp( } break; case bsoncxx::type::k_utf8: // TODO: Determine if we could support reading data as string - // https://bitquill.atlassian.net/browse/AD-680 + // https://github.com/aws/amazon-documentdb-odbc-driver/issues/178 convRes = ConversionResult::Type::AI_UNSUPPORTED_CONVERSION; break; default: diff --git a/src/odbc/src/jni/java.cpp b/src/odbc/src/jni/java.cpp index ff9de3524..f9f68f63a 100644 --- a/src/odbc/src/jni/java.cpp +++ b/src/odbc/src/jni/java.cpp @@ -31,7 +31,7 @@ #include // Todo: Refactor boost::optional to std::optional after code base is migrated -// to C++17 https://bitquill.atlassian.net/browse/AD-631 +// to C++17 https://github.com/aws/amazon-documentdb-odbc-driver/issues/179 using namespace documentdb::odbc::common::concurrent; using namespace documentdb::odbc::jni::java; @@ -1099,7 +1099,7 @@ JniErrorCode JniContext::DriverManagerGetConnection( } // TODO enable string logging and hide the user password. - // https://bitquill.atlassian.net/browse/AD-702 + // https://github.com/aws/amazon-documentdb-odbc-driver/issues/180 // LOG_INFO_MSG("Connection String: [" << connectionString << "]"); jstring jConnectionString = env->NewStringUTF(connectionString); diff --git a/src/odbc/src/odbc.cpp b/src/odbc/src/odbc.cpp index 67dfdb5ea..5edd55f25 100644 --- a/src/odbc/src/odbc.cpp +++ b/src/odbc/src/odbc.cpp @@ -328,7 +328,7 @@ SQLRETURN SQLDriverConnect(SQLHDBC conn, SQLHWND windowHandle, LOG_DEBUG_MSG("SQLDriverConnect called"); // TODO enable logging connection string - // https://bitquill.atlassian.net/browse/AD-702 + // https://github.com/aws/amazon-documentdb-odbc-driver/issues/180 // if (inConnectionString) // LOG_INFO_MSG("Connection String: [" << inConnectionString << "]"); diff --git a/src/odbc/src/query/column_metadata_query.cpp b/src/odbc/src/query/column_metadata_query.cpp index d69969f33..3d546725f 100644 --- a/src/odbc/src/query/column_metadata_query.cpp +++ b/src/odbc/src/query/column_metadata_query.cpp @@ -274,8 +274,8 @@ SqlResult::Type ColumnMetadataQuery::GetColumn( } case ResultColumn::DECIMAL_DIGITS: { - // todo implement the function for getting the decimal digits: - // https://bitquill.atlassian.net/browse/AD-615 + // TODO: implement the function for getting the decimal digits: + // https://github.com/aws/amazon-documentdb-odbc-driver/issues/181 boost::optional< int16_t > decDigits = type_traits::BinaryTypeDecimalDigits(columnType); if (!decDigits || *decDigits < 0) @@ -318,7 +318,7 @@ SqlResult::Type ColumnMetadataQuery::GetColumn( case ResultColumn::SQL_DATETIME_SUB: { buffer.PutNull(); // todo implement the function for getting the datetime sub code: - // https://bitquill.atlassian.net/browse/AD-609 + // https://github.com/aws/amazon-documentdb-odbc-driver/issues/182 break; } diff --git a/src/odbc/src/utility.cpp b/src/odbc/src/utility.cpp index 6182c00d3..c28d57d9b 100644 --- a/src/odbc/src/utility.cpp +++ b/src/odbc/src/utility.cpp @@ -118,9 +118,8 @@ size_t CopyUtf8StringToWcharString(const char* inBuffer, OutCharT* outBuffer, // null-terminate target string, if room pOutBuffer[lenConverted] = 0; - // TODO AD-843 Complete the following comment - // https://bitquill.atlassian.net/browse/AD-843 - // Note: + // Note: This is to detect if resulting buffer is truncated. + // I.e., partial result or if we did not make it to the end of the input buffer. isTruncated = (result == std::codecvt_base::partial || (inBufferEnd != pInBufferNext)); break;