(t *testing.T)
| 67 | } |
| 68 | |
| 69 | func TestWritePingFails(t *testing.T) { |
| 70 | mode.Set(mode.TestDev) |
| 71 | oldPing := ping |
| 72 | // try emulate an write error, mostly this should kill the ReadMessage gorouting first but you'll never know. |
| 73 | ping = func(conn *websocket.Conn) error { |
| 74 | return errors.New("asd") |
| 75 | } |
| 76 | defer func() { |
| 77 | ping = oldPing |
| 78 | }() |
| 79 | |
| 80 | defer leaktest.CheckTimeout(t, 10*time.Second)() |
| 81 | |
| 82 | server, api := bootTestServer(staticUserID()) |
| 83 | defer api.Close() |
| 84 | defer server.Close() |
| 85 | |
| 86 | wsURL := wsURL(server.URL) |
| 87 | user := testClient(t, wsURL) |
| 88 | defer user.conn.Close() |
| 89 | |
| 90 | waitForConnectedClients(api, 1) |
| 91 | |
| 92 | clients := clients(api, 1) |
| 93 | |
| 94 | assert.NotEmpty(t, clients) |
| 95 | |
| 96 | time.Sleep(api.pingPeriod + (50 * time.Millisecond)) // waiting for ping |
| 97 | |
| 98 | api.Notify(1, &model.MessageExternal{Message: "HI"}) |
| 99 | user.expectNoMessage() |
| 100 | } |
| 101 | |
| 102 | func TestPing(t *testing.T) { |
| 103 | mode.Set(mode.TestDev) |
nothing calls this directly
no test coverage detected
searching dependent graphs…