mirror of
https://github.com/MariaDB/server.git
synced 2025-01-27 01:04:19 +01:00
95 lines
2.7 KiB
Tcl
95 lines
2.7 KiB
Tcl
|
# See the file LICENSE for redistribution information.
|
||
|
#
|
||
|
# Copyright (c) 1996-2002
|
||
|
# Sleepycat Software. All rights reserved.
|
||
|
#
|
||
|
# $Id: mutex002.tcl,v 11.23 2002/04/30 19:37:36 sue Exp $
|
||
|
#
|
||
|
|
||
|
# TEST mutex002
|
||
|
# TEST Test basic mutex synchronization
|
||
|
proc mutex002 { } {
|
||
|
source ./include.tcl
|
||
|
|
||
|
puts "Mutex002: Basic synchronization"
|
||
|
env_cleanup $testdir
|
||
|
set nlocks 20
|
||
|
|
||
|
# Fork off child before we open any files.
|
||
|
set f1 [open |$tclsh_path r+]
|
||
|
puts $f1 "source $test_path/test.tcl"
|
||
|
flush $f1
|
||
|
|
||
|
# Open the environment and the mutex locally
|
||
|
puts "\tMutex002.a: Open local and remote env"
|
||
|
set local_env [berkdb_env -create -mode 0644 -lock -home $testdir]
|
||
|
error_check_good env_open [is_valid_env $local_env] TRUE
|
||
|
|
||
|
set local_mutex [$local_env mutex 0644 $nlocks]
|
||
|
error_check_good \
|
||
|
mutex_init [is_valid_mutex $local_mutex $local_env] TRUE
|
||
|
|
||
|
# Open the environment and the mutex remotely
|
||
|
set remote_env [send_cmd $f1 "berkdb_env -lock -home $testdir"]
|
||
|
error_check_good remote:env_open [is_valid_env $remote_env] TRUE
|
||
|
|
||
|
set remote_mutex [send_cmd $f1 "$remote_env mutex 0644 $nlocks"]
|
||
|
error_check_good \
|
||
|
mutex_init [is_valid_mutex $remote_mutex $remote_env] TRUE
|
||
|
|
||
|
# Do a get here, then set the value to be pid.
|
||
|
# On the remote side fire off a get and getval.
|
||
|
puts "\tMutex002.b: Local and remote get/set"
|
||
|
set r [$local_mutex get 1]
|
||
|
error_check_good lock_get $r 0
|
||
|
|
||
|
set r [$local_mutex setval 1 [pid]]
|
||
|
error_check_good lock_get $r 0
|
||
|
|
||
|
# Now have the remote side request the lock and check its
|
||
|
# value. Then wait 5 seconds, release the mutex and see
|
||
|
# what the remote side returned.
|
||
|
send_timed_cmd $f1 1 "$remote_mutex get 1"
|
||
|
send_timed_cmd $f1 1 "set ret \[$remote_mutex getval 1\]"
|
||
|
|
||
|
# Now sleep before resetting and releasing lock
|
||
|
tclsleep 5
|
||
|
set newv [expr [pid] - 1]
|
||
|
set r [$local_mutex setval 1 $newv]
|
||
|
error_check_good mutex_setval $r 0
|
||
|
|
||
|
set r [$local_mutex release 1]
|
||
|
error_check_good mutex_release $r 0
|
||
|
|
||
|
# Now get the result from the other script
|
||
|
# Timestamp
|
||
|
set result [rcv_result $f1]
|
||
|
error_check_good lock_get:remote_time [expr $result > 4] 1
|
||
|
|
||
|
# Timestamp
|
||
|
set result [rcv_result $f1]
|
||
|
|
||
|
# Mutex value
|
||
|
set result [send_cmd $f1 "puts \$ret"]
|
||
|
error_check_good lock_get:remote_getval $result $newv
|
||
|
|
||
|
# Close down the remote
|
||
|
puts "\tMutex002.c: Close remote"
|
||
|
set ret [send_cmd $f1 "$remote_mutex close" 5]
|
||
|
# Not sure why we need this, but we do... an extra blank line
|
||
|
# someone gets output somewhere
|
||
|
gets $f1 ret
|
||
|
error_check_good remote:mutex_close $ret 0
|
||
|
|
||
|
set ret [send_cmd $f1 "$remote_env close"]
|
||
|
error_check_good remote:env_close $ret 0
|
||
|
|
||
|
catch { close $f1 } result
|
||
|
|
||
|
set ret [$local_mutex close]
|
||
|
error_check_good local:mutex_close $ret 0
|
||
|
|
||
|
set ret [$local_env close]
|
||
|
error_check_good local:env_close $ret 0
|
||
|
}
|