You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@subversion.apache.org by ph...@apache.org on 2013/10/28 19:08:37 UTC

svn commit: r1536460 - in /subversion/trunk: build.conf subversion/include/private/svn_sqlite.h subversion/libsvn_subr/sqlite.c subversion/tests/libsvn_subr/sqlite-test.c

Author: philip
Date: Mon Oct 28 18:08:36 2013
New Revision: 1536460

URL: http://svn.apache.org/r1536460
Log:
Add a regression test for a small part of the SQLite wrapping code.

* build.conf
  (sqlite-test): New.

* subversion/include/private/svn_sqlite.h
  (svn_sqlite__result_error): New.

* subversion/libsvn_subr/sqlite.c
  (svn_sqlite__result_error): New.

* subversion/tests/libsvn_subr/sqlite-test.c: New file.

Added:
    subversion/trunk/subversion/tests/libsvn_subr/sqlite-test.c
Modified:
    subversion/trunk/build.conf
    subversion/trunk/subversion/include/private/svn_sqlite.h
    subversion/trunk/subversion/libsvn_subr/sqlite.c

Modified: subversion/trunk/build.conf
URL: http://svn.apache.org/viewvc/subversion/trunk/build.conf?rev=1536460&r1=1536459&r2=1536460&view=diff
==============================================================================
--- subversion/trunk/build.conf (original)
+++ subversion/trunk/build.conf Mon Oct 28 18:08:36 2013
@@ -1051,6 +1051,14 @@ sources = string-test.c
 install = test
 libs = libsvn_test libsvn_subr apriconv apr
 
+[sqlite-test]
+description = Test stream library
+type = exe
+path = subversion/tests/libsvn_subr
+sources = sqlite-test.c
+install = test
+libs = libsvn_test libsvn_subr apriconv apr
+
 [time-test]
 description = Test time functions
 type = exe

