⌘+k ctrl+k
1.3 (稳定版)
搜索快捷键 cmd + k | ctrl + k
Catch C/C++ 测试

尽管我们更倾向于使用 sqllogic 测试来测试大部分功能,但对于某些测试,仅使用 SQL 是不够的。这通常发生在您想要测试 C++ API 的情况下。当纯 SQL 确实不是一个选项时,可能需要使用 Catch 框架进行 C++ 测试。

Catch 测试也位于测试目录下。以下是一个 Catch 测试的示例,用于测试系统的存储功能

#include "catch.hpp"
#include "test_helpers.hpp"

TEST_CASE("Test simple storage", "[storage]") {
    auto config = GetTestConfig();
    unique_ptr<QueryResult> result;
    auto storage_database = TestCreatePath("storage_test");

    // make sure the database does not exist
    DeleteDatabase(storage_database);
    {
        // create a database and insert values
        DuckDB db(storage_database, config.get());
        Connection con(db);
        REQUIRE_NO_FAIL(con.Query("CREATE TABLE test (a INTEGER, b INTEGER);"));
        REQUIRE_NO_FAIL(con.Query("INSERT INTO test VALUES (11, 22), (13, 22), (12, 21), (NULL, NULL)"));
        REQUIRE_NO_FAIL(con.Query("CREATE TABLE test2 (a INTEGER);"));
        REQUIRE_NO_FAIL(con.Query("INSERT INTO test2 VALUES (13), (12), (11)"));
    }
    // reload the database from disk a few times
    for (idx_t i = 0; i < 2; i++) {
        DuckDB db(storage_database, config.get());
        Connection con(db);
        result = con.Query("SELECT * FROM test ORDER BY a");
        REQUIRE(CHECK_COLUMN(result, 0, {Value(), 11, 12, 13}));
        REQUIRE(CHECK_COLUMN(result, 1, {Value(), 22, 21, 22}));
        result = con.Query("SELECT * FROM test2 ORDER BY a");
        REQUIRE(CHECK_COLUMN(result, 0, {11, 12, 13}));
    }
    DeleteDatabase(storage_database);
}

该测试使用 TEST_CASE 包装器来创建每个测试。数据库使用 C++ API 创建和查询。结果通过 REQUIRE_FAIL / REQUIRE_NO_FAIL 进行检查(分别对应语句成功和语句错误),或通过 REQUIRE(CHECK_COLUMN(...)) 进行检查(对应带结果检查的查询)。以这种方式创建的每个测试都需要添加到相应的 CMakeLists.txt 中。