memcache_test.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. /*
  2. Copyright 2011 Google Inc.
  3. Licensed under the Apache License, Version 2.0 (the "License");
  4. you may not use this file except in compliance with the License.
  5. You may obtain a copy of the License at
  6. http://www.apache.org/licenses/LICENSE-2.0
  7. Unless required by applicable law or agreed to in writing, software
  8. distributed under the License is distributed on an "AS IS" BASIS,
  9. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. See the License for the specific language governing permissions and
  11. limitations under the License.
  12. */
  13. // Package memcache provides a client for the memcached cache server.
  14. package memcache
  15. import (
  16. "net"
  17. "os"
  18. "strings"
  19. "testing"
  20. )
  21. const testServer = "localhost:11211"
  22. func setup(t *testing.T) bool {
  23. c, err := net.Dial("tcp", testServer)
  24. if err != nil {
  25. t.Logf("skipping test; no server running at %s", testServer)
  26. return false
  27. }
  28. c.Write([]byte("flush_all\r\n"))
  29. c.Close()
  30. return true
  31. }
  32. func TestMemcache(t *testing.T) {
  33. if !setup(t) {
  34. return
  35. }
  36. checkErr := func(err os.Error, format string, args ...interface{}) {
  37. if err != nil {
  38. t.Fatalf(format, args...)
  39. }
  40. }
  41. c := New(testServer)
  42. mustSet := func(it *Item) {
  43. if err := c.Set(it); err != nil {
  44. t.Fatalf("failed to Set %#v: %v", *it, err)
  45. }
  46. }
  47. // Set
  48. foo := &Item{Key: "foo", Value: []byte("fooval"), Flags: 123}
  49. err := c.Set(foo)
  50. checkErr(err, "first set(foo): %v", err)
  51. err = c.Set(foo)
  52. checkErr(err, "second set(foo): %v", err)
  53. // Get
  54. it, err := c.Get("foo")
  55. checkErr(err, "get(foo): %v", err)
  56. if it.Key != "foo" {
  57. t.Errorf("get(foo) Key = %q, want foo", it.Key)
  58. }
  59. if string(it.Value) != "fooval" {
  60. t.Errorf("get(foo) Value = %q, want fooval", string(it.Value))
  61. }
  62. if it.Flags != 123 {
  63. t.Errorf("get(foo) Flags = %v, want 123", it.Flags)
  64. }
  65. // Add
  66. bar := &Item{Key: "bar", Value: []byte("barval")}
  67. err = c.Add(bar)
  68. checkErr(err, "first add(foo): %v", err)
  69. if err := c.Add(bar); err != ErrNotStored {
  70. t.Fatalf("second add(foo) want ErrNotStored, got %v", err)
  71. }
  72. // GetMulti
  73. m, err := c.GetMulti([]string{"foo", "bar"})
  74. checkErr(err, "GetMulti: %v", err)
  75. if g, e := len(m), 2; g != e {
  76. t.Errorf("GetMulti: got len(map) = %d, want = %d", g, e)
  77. }
  78. if _, ok := m["foo"]; !ok {
  79. t.Fatalf("GetMulti: didn't get key 'foo'")
  80. }
  81. if _, ok := m["bar"]; !ok {
  82. t.Fatalf("GetMulti: didn't get key 'bar'")
  83. }
  84. if g, e := string(m["foo"].Value), "fooval"; g != e {
  85. t.Errorf("GetMulti: foo: got %q, want %q", g, e)
  86. }
  87. if g, e := string(m["bar"].Value), "barval"; g != e {
  88. t.Errorf("GetMulti: bar: got %q, want %q", g, e)
  89. }
  90. // Delete
  91. err = c.Delete("foo")
  92. checkErr(err, "Delete: %v", err)
  93. it, err = c.Get("foo")
  94. if err != ErrCacheMiss {
  95. t.Errorf("post-Delete want ErrCacheMiss, got %v", err)
  96. }
  97. // Incr/Decr
  98. mustSet(&Item{Key: "num", Value: []byte("42")})
  99. n, err := c.Increment("num", 8)
  100. checkErr(err, "Increment num + 8: %v", err)
  101. if n != 50 {
  102. t.Fatalf("Increment num + 8: want=50, got=%d", n)
  103. }
  104. n, err = c.Decrement("num", 49)
  105. checkErr(err, "Decrement: %v", err)
  106. if n != 1 {
  107. t.Fatalf("Decrement 49: want=1, got=%d", n)
  108. }
  109. err = c.Delete("num")
  110. checkErr(err, "delete num: %v", err)
  111. n, err = c.Increment("num", 1)
  112. if err != ErrCacheMiss {
  113. t.Fatalf("increment post-delete: want ErrCacheMiss, got %v", err)
  114. }
  115. mustSet(&Item{Key: "num", Value: []byte("not-numeric")})
  116. n, err = c.Increment("num", 1)
  117. if err == nil || !strings.Contains(err.String(), "client error") {
  118. t.Fatalf("increment non-number: want client error, got %v", err)
  119. }
  120. }