mariadb/bdb/test/lock003.tcl

100 lines
2.6 KiB
Tcl
Raw Normal View History

2001-03-05 01:42:05 +01:00
# See the file LICENSE for redistribution information.
#
2002-10-30 12:57:05 +01:00
# Copyright (c) 1996-2002
2001-03-05 01:42:05 +01:00
# Sleepycat Software. All rights reserved.
#
2002-10-30 12:57:05 +01:00
# $Id: lock003.tcl,v 11.25 2002/09/05 17:23:06 sandstro Exp $
2001-03-05 01:42:05 +01:00
#
2002-10-30 12:57:05 +01:00
# TEST lock003
# TEST Exercise multi-process aspects of lock. Generate a bunch of parallel
# TEST testers that try to randomly obtain locks; make sure that the locks
# TEST correctly protect corresponding objects.
proc lock003 { {iter 500} {max 1000} {procs 5} } {
2001-03-05 01:42:05 +01:00
source ./include.tcl
2002-10-30 12:57:05 +01:00
global lock_curid
global lock_maxid
set ldegree 5
set objs 75
set reads 65
set wait 1
set conflicts { 0 0 0 0 0 1 0 1 1}
set seeds {}
2001-03-05 01:42:05 +01:00
puts "Lock003: Multi-process random lock test"
# Clean up after previous runs
2002-10-30 12:57:05 +01:00
env_cleanup $testdir
2001-03-05 01:42:05 +01:00
# Open/create the lock region
2002-10-30 12:57:05 +01:00
puts "\tLock003.a: Create environment"
set e [berkdb_env -create -lock -home $testdir]
2001-03-05 01:42:05 +01:00
error_check_good env_open [is_substr $e env] 1
2002-10-30 12:57:05 +01:00
$e lock_id_set $lock_curid $lock_maxid
2001-03-05 01:42:05 +01:00
2002-10-30 12:57:05 +01:00
error_check_good env_close [$e close] 0
2001-03-05 01:42:05 +01:00
# Now spawn off processes
set pidlist {}
2002-10-30 12:57:05 +01:00
2001-03-05 01:42:05 +01:00
for { set i 0 } {$i < $procs} {incr i} {
if { [llength $seeds] == $procs } {
set s [lindex $seeds $i]
}
2002-10-30 12:57:05 +01:00
# puts "$tclsh_path\
# $test_path/wrap.tcl \
# lockscript.tcl $testdir/$i.lockout\
# $testdir $iter $objs $wait $ldegree $reads &"
2001-03-05 01:42:05 +01:00
set p [exec $tclsh_path $test_path/wrap.tcl \
lockscript.tcl $testdir/lock003.$i.out \
2002-10-30 12:57:05 +01:00
$testdir $iter $objs $wait $ldegree $reads &]
2001-03-05 01:42:05 +01:00
lappend pidlist $p
}
2002-10-30 12:57:05 +01:00
puts "\tLock003.b: $procs independent processes now running"
watch_procs $pidlist 30 10800
# Check for test failure
set e [eval findfail [glob $testdir/lock003.*.out]]
error_check_good "FAIL: error message(s) in log files" $e 0
2001-03-05 01:42:05 +01:00
# Remove log files
for { set i 0 } {$i < $procs} {incr i} {
2002-10-30 12:57:05 +01:00
fileremove -f $testdir/lock003.$i.out
}
}
# Create and destroy flag files to show we have an object locked, and
# verify that the correct files exist or don't exist given that we've
# just read or write locked a file.
proc lock003_create { rw obj } {
source ./include.tcl
set pref $testdir/L3FLAG
set f [open $pref.$rw.[pid].$obj w]
close $f
}
proc lock003_destroy { obj } {
source ./include.tcl
set pref $testdir/L3FLAG
set f [glob -nocomplain $pref.*.[pid].$obj]
error_check_good l3_destroy [llength $f] 1
fileremove $f
}
proc lock003_vrfy { rw obj } {
source ./include.tcl
set pref $testdir/L3FLAG
if { [string compare $rw "write"] == 0 } {
set fs [glob -nocomplain $pref.*.*.$obj]
error_check_good "number of other locks on $obj" [llength $fs] 0
} else {
set fs [glob -nocomplain $pref.write.*.$obj]
error_check_good "number of write locks on $obj" [llength $fs] 0
2001-03-05 01:42:05 +01:00
}
}
2002-10-30 12:57:05 +01:00