1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
|
#include "catch.hpp"
#include "duckdb/main/appender.hpp"
#include "test_helpers.hpp"
#include <vector>
using namespace duckdb;
using namespace std;
TEST_CASE("Abort appender due to primary key conflict", "[appender]") {
duckdb::unique_ptr<QueryResult> result;
DuckDB db(nullptr);
Connection con(db);
REQUIRE_NO_FAIL(con.Query("CREATE TABLE integers(i INTEGER PRIMARY KEY)"));
REQUIRE_NO_FAIL(con.Query("INSERT INTO integers VALUES (1)"));
Appender appender(con, "integers");
appender.BeginRow();
appender.Append<int32_t>(1);
appender.EndRow();
// this should fail!
REQUIRE_THROWS(appender.Flush());
result = con.Query("SELECT * FROM integers");
REQUIRE(CHECK_COLUMN(result, 0, {1}));
}
|