summaryrefslogtreecommitdiff
path: root/test/csharp/HashDatabaseTest.cs
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@baserock.org>2015-02-17 17:25:57 +0000
committer <>2015-03-17 16:26:24 +0000
commit780b92ada9afcf1d58085a83a0b9e6bc982203d1 (patch)
tree598f8b9fa431b228d29897e798de4ac0c1d3d970 /test/csharp/HashDatabaseTest.cs
parent7a2660ba9cc2dc03a69ddfcfd95369395cc87444 (diff)
downloadberkeleydb-master.tar.gz
Imported from /home/lorry/working-area/delta_berkeleydb/db-6.1.23.tar.gz.HEADdb-6.1.23master
Diffstat (limited to 'test/csharp/HashDatabaseTest.cs')
-rw-r--r--test/csharp/HashDatabaseTest.cs294
1 files changed, 292 insertions, 2 deletions
diff --git a/test/csharp/HashDatabaseTest.cs b/test/csharp/HashDatabaseTest.cs
index cba722f8..b03319d9 100644
--- a/test/csharp/HashDatabaseTest.cs
+++ b/test/csharp/HashDatabaseTest.cs
@@ -1,7 +1,7 @@
/*-
* See the file LICENSE for redistribution information.
*
- * Copyright (c) 2009, 2012 Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2009, 2015 Oracle and/or its affiliates. All rights reserved.
*
*/
using System;
@@ -25,6 +25,242 @@ namespace CsharpAPITest
base.SetUpTestfixture();
}
+ [Test]
+ public void TestBlob() {
+ testName = "TestBlob";
+ SetUpTest(false);
+ // Test opening the blob database without environment.
+ TestBlobHashDatabase(0, null, 6, null, false);
+
+ /*
+ * Test opening the blob database without environment
+ * but specifying blob directory.
+ */
+ TestBlobHashDatabase(0, null, 6, testHome + "/DBBLOB", true);
+
+ // Test opening the blob database with environment.
+ TestBlobHashDatabase(3, "ENVBLOB", 6, null, false);
+
+ /*
+ * Test opening the blob database with environment
+ * and specifying blob directory.
+ */
+ TestBlobHashDatabase(3, null, 6, "/DBBLOB", true);
+ }
+
+ /*
+ * Test the blob database with or without environment.
+ * 1. Config and open the environment;
+ * 2. Verify the environment blob configs;
+ * 3. Config and open the database;
+ * 4. Verify the database blob configs;
+ * 5. Insert and verify some blob data by database methods;
+ * 6. Insert some blob data by cursor, update it and verify
+ * the update by database stream and cursor;
+ * 7. Verify the stats;
+ * 8. Close all handles.
+ * If "blobdbt" is true, set the data DatabaseEntry.Blob as
+ * true, otherwise make the data DatabaseEntry reach the blob
+ * threshold in size.
+ */
+ void TestBlobHashDatabase(uint env_threshold, string env_blobdir,
+ uint db_threshold, string db_blobdir, bool blobdbt)
+ {
+ if (env_threshold == 0 && db_threshold == 0)
+ return;
+
+ string hashDBName =
+ testHome + "/" + testName + ".db";
+
+ Configuration.ClearDir(testHome);
+ HashDatabaseConfig cfg = new HashDatabaseConfig();
+ cfg.Creation = CreatePolicy.ALWAYS;
+ string blrootdir = "__db_bl";
+
+ // Open the environment and verify the blob config.
+ if (env_threshold > 0)
+ {
+ DatabaseEnvironmentConfig envConfig =
+ new DatabaseEnvironmentConfig();
+ envConfig.AutoCommit = true;
+ envConfig.Create = true;
+ envConfig.UseMPool = true;
+ envConfig.UseLogging = true;
+ envConfig.UseTxns = true;
+ envConfig.UseLocking = true;
+ envConfig.BlobThreshold = env_threshold;
+ if (env_blobdir != null)
+ {
+ envConfig.BlobDir = env_blobdir;
+ blrootdir = env_blobdir;
+ }
+ DatabaseEnvironment env = DatabaseEnvironment.Open(
+ testHome, envConfig);
+ if (env_blobdir == null)
+ Assert.IsNull(env.BlobDir);
+ else
+ Assert.AreEqual(0,
+ env.BlobDir.CompareTo(env_blobdir));
+ Assert.AreEqual(env_threshold, env.BlobThreshold);
+ cfg.Env = env;
+ hashDBName = testName + ".db";
+ }
+
+ // Open the database and verify the blob config.
+ if (db_threshold > 0)
+ cfg.BlobThreshold = db_threshold;
+ if (db_blobdir != null)
+ {
+ cfg.BlobDir = db_blobdir;
+ /*
+ * The blob directory setting in the database
+ * is effective only when it is opened without
+ * an environment.
+ */
+ if (cfg.Env == null)
+ blrootdir = db_blobdir;
+ }
+
+ HashDatabase db = HashDatabase.Open(hashDBName, cfg);
+ Assert.AreEqual(
+ db_threshold > 0 ? db_threshold : env_threshold,
+ db.BlobThreshold);
+ if (db_blobdir == null && cfg.Env == null)
+ Assert.IsNull(db.BlobDir);
+ else
+ Assert.AreEqual(0,
+ db.BlobDir.CompareTo(blrootdir));
+
+ // Insert and verify some blob data by database methods.
+ string[] records = {"a", "b", "c", "d", "e", "f", "g", "h",
+ "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s",
+ "t", "u", "v", "w", "x", "y", "z"};
+ DatabaseEntry kdbt = new DatabaseEntry();
+ DatabaseEntry ddbt = new DatabaseEntry();
+ byte[] kdata, ddata;
+ string str;
+ KeyValuePair<DatabaseEntry, DatabaseEntry> pair;
+ ddbt.Blob = blobdbt;
+ Assert.AreEqual(blobdbt, ddbt.Blob);
+ for (int i = 0; i < records.Length; i++)
+ {
+ kdata = BitConverter.GetBytes(i);
+ str = records[i];
+ if (!blobdbt)
+ {
+ for (int j = 0; j < db_threshold; j++)
+ str = str + records[i];
+ }
+ ddata = Encoding.ASCII.GetBytes(str);
+ kdbt.Data = kdata;
+ ddbt.Data = ddata;
+ db.Put(kdbt, ddbt);
+ try
+ {
+ pair = db.Get(kdbt);
+ }
+ catch (DatabaseException)
+ {
+ db.Close();
+ if (cfg.Env != null)
+ cfg.Env.Close();
+ throw new TestException();
+ }
+ Assert.AreEqual(ddata, pair.Value.Data);
+ }
+
+ /*
+ * Insert some blob data by cursor, update it and verify
+ * the update by database stream.
+ */
+ kdata = BitConverter.GetBytes(records.Length);
+ ddata = Encoding.ASCII.GetBytes("abc");
+ kdbt.Data = kdata;
+ ddbt.Data = ddata;
+ ddbt.Blob = true;
+ Assert.IsTrue(ddbt.Blob);
+ pair =
+ new KeyValuePair<DatabaseEntry, DatabaseEntry>(kdbt, ddbt);
+ CursorConfig dbcConfig = new CursorConfig();
+ Transaction txn = null;
+ if (cfg.Env != null)
+ txn = cfg.Env.BeginTransaction();
+ HashCursor cursor = db.Cursor(dbcConfig, txn);
+ cursor.Add(pair);
+ DatabaseStreamConfig dbsc = new DatabaseStreamConfig();
+ dbsc.SyncPerWrite = true;
+ DatabaseStream dbs = cursor.DbStream(dbsc);
+ Assert.AreNotEqual(null, dbs);
+ Assert.IsFalse(dbs.GetConfig.ReadOnly);
+ Assert.IsTrue(dbs.GetConfig.SyncPerWrite);
+ Assert.AreEqual(3, dbs.Size());
+ DatabaseEntry sdbt = dbs.Read(0, 3);
+ Assert.IsNotNull(sdbt);
+ Assert.AreEqual(ddata, sdbt.Data);
+ sdbt = new DatabaseEntry(Encoding.ASCII.GetBytes("defg"));
+ Assert.IsTrue(dbs.Write(sdbt, 3));
+ Assert.AreEqual(7, dbs.Size());
+ sdbt = dbs.Read(0, 7);
+ Assert.IsNotNull(sdbt);
+ Assert.AreEqual(Encoding.ASCII.GetBytes("abcdefg"), sdbt.Data);
+ dbs.Close();
+
+ /*
+ * Verify the database stream can not write when it is
+ * configured to be read-only.
+ */
+ dbsc.ReadOnly = true;
+ dbs = cursor.DbStream(dbsc);
+ Assert.IsTrue(dbs.GetConfig.ReadOnly);
+ try
+ {
+ Assert.IsFalse(dbs.Write(sdbt, 7));
+ throw new TestException();
+ }
+ catch (DatabaseException)
+ {
+ }
+ dbs.Close();
+
+ // Verify the update by cursor.
+ Assert.IsTrue(cursor.Move(kdbt, true));
+ pair = cursor.Current;
+ Assert.AreEqual(Encoding.ASCII.GetBytes("abcdefg"),
+ pair.Value.Data);
+ cursor.Close();
+ if (cfg.Env != null)
+ txn.Commit();
+
+ /*
+ * Verify the blob files are created in the expected location.
+ * This part of test is disabled since BTreeDatabase.BlobSubDir
+ * is not exposed to users.
+ */
+ //if (cfg.Env != null)
+ // blrootdir = testHome + "/" + blrootdir;
+ //string blobdir = blrootdir + "/" + db.BlobSubDir;
+ //Assert.AreEqual(records.Length + 1,
+ // Directory.GetFiles(blobdir, "__db.bl*").Length);
+ //Assert.AreEqual(1,
+ // Directory.GetFiles(blobdir, "__db_blob_meta.db").Length);
+
+ // Verify the stats.
+ HashStats st = db.Stats();
+ Assert.AreEqual(records.Length + 1, st.nBlobRecords);
+
+ // Close all handles.
+ db.Close();
+ if (cfg.Env != null)
+ cfg.Env.Close();
+
+ /*
+ * Remove the default blob directory
+ * when it is not under the test home.
+ */
+ if (db_blobdir == null && cfg.Env == null)
+ Directory.Delete("__db_bl", true);
+ }
+
[Test]
public void TestCompactWithoutTxn() {
int i, nRecs;
@@ -163,6 +399,60 @@ namespace CsharpAPITest
}
[Test]
+ public void TestMessageFile()
+ {
+ testName = "TestMessageFile";
+ SetUpTest(true);
+
+ // Configure and open an environment.
+ DatabaseEnvironmentConfig envConfig =
+ new DatabaseEnvironmentConfig();
+ envConfig.Create = true;
+ envConfig.UseMPool = true;
+ DatabaseEnvironment env = DatabaseEnvironment.Open(
+ testHome, envConfig);
+
+ // Configure and open a database.
+ HashDatabaseConfig DBConfig =
+ new HashDatabaseConfig();
+ DBConfig.Env = env;
+ DBConfig.Creation = CreatePolicy.IF_NEEDED;
+
+ string DBFileName = testName + ".db";
+ HashDatabase db = HashDatabase.Open(DBFileName, DBConfig);
+
+ // Confirm message file does not exist.
+ string messageFile = testHome + "/" + "msgfile";
+ Assert.AreEqual(false, File.Exists(messageFile));
+
+ // Call set_msgfile() of db.
+ db.Msgfile = messageFile;
+
+ // Print db statistic to message file.
+ db.PrintStats(true);
+
+ // Confirm message file exists now.
+ Assert.AreEqual(true, File.Exists(messageFile));
+
+ db.Msgfile = "";
+ string line = null;
+
+ // Read the third line of message file.
+ System.IO.StreamReader file = new System.IO.StreamReader(@"" + messageFile);
+ line = file.ReadLine();
+ line = file.ReadLine();
+ line = file.ReadLine();
+
+ // Confirm the message file is not empty.
+ Assert.AreEqual(line, "DB handle information:");
+ file.Close();
+
+ // Close database and environment.
+ db.Close();
+ env.Close();
+ }
+
+ [Test]
public void TestOpenNewHashDB()
{
testName = "TestOpenNewHashDB";
@@ -463,7 +753,7 @@ namespace CsharpAPITest
{
Assert.AreEqual(10, stats.FillFactor);
Assert.AreEqual(4096, stats.PageSize);
- Assert.AreNotEqual(0, stats.Version);
+ Assert.AreEqual(10, stats.Version);
}
public void ConfirmStatsPart2Case1(HashStats stats)