client.go 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. // Copyright 2015 The Gorilla WebSocket Authors. All rights reserved.
  2. // Use of this source code is governed by a BSD-style
  3. // license that can be found in the LICENSE file.
  4. // +build ignore
  5. package main
  6. import (
  7. "flag"
  8. "log"
  9. "net/url"
  10. "os"
  11. "os/signal"
  12. "time"
  13. "github.com/gorilla/websocket"
  14. )
  15. var addr = flag.String("addr", "localhost:8080", "http service address")
  16. func main() {
  17. flag.Parse()
  18. log.SetFlags(0)
  19. interrupt := make(chan os.Signal, 1)
  20. signal.Notify(interrupt, os.Interrupt)
  21. u := url.URL{Scheme: "ws", Host: *addr, Path: "/echo"}
  22. log.Printf("connecting to %s", u.String())
  23. c, _, err := websocket.DefaultDialer.Dial(u.String(), nil)
  24. if err != nil {
  25. log.Fatal("dial:", err)
  26. }
  27. defer c.Close()
  28. done := make(chan struct{})
  29. go func() {
  30. defer close(done)
  31. for {
  32. _, message, err := c.ReadMessage()
  33. if err != nil {
  34. log.Println("read:", err)
  35. return
  36. }
  37. log.Printf("recv: %s", message)
  38. }
  39. }()
  40. ticker := time.NewTicker(time.Second)
  41. defer ticker.Stop()
  42. for {
  43. select {
  44. case <-done:
  45. return
  46. case t := <-ticker.C:
  47. err := c.WriteMessage(websocket.TextMessage, []byte(t.String()))
  48. if err != nil {
  49. log.Println("write:", err)
  50. return
  51. }
  52. case <-interrupt:
  53. log.Println("interrupt")
  54. // Cleanly close the connection by sending a close message and then
  55. // waiting (with timeout) for the server to close the connection.
  56. err := c.WriteMessage(websocket.CloseMessage, websocket.FormatCloseMessage(websocket.CloseNormalClosure, ""))
  57. if err != nil {
  58. log.Println("write close:", err)
  59. return
  60. }
  61. select {
  62. case <-done:
  63. case <-time.After(time.Second):
  64. }
  65. return
  66. }
  67. }
  68. }