Commit d811f6b0 authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

packer/rpc: allow data to be sent even in FinWait [GH-705]

parent 63f957cf
...@@ -339,13 +339,18 @@ func (m *MuxConn) loop() { ...@@ -339,13 +339,18 @@ func (m *MuxConn) loop() {
case muxPacketData: case muxPacketData:
stream.mu.Lock() stream.mu.Lock()
if stream.state == streamStateEstablished { switch stream.state {
case streamStateFinWait1:
fallthrough
case streamStateFinWait2:
fallthrough
case streamStateEstablished:
select { select {
case stream.writeCh <- data: case stream.writeCh <- data:
default: default:
panic(fmt.Sprintf("Failed to write data, buffer full for stream %d", id)) panic(fmt.Sprintf("Failed to write data, buffer full for stream %d", id))
} }
} else { default:
log.Printf("[ERR] Data received for stream in state: %d", stream.state) log.Printf("[ERR] Data received for stream in state: %d", stream.state)
} }
stream.mu.Unlock() stream.mu.Unlock()
......
...@@ -114,6 +114,51 @@ func TestMuxConn(t *testing.T) { ...@@ -114,6 +114,51 @@ func TestMuxConn(t *testing.T) {
<-doneCh <-doneCh
} }
// This tests that even when the client end is closed, data can be
// read from the server.
func TestMuxConn_clientCloseRead(t *testing.T) {
client, server := testMux(t)
defer client.Close()
defer server.Close()
// This channel will be closed when we close
waitCh := make(chan struct{})
go func() {
conn, err := server.Accept(0)
if err != nil {
t.Fatalf("err: %s", err)
}
<-waitCh
_, err = conn.Write([]byte("foo"))
if err != nil {
t.Fatalf("err: %s", err)
}
conn.Close()
}()
s0, err := client.Dial(0)
if err != nil {
t.Fatalf("err: %s", err)
}
if err := s0.Close(); err != nil {
t.Fatalf("bad: %s", err)
}
// Close this to continue on on the server-side
close(waitCh)
var data [1024]byte
n, err := s0.Read(data[:])
if string(data[:n]) != "foo" {
t.Fatalf("bad: %#v", string(data[:n]))
}
}
func TestMuxConn_socketClose(t *testing.T) { func TestMuxConn_socketClose(t *testing.T) {
client, server := testMux(t) client, server := testMux(t)
defer client.Close() defer client.Close()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment