1 # See the file LICENSE for redistribution information.
3 # Copyright (c) 1996, 2012 Oracle and/or its affiliates. All rights reserved.
8 # TEST Test multiple data directories. Do a bunch of different opens
9 # TEST to make sure that the files are detected in different directories.
14 set omethod [convert_method $method]
15 set args [convert_args $method ""]
17 puts "Env004: Multiple data directory test."
20 file mkdir $testdir/data1
21 file mkdir $testdir/data2
22 file mkdir $testdir/data3
24 puts "\tEnv004.a: Multiple data directories in DB_CONFIG file"
26 # Create a config file
27 set cid [open $testdir/DB_CONFIG w]
28 puts $cid "set_data_dir ."
29 puts $cid "set_data_dir data1"
30 puts $cid "set_data_dir data2"
31 puts $cid "set_data_dir data3"
34 set e [berkdb_env -create -private -home $testdir]
35 error_check_good dbenv [is_valid_env $e] TRUE
36 ddir_test $method $e $args
37 error_check_good env_close [$e close] 0
39 puts "\tEnv004.b: Multiple data directories in berkdb_env call."
41 file mkdir $testdir/data1
42 file mkdir $testdir/data2
43 file mkdir $testdir/data3
45 # Now call dbenv with config specified
46 set e [berkdb_env -create -private \
47 -data_dir . -data_dir data1 -data_dir data2 \
48 -data_dir data3 -home $testdir]
49 error_check_good dbenv [is_valid_env $e] TRUE
50 ddir_test $method $e $args
51 error_check_good env_close [$e close] 0
54 proc ddir_test { method e args } {
57 set args [convert_args $args]
58 set omethod [convert_method $method]
60 # Now create one file in each directory
61 set db1 [eval {berkdb_open -create \
62 -truncate -mode 0644 $omethod -env $e} $args {data1/datafile1.db}]
63 error_check_good dbopen1 [is_valid_db $db1] TRUE
65 set db2 [eval {berkdb_open -create \
66 -truncate -mode 0644 $omethod -env $e} $args {data2/datafile2.db}]
67 error_check_good dbopen2 [is_valid_db $db2] TRUE
69 set db3 [eval {berkdb_open -create \
70 -truncate -mode 0644 $omethod -env $e} $args {data3/datafile3.db}]
71 error_check_good dbopen3 [is_valid_db $db3] TRUE
74 error_check_good db_close1 [$db1 close] 0
75 error_check_good db_close2 [$db2 close] 0
76 error_check_good db_close3 [$db3 close] 0
78 # Now, reopen the files without complete pathnames and make
79 # sure that we find them.
81 set db1 [berkdb_open -env $e datafile1.db]
82 error_check_good dbopen1 [is_valid_db $db1] TRUE
84 set db2 [berkdb_open -env $e datafile2.db]
85 error_check_good dbopen2 [is_valid_db $db2] TRUE
87 set db3 [berkdb_open -env $e datafile3.db]
88 error_check_good dbopen3 [is_valid_db $db3] TRUE
90 # Finally close all the files
91 error_check_good db_close1 [$db1 close] 0
92 error_check_good db_close2 [$db2 close] 0
93 error_check_good db_close3 [$db3 close] 0