mirror of
https://codeberg.org/redict/redict.git
synced 2025-01-22 16:18:28 -05:00
testsuite: fix fd leak, prevent port clashing when using --baseport
when using --baseport to run two tests suite in parallel (different folders), we need to also make sure the port used by the testsuite to communicate with it's workers is unique. otherwise the attept to find a free port connects to the other test suite and messes it. maybe one day we need to attempt to bind, instead of connect when tring to find a free port.
This commit is contained in:
parent
c31055db61
commit
5b44631397
@ -109,6 +109,7 @@ proc ::redis::__dispatch__raw__ {id method argv} {
|
||||
}
|
||||
::redis::redis_write $fd $cmd
|
||||
if {[catch {flush $fd}]} {
|
||||
catch {close $fd}
|
||||
set ::redis::fd($id) {}
|
||||
return -code error "I/O error reading reply"
|
||||
}
|
||||
@ -251,6 +252,7 @@ proc ::redis::redis_read_reply {id fd} {
|
||||
% {redis_read_map $id $fd}
|
||||
default {
|
||||
if {$type eq {}} {
|
||||
catch {close $fd}
|
||||
set ::redis::fd($id) {}
|
||||
return -code error "I/O error reading reply"
|
||||
}
|
||||
|
@ -180,6 +180,10 @@ proc reconnect {args} {
|
||||
set port [dict get $srv "port"]
|
||||
set config [dict get $srv "config"]
|
||||
set client [redis $host $port 0 $::tls]
|
||||
if {[dict exists $srv "client"]} {
|
||||
set old [dict get $srv "client"]
|
||||
$old close
|
||||
}
|
||||
dict set srv "client" $client
|
||||
|
||||
# select the right db when we don't have to authenticate
|
||||
@ -257,7 +261,7 @@ proc test_server_main {} {
|
||||
set tclsh [info nameofexecutable]
|
||||
# Open a listening socket, trying different ports in order to find a
|
||||
# non busy one.
|
||||
set clientport [find_available_port 11111 32]
|
||||
set clientport [find_available_port [expr {$::baseport - 32}] 32]
|
||||
if {!$::quiet} {
|
||||
puts "Starting test server at port $clientport"
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user