libdb/test/tcl/test106.tcl
2011-09-13 13:44:24 -04:00

113 lines
3.1 KiB
Tcl

# See the file LICENSE for redistribution information.
#
# Copyright (c) 2003, 2011 Oracle and/or its affiliates. All rights reserved.
#
# $Id$
#
# TEST test106
# TEST
# TEST
# TEST
proc test106 { method {nitems 100} {niter 200} {tnum "106"} args } {
source ./include.tcl
global dict
global rand_init
# Set random seed for use in t106script procs op2 and create_data.
error_check_good set_random_seed [berkdb srand $rand_init] 0
set args [convert_args $method $args]
set omethod [convert_method $method]
set pageargs ""
split_pageargs $args pageargs
if { [is_btree $method] != 1 } {
puts "\tTest$tnum: Skipping for method $method."
return
}
# Skip for specified pagesizes. This test runs at the native
# pagesize. (For SR #7964 testing, we may need to force
# to 8192.)
set pgindex [lsearch -exact $args "-pagesize"]
if { $pgindex != -1 } {
puts "Test$tnum: Skipping for specific pagesizes"
return
}
# This test needs a txn-enabled environment. If one is not
# provided, create it.
#
set eindex [lsearch -exact $args "-env"]
if { $eindex == -1 } {
set env \
[eval {berkdb_env -create -home $testdir -txn} $pageargs]
} else {
incr eindex
set env [lindex $args $eindex]
set txnenv [is_txnenv $env]
if { $txnenv != 1 } {
puts "Skipping test$tnum for non-txn environment."
return
}
set testdir [get_home $env]
}
cleanup $testdir $env
# The bulk of the work of this test is done in t106script.tcl.
# Here we kick off one consumer, then five producers, then sit
# back and wait for them to finish.
foreach order { ordered random } {
set nproducers 5
puts "\tTest$tnum.a: Start deadlock detector ($order)."
set dpid [exec $util_path/db_deadlock -a o -v -t 5\
-h $testdir >& $testdir/dd.out &]
puts "\tTest$tnum.b: Start consumer process ($order)."
sentinel_init
set pidlist {}
set cpid [exec $tclsh_path $test_path/wrap.tcl t106script.tcl \
$testdir/t106script.log.cons.$order.1 $testdir WAIT \
0 $nproducers $testdir/CONSUMERLOG 1 $tnum $order $niter \
$args &]
lappend pidlist $cpid
puts "\tTest$tnum.c: Initialize producers ($order)."
for { set p 1 } { $p <= $nproducers } { incr p } {
set ppid [exec $tclsh_path $test_path/wrap.tcl \
t106script.tcl \
$testdir/t106script.log.init.$order.$p \
$testdir INITIAL $nitems $nproducers \
$testdir/INITLOG.$p $p $tnum \
$order $niter $args &]
lappend pidlist $ppid
}
# Wait for all producers to be initialized before continuing
# to the RMW portion of the test.
watch_procs $pidlist 10
sentinel_init
set pidlist {}
puts "\tTest$tnum.d: Run producers in RMW mode ($order)."
for { set p 1 } { $p <= $nproducers } { incr p } {
set ppid [exec $tclsh_path $test_path/wrap.tcl \
t106script.tcl \
$testdir/t106script.log.prod.$order.$p \
$testdir PRODUCE $nitems $nproducers \
$testdir/PRODUCERLOG.$p $p $tnum \
$order $niter $args &]
lappend pidlist $ppid
}
watch_procs $pidlist 10
tclkill $dpid
}
# If this test created the env, close it.
if { $eindex == -1 } {
error_check_good env_close [$env close] 0
}
}