gecko-dev/db/test/lockscript.tcl

90 строки
2.2 KiB
Tcl

# See the file LICENSE for redistribution information.
#
# Copyright (c) 1996, 1997, 1998
# Sleepycat Software. All rights reserved.
#
# @(#)lockscript.tcl 10.2 (Sleepycat) 4/10/98
#
# Random lock tester.
# Usage: lockscript dir numiters numobjs sleepint degree readratio seed
# dir: lock directory.
# numiters: Total number of iterations.
# numobjs: Number of objects on which to lock.
# sleepint: Maximum sleep interval.
# degree: Maximum number of locks to acquire at once
# readratio: Percent of locks that should be reads.
# seed: Seed for random number generator. If -1, use pid.
source ../test/testutils.tcl
source ./include.tcl
set usage "lockscript dir numiters numobjs sleepint degree readratio seed"
# Verify usage
if { $argc != 7 } {
puts stderr $usage
exit
}
# Initialize arguments
set dir [lindex $argv 0]
set numiters [ lindex $argv 1 ]
set numobjs [ lindex $argv 2 ]
set sleepint [ lindex $argv 3 ]
set degree [ lindex $argv 4 ]
set readratio [ lindex $argv 5 ]
set seed [ lindex $argv 6 ]
set locker [pid]
# Initialize seed
if { $seed == -1 } {
srand $locker
} else {
srand $seed
}
puts -nonewline "Beginning execution for $locker: $numiters $numobjs "
puts "$sleepint $degree $readratio $seed"
flush stdout
set lp [lock_open "" 0 0 -dbhome $dir]
error_check_bad lock_open $lp NULL
error_check_good lock_open [is_substr $lp lockmgr] 1
for { set iter 0 } { $iter < $numiters } { incr iter } {
set nlocks [random_int 1 $degree]
# We will always lock objects in ascending order to avoid
# deadlocks.
set lastobj 1
set locklist {}
for { set lnum 0 } { $lnum < $nlocks } { incr lnum } {
# Pick lock parameters
set obj [random_int $lastobj $numobjs]
set lastobj [expr $obj + 1]
set x [random_int 1 100 ]
if { $x <= $readratio } {
set rw $DB_LOCK_READ
} else {
set rw $DB_LOCK_WRITE
}
puts "[timestamp] $locker $lnum: $rw $obj"
# Do get; add to list
set lockp [$lp get $locker $obj $rw 0]
lappend locklist $lockp
if {$lastobj > $numobjs} {
break
}
}
# Pick sleep interval
exec $SLEEP [ random_int 1 $sleepint ]
# Now release locks
puts "[timestamp] $locker released locks"
release_list $locklist
flush stdout
}
puts "[timestamp] $locker Complete"
flush stdout