Fix WebSocket close

pull/51/head
178inaba 2017-04-30 22:14:02 +09:00
parent 70b3dbf548
commit fc574ac209
2 changed files with 14 additions and 3 deletions

View File

@ -66,6 +66,7 @@ func (c *WSClient) streamingWS(ctx context.Context, stream, tag string) (chan Ev
q := make(chan Event) q := make(chan Event)
go func() { go func() {
defer close(q)
for { for {
err := c.handleWS(ctx, u.String(), q) err := c.handleWS(ctx, u.String(), q)
if err != nil { if err != nil {
@ -85,7 +86,12 @@ func (c *WSClient) handleWS(ctx context.Context, rawurl string, q chan Event) er
// End. // End.
return err return err
} }
defer conn.Close()
// Close the WebSocket when the context is canceled.
go func() {
<-ctx.Done()
conn.Close()
}()
for { for {
select { select {

View File

@ -106,13 +106,12 @@ func wsMock(w http.ResponseWriter, r *http.Request) {
func wsTest(t *testing.T, q chan Event, cancel func()) { func wsTest(t *testing.T, q chan Event, cancel func()) {
time.AfterFunc(time.Second, func() { time.AfterFunc(time.Second, func() {
cancel() cancel()
close(q)
}) })
events := []Event{} events := []Event{}
for e := range q { for e := range q {
events = append(events, e) events = append(events, e)
} }
if len(events) != 4 { if len(events) != 6 {
t.Fatalf("result should be four: %d", len(events)) t.Fatalf("result should be four: %d", len(events))
} }
if events[0].(*UpdateEvent).Status.Content != "foo" { if events[0].(*UpdateEvent).Status.Content != "foo" {
@ -127,6 +126,12 @@ func wsTest(t *testing.T, q chan Event, cancel func()) {
if errorEvent, ok := events[3].(*ErrorEvent); !ok { if errorEvent, ok := events[3].(*ErrorEvent); !ok {
t.Fatalf("should be fail: %v", errorEvent.err) t.Fatalf("should be fail: %v", errorEvent.err)
} }
if errorEvent, ok := events[4].(*ErrorEvent); !ok {
t.Fatalf("should be fail: %v", errorEvent.err)
}
if errorEvent, ok := events[5].(*ErrorEvent); !ok {
t.Fatalf("should be fail: %v", errorEvent.err)
}
} }
func TestStreamingWS(t *testing.T) { func TestStreamingWS(t *testing.T) {