summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorminfrin <minfrin@13f79535-47bb-0310-9956-ffa450edef68>2008-09-06 22:19:08 +0000
committerminfrin <minfrin@13f79535-47bb-0310-9956-ffa450edef68>2008-09-06 22:19:08 +0000
commit73d7136795c067af72021e07bdd44e3ca22a98ad (patch)
tree6e3aad479c1f3d6690d115af0effe940c74f08ea
parent63cc98993e6e97b24037cad8acd3a16c48279147 (diff)
downloadlibapr-util-73d7136795c067af72021e07bdd44e3ca22a98ad.tar.gz
Fix a segfault in the DBD testcase when the DBD modules were not present.
git-svn-id: http://svn.apache.org/repos/asf/apr/apr-util/trunk@692751 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r--CHANGES3
-rw-r--r--test/testdbd.c26
2 files changed, 22 insertions, 7 deletions
diff --git a/CHANGES b/CHANGES
index 50fc91c0..89a99bd0 100644
--- a/CHANGES
+++ b/CHANGES
@@ -1,6 +1,9 @@
-*- coding: utf-8 -*-
Changes with APR-util 1.4.0
+ *) Fix a segfault in the DBD testcase when the DBD modules were not present.
+ [Graham Leggett]
+
*) Add DTrace Probes to Hooks, making it easier to inspect APR Hook based
applications with DTrace. [Theo Schlossnagle <jesus omniti.com>]
diff --git a/test/testdbd.c b/test/testdbd.c
index e7d16428..682599eb 100644
--- a/test/testdbd.c
+++ b/test/testdbd.c
@@ -31,7 +31,7 @@ static void test_dbd_init(abts_case *tc, void *data)
}
#if APU_HAVE_SQLITE2 || APU_HAVE_SQLITE3
-static void test_statement(abts_case *tc, apr_dbd_t* handle,
+static void test_statement(abts_case *tc, apr_dbd_t* handle,
const apr_dbd_driver_t* driver, const char* sql)
{
int nrows;
@@ -42,7 +42,7 @@ static void test_statement(abts_case *tc, apr_dbd_t* handle,
ABTS_ASSERT(tc, sql, rv == APR_SUCCESS);
}
-static void create_table(abts_case *tc, apr_dbd_t* handle,
+static void create_table(abts_case *tc, apr_dbd_t* handle,
const apr_dbd_driver_t* driver)
{
const char *sql = "CREATE TABLE apr_dbd_test ("
@@ -53,14 +53,14 @@ static void create_table(abts_case *tc, apr_dbd_t* handle,
test_statement(tc, handle, driver, sql);
}
-static void drop_table(abts_case *tc, apr_dbd_t* handle,
+static void drop_table(abts_case *tc, apr_dbd_t* handle,
const apr_dbd_driver_t* driver)
{
const char *sql = "DROP TABLE apr_dbd_test";
test_statement(tc, handle, driver, sql);
}
-static void delete_rows(abts_case *tc, apr_dbd_t* handle,
+static void delete_rows(abts_case *tc, apr_dbd_t* handle,
const apr_dbd_driver_t* driver)
{
const char *sql = "DELETE FROM apr_dbd_test";
@@ -68,7 +68,7 @@ static void delete_rows(abts_case *tc, apr_dbd_t* handle,
}
-static void insert_data(abts_case *tc, apr_dbd_t* handle,
+static void insert_data(abts_case *tc, apr_dbd_t* handle,
const apr_dbd_driver_t* driver, int count)
{
apr_pool_t* pool = p;
@@ -86,7 +86,7 @@ static void insert_data(abts_case *tc, apr_dbd_t* handle,
}
}
-static void select_rows(abts_case *tc, apr_dbd_t* handle,
+static void select_rows(abts_case *tc, apr_dbd_t* handle,
const apr_dbd_driver_t* driver, int count)
{
apr_status_t rv;
@@ -144,7 +144,7 @@ static void test_escape(abts_case *tc, apr_dbd_t *handle,
ABTS_STR_EQUAL(tc, "foo''bar", escaped);
}
-static void test_dbd_generic(abts_case *tc, apr_dbd_t* handle,
+static void test_dbd_generic(abts_case *tc, apr_dbd_t* handle,
const apr_dbd_driver_t* driver)
{
void* native;
@@ -182,12 +182,18 @@ static void test_dbd_sqlite2(abts_case *tc, void *data)
rv = apr_dbd_get_driver(pool, "sqlite2", &driver);
ABTS_ASSERT(tc, "failed to fetch driver", rv == APR_SUCCESS);
ABTS_PTR_NOTNULL(tc, driver);
+ if (!driver) {
+ return;
+ }
ABTS_STR_EQUAL(tc, "sqlite2", apr_dbd_name(driver));
rv = apr_dbd_open(driver, pool, "data/sqlite2.db:600", &handle);
ABTS_ASSERT(tc, "failed to open database", rv == APR_SUCCESS);
ABTS_PTR_NOTNULL(tc, handle);
+ if (!handle) {
+ return;
+ }
test_dbd_generic(tc, handle, driver);
}
@@ -204,12 +210,18 @@ static void test_dbd_sqlite3(abts_case *tc, void *data)
rv = apr_dbd_get_driver(pool, "sqlite3", &driver);
ABTS_ASSERT(tc, "failed to fetch driver", rv == APR_SUCCESS);
ABTS_PTR_NOTNULL(tc, driver);
+ if (!driver) {
+ return;
+ }
ABTS_STR_EQUAL(tc, "sqlite3", apr_dbd_name(driver));
rv = apr_dbd_open(driver, pool, "data/sqlite3.db", &handle);
ABTS_ASSERT(tc, "failed to open database", rv == APR_SUCCESS);
ABTS_PTR_NOTNULL(tc, handle);
+ if (!handle) {
+ return;
+ }
test_dbd_generic(tc, handle, driver);
}