deviceid_test.go 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. // Copyright (C) 2014 The Protocol Authors.
  2. package protocol
  3. import "testing"
  4. var formatted = "P56IOI7-MZJNU2Y-IQGDREY-DM2MGTI-MGL3BXN-PQ6W5BM-TBBZ4TJ-XZWICQ2"
  5. var formatCases = []string{
  6. "P56IOI-7MZJNU-2IQGDR-EYDM2M-GTMGL3-BXNPQ6-W5BTBB-Z4TJXZ-WICQ",
  7. "P56IOI-7MZJNU2Y-IQGDR-EYDM2M-GTI-MGL3-BXNPQ6-W5BM-TBB-Z4TJXZ-WICQ2",
  8. "P56IOI7 MZJNU2I QGDREYD M2MGTMGL 3BXNPQ6W 5BTB BZ4T JXZWICQ",
  9. "P56IOI7 MZJNU2Y IQGDREY DM2MGTI MGL3BXN PQ6W5BM TBBZ4TJ XZWICQ2",
  10. "P56IOI7MZJNU2IQGDREYDM2MGTMGL3BXNPQ6W5BTBBZ4TJXZWICQ",
  11. "p56ioi7mzjnu2iqgdreydm2mgtmgl3bxnpq6w5btbbz4tjxzwicq",
  12. "P56IOI7MZJNU2YIQGDREYDM2MGTIMGL3BXNPQ6W5BMTBBZ4TJXZWICQ2",
  13. "P561017MZJNU2YIQGDREYDM2MGTIMGL3BXNPQ6W5BMT88Z4TJXZWICQ2",
  14. "p56ioi7mzjnu2yiqgdreydm2mgtimgl3bxnpq6w5bmtbbz4tjxzwicq2",
  15. "p561017mzjnu2yiqgdreydm2mgtimgl3bxnpq6w5bmt88z4tjxzwicq2",
  16. }
  17. func TestFormatDeviceID(t *testing.T) {
  18. for i, tc := range formatCases {
  19. var id DeviceID
  20. err := id.UnmarshalText([]byte(tc))
  21. if err != nil {
  22. t.Errorf("#%d UnmarshalText(%q); %v", i, tc, err)
  23. } else if f := id.String(); f != formatted {
  24. t.Errorf("#%d FormatDeviceID(%q)\n\t%q !=\n\t%q", i, tc, f, formatted)
  25. }
  26. }
  27. }
  28. var validateCases = []struct {
  29. s string
  30. ok bool
  31. }{
  32. {"", true}, // Empty device ID, all zeroes
  33. {"a", false},
  34. {"P56IOI7-MZJNU2Y-IQGDREY-DM2MGTI-MGL3BXN-PQ6W5BM-TBBZ4TJ-XZWICQ2", true},
  35. {"P56IOI7-MZJNU2-IQGDREY-DM2MGT-MGL3BXN-PQ6W5B-TBBZ4TJ-XZWICQ", true},
  36. {"P56IOI7 MZJNU2I QGDREYD M2MGTMGL 3BXNPQ6W 5BTB BZ4T JXZWICQ", true},
  37. {"P56IOI7MZJNU2IQGDREYDM2MGTMGL3BXNPQ6W5BTBBZ4TJXZWICQ", true},
  38. {"P56IOI7MZJNU2IQGDREYDM2MGTMGL3BXNPQ6W5BTBBZ4TJXZWICQCCCC", false},
  39. {"p56ioi7mzjnu2iqgdreydm2mgtmgl3bxnpq6w5btbbz4tjxzwicq", true},
  40. {"p56ioi7mzjnu2iqgdreydm2mgtmgl3bxnpq6w5btbbz4tjxzwicqCCCC", false},
  41. }
  42. func TestValidateDeviceID(t *testing.T) {
  43. for _, tc := range validateCases {
  44. var id DeviceID
  45. err := id.UnmarshalText([]byte(tc.s))
  46. if (err == nil && !tc.ok) || (err != nil && tc.ok) {
  47. t.Errorf("ValidateDeviceID(%q); %v != %v", tc.s, err, tc.ok)
  48. }
  49. }
  50. }
  51. func TestMarshallingDeviceID(t *testing.T) {
  52. n0 := DeviceID{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 10, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32}
  53. n1 := DeviceID{}
  54. n2 := DeviceID{}
  55. bs, _ := n0.MarshalText()
  56. if err := n1.UnmarshalText(bs); err != nil {
  57. t.Fatal(err)
  58. }
  59. bs, _ = n1.MarshalText()
  60. if err := n2.UnmarshalText(bs); err != nil {
  61. t.Fatal(err)
  62. }
  63. if n2.String() != n0.String() {
  64. t.Errorf("String marshalling error; %q != %q", n2.String(), n0.String())
  65. }
  66. if !n2.Equals(n0) {
  67. t.Error("Equals error")
  68. }
  69. if n2.Compare(n0) != 0 {
  70. t.Error("Compare error")
  71. }
  72. }
  73. func TestShortIDString(t *testing.T) {
  74. id, _ := DeviceIDFromString(formatted)
  75. sid := id.Short().String()
  76. if len(sid) != 7 {
  77. t.Errorf("Wrong length for short ID: got %d, want 7", len(sid))
  78. }
  79. want := formatted[:len(sid)]
  80. if sid != want {
  81. t.Errorf("Wrong short ID: got %q, want %q", sid, want)
  82. }
  83. }
  84. func TestDeviceIDFromBytes(t *testing.T) {
  85. id0, _ := DeviceIDFromString(formatted)
  86. id1, err := DeviceIDFromBytes(id0[:])
  87. if err != nil {
  88. t.Fatal(err)
  89. } else if id1.String() != formatted {
  90. t.Errorf("Wrong device ID, got %q, want %q", id1, formatted)
  91. }
  92. }
  93. func TestNewDeviceIDMarshalling(t *testing.T) {
  94. // The new DeviceID.Unmarshal / DeviceID.MarshalTo serialization should
  95. // be message compatible with how we used to serialize DeviceIDs.
  96. // Create a message with a device ID in old style bytes format
  97. id0, _ := DeviceIDFromString(formatted)
  98. msg0 := TestOldDeviceID{Test: id0[:]}
  99. // Marshal it
  100. bs, err := msg0.Marshal()
  101. if err != nil {
  102. t.Fatal(err)
  103. }
  104. // Unmarshal using the new DeviceID.Unmarshal
  105. var msg1 TestNewDeviceID
  106. if err := msg1.Unmarshal(bs); err != nil {
  107. t.Fatal(err)
  108. }
  109. // Verify it's the same
  110. if msg1.Test != id0 {
  111. t.Error("Mismatch in old -> new direction")
  112. }
  113. // Marshal using the new DeviceID.MarshalTo
  114. bs, err = msg1.Marshal()
  115. if err != nil {
  116. t.Fatal(err)
  117. }
  118. // Create an old style message and attempt unmarshal
  119. var msg2 TestOldDeviceID
  120. if err := msg2.Unmarshal(bs); err != nil {
  121. t.Fatal(err)
  122. }
  123. // Verify it's the same
  124. id1, err := DeviceIDFromBytes(msg2.Test)
  125. if err != nil {
  126. t.Fatal(err)
  127. } else if id1 != id0 {
  128. t.Error("Mismatch in old -> new direction")
  129. }
  130. }
  131. var resStr string
  132. func BenchmarkLuhnify(b *testing.B) {
  133. str := "ABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJAB"
  134. var err error
  135. for i := 0; i < b.N; i++ {
  136. resStr, err = luhnify(str)
  137. if err != nil {
  138. b.Fatal(err)
  139. }
  140. }
  141. }
  142. func BenchmarkUnluhnify(b *testing.B) {
  143. str, _ := luhnify("ABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJAB")
  144. var err error
  145. for i := 0; i < b.N; i++ {
  146. resStr, err = unluhnify(str)
  147. if err != nil {
  148. b.Fatal(err)
  149. }
  150. }
  151. }
  152. func BenchmarkChunkify(b *testing.B) {
  153. str := "ABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJAB"
  154. for i := 0; i < b.N; i++ {
  155. resStr = chunkify(str)
  156. }
  157. }
  158. func BenchmarkUnchunkify(b *testing.B) {
  159. str := chunkify("ABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJAB")
  160. for i := 0; i < b.N; i++ {
  161. resStr = unchunkify(str)
  162. }
  163. }