Modified: subversion/trunk/subversion/include/private/svn_sqlite.h
URL: http://svn.apache.org/viewvc/subversion/trunk/subversion/include/private/svn_sqlite.h?rev=1536460&r1=1536459&r2=1536460&view=diff
==============================================================================
--- subversion/trunk/subversion/include/private/svn_sqlite.h (original)
+++ subversion/trunk/subversion/include/private/svn_sqlite.h Mon Oct 28 18:08:36 2013
@@ -372,6 +372,9 @@ svn_sqlite__result_null(svn_sqlite__cont
 void
 svn_sqlite__result_int64(svn_sqlite__context_t *sctx, apr_int64_t val);
 
+void
+svn_sqlite__result_error(svn_sqlite__context_t *sctx, const char *msg, int num);
+
 
 /* --------------------------------------------------------------------- */
 

Modified: subversion/trunk/subversion/libsvn_subr/sqlite.c
URL: http://svn.apache.org/viewvc/subversion/trunk/subversion/libsvn_subr/sqlite.c?rev=1536460&r1=1536459&r2=1536460&view=diff
==============================================================================
--- subversion/trunk/subversion/libsvn_subr/sqlite.c (original)
+++ subversion/trunk/subversion/libsvn_subr/sqlite.c Mon Oct 28 18:08:36 2013
@@ -1437,3 +1437,9 @@ svn_sqlite__result_int64(svn_sqlite__con
 {
   sqlite3_result_int64(sctx->context, val);
 }
+
+void
+svn_sqlite__result_error(svn_sqlite__context_t *sctx, const char *msg, int num)
+{
+  sqlite3_result_error(sctx->context, msg, num);
+}

Added: subversion/trunk/subversion/tests/libsvn_subr/sqlite-test.c
URL: http://svn.apache.org/viewvc/subversion/trunk/subversion/tests/libsvn_subr/sqlite-test.c?rev=1536460&view=auto
==============================================================================
--- subversion/trunk/subversion/tests/libsvn_subr/sqlite-test.c (added)
+++ subversion/trunk/subversion/tests/libsvn_subr/sqlite-test.c Mon Oct 28 18:08:36 2013
@@ -0,0 +1,119 @@
+/*
+ * sqlite-test.c -- test the stream functions
+ *
+ * ====================================================================
+ *    Licensed to the Apache Software Foundation (ASF) under one
+ *    or more contributor license agreements.  See the NOTICE file
+ *    distributed with this work for additional information
+ *    regarding copyright ownership.  The ASF licenses this file
+ *    to you under the Apache License, Version 2.0 (the
+ *    "License"); you may not use this file except in compliance
+ *    with the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ *    Unless required by applicable law or agreed to in writing,
+ *    software distributed under the License is distributed on an
+ *    "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ *    KIND, either express or implied.  See the License for the
+ *    specific language governing permissions and limitations
+ *    under the License.
+ * ====================================================================
+ */
+
+#include "private/svn_sqlite.h"
+#include "../svn_test.h"
+
+static svn_error_t *
+open_db(svn_sqlite__db_t **sdb,
+        const char *db_name,
+        const char *const *statements,
+        apr_pool_t *pool)
+{
+  const char *db_dir, *db_abspath;
+
+  SVN_ERR(svn_dirent_get_absolute(&db_dir, "sqlite-test-tmp", pool));
+  SVN_ERR(svn_io_remove_dir2(db_dir, TRUE, NULL, NULL, pool));
+  SVN_ERR(svn_io_make_dir_recursively(db_dir, pool));
+  svn_test_add_dir_cleanup(db_dir);
+
+  db_abspath = svn_dirent_join(db_dir, db_name, pool);
+
+  SVN_ERR(svn_sqlite__open(sdb, db_abspath, svn_sqlite__mode_rwcreate,
+                           statements, 0, NULL, pool, pool));
+
+  return SVN_NO_ERROR;
+}
+
+static svn_error_t *
+error_second(svn_sqlite__context_t *sctx,
+             int argc,
+             svn_sqlite__value_t *values[],
+             apr_pool_t *scratch_pool)
+{
+  static int i = 0;
+
+  if (++i == 2)
+    svn_sqlite__result_error(sctx, "fake error", 0);
+  else
+    svn_sqlite__result_int64(sctx, 1);
+  
+  return SVN_NO_ERROR;
+}
+
+static svn_error_t *
+test_sqlite_reset(apr_pool_t *pool)
+{
+  svn_sqlite__db_t *sdb;
+  svn_sqlite__stmt_t *stmt;
+  svn_boolean_t have_row;
+  const char *value;
+
+  static const char *const statements[] = {
+    "CREATE TABLE reset ("
+    "    one TEXT NOT NULL,"
+    "    two TEXT"
+    ");"
+    "INSERT INTO reset(one, two) VALUES ('foo', 'bar');"
+    "INSERT INTO reset(one, two) VALUES ('zig', 'zag')",
+
+    "SELECT one FROM reset WHERE two IS NOT NULL AND error_second(one)",
+
+    NULL
+  };
+
+  SVN_ERR(open_db(&sdb, "reset", statements, pool));
+  SVN_ERR(svn_sqlite__create_scalar_function(sdb, "error_second", 1,
+                                             error_second, NULL));
+  SVN_ERR(svn_sqlite__exec_statements(sdb, 0));
+  SVN_ERR(svn_sqlite__get_statement(&stmt, sdb, 1));
+
+  /* First step is OK. */
+  SVN_ERR(svn_sqlite__step(&have_row, stmt));
+  SVN_TEST_ASSERT(have_row);
+  value = svn_sqlite__column_text(stmt, 0, NULL);
+  SVN_TEST_ASSERT(value && !strcmp(value, "foo"));
+
+  /* Second step fails. */
+  SVN_TEST_ASSERT_ERROR(svn_sqlite__step(&have_row, stmt),
+                        SVN_ERR_SQLITE_ERROR);
+
+  /* Reset and then the first step can be repeated. */
+  SVN_ERR(svn_sqlite__reset(stmt));
+  SVN_ERR(svn_sqlite__step(&have_row, stmt));
+  SVN_TEST_ASSERT(have_row);
+  value = svn_sqlite__column_text(stmt, 0, NULL);
+  SVN_TEST_ASSERT(value && !strcmp(value, "foo"));
+  SVN_ERR(svn_sqlite__reset(stmt));
+
+  return SVN_NO_ERROR;
+}
+
+
+struct svn_test_descriptor_t test_funcs[] =
+  {
+    SVN_TEST_NULL,
+    SVN_TEST_PASS2(test_sqlite_reset,
+                   "sqlite reset"),
+    SVN_TEST_NULL
+  };