Skip to content

Commit

Permalink
close: Implement CloseNow
Browse files Browse the repository at this point in the history
Closes #384
  • Loading branch information
nhooyr committed Oct 14, 2023
1 parent 1dbc141 commit 3500fce
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 1 deletion.
11 changes: 10 additions & 1 deletion close.go
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,15 @@ func (c *Conn) Close(code StatusCode, reason string) error {
return c.closeHandshake(code, reason)
}

// CloseNow closes the WebSocket connection without attempting a close handshake.
// Use When you do not want the overhead of the close handshake.
func (c *Conn) CloseNow() (err error) {
defer errd.Wrap(&err, "failed to close WebSocket")

c.close(nil)
return c.closeErr
}

func (c *Conn) closeHandshake(code StatusCode, reason string) (err error) {
defer errd.Wrap(&err, "failed to close WebSocket")

Expand Down Expand Up @@ -265,7 +274,7 @@ func (c *Conn) setCloseErr(err error) {
}

func (c *Conn) setCloseErrLocked(err error) {
if c.closeErr == nil {
if c.closeErr == nil && err != nil {
c.closeErr = fmt.Errorf("WebSocket closed: %w", err)
}
}
Expand Down
3 changes: 3 additions & 0 deletions conn.go
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,9 @@ func (c *Conn) close(err error) {
if c.isClosed() {
return
}
if err == nil {
err = c.rwc.Close()
}
c.setCloseErrLocked(err)
close(c.closed)
runtime.SetFinalizer(c, nil)
Expand Down
9 changes: 9 additions & 0 deletions conn_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -295,6 +295,15 @@ func TestConn(t *testing.T) {
err = c1.Close(websocket.StatusNormalClosure, "")
assert.Success(t, err)
})

t.Run("CloseNow", func(t *testing.T) {
_, c1, c2 := newConnTest(t, nil, nil)

err1 := c1.CloseNow()
err2 := c2.CloseNow()
assert.Success(t, err1)
assert.Success(t, err2)
})
}

func TestWasm(t *testing.T) {
Expand Down

0 comments on commit 3500fce

Please sign in to comment.