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. // keep consistent with ShortIDStringLength in lib/protocol/deviceid.go
  77. if len(sid) != 7 {
  78. t.Errorf("Wrong length for short ID: got %d, want 7", len(sid))
  79. }
  80. want := formatted[:len(sid)]
  81. if sid != want {
  82. t.Errorf("Wrong short ID: got %q, want %q", sid, want)
  83. }
  84. }
  85. func TestDeviceIDFromBytes(t *testing.T) {
  86. id0, _ := DeviceIDFromString(formatted)
  87. id1, err := DeviceIDFromBytes(id0[:])
  88. if err != nil {
  89. t.Fatal(err)
  90. } else if id1.String() != formatted {
  91. t.Errorf("Wrong device ID, got %q, want %q", id1, formatted)
  92. }
  93. }
  94. func TestNewDeviceIDMarshalling(t *testing.T) {
  95. // The new DeviceID.Unmarshal / DeviceID.MarshalTo serialization should
  96. // be message compatible with how we used to serialize DeviceIDs.
  97. // Create a message with a device ID in old style bytes format
  98. id0, _ := DeviceIDFromString(formatted)
  99. msg0 := TestOldDeviceID{Test: id0[:]}
  100. // Marshal it
  101. bs, err := msg0.Marshal()
  102. if err != nil {
  103. t.Fatal(err)
  104. }
  105. // Unmarshal using the new DeviceID.Unmarshal
  106. var msg1 TestNewDeviceID
  107. if err := msg1.Unmarshal(bs); err != nil {
  108. t.Fatal(err)
  109. }
  110. // Verify it's the same
  111. if msg1.Test != id0 {
  112. t.Error("Mismatch in old -> new direction")
  113. }
  114. // Marshal using the new DeviceID.MarshalTo
  115. bs, err = msg1.Marshal()
  116. if err != nil {
  117. t.Fatal(err)
  118. }
  119. // Create an old style message and attempt unmarshal
  120. var msg2 TestOldDeviceID
  121. if err := msg2.Unmarshal(bs); err != nil {
  122. t.Fatal(err)
  123. }
  124. // Verify it's the same
  125. id1, err := DeviceIDFromBytes(msg2.Test)
  126. if err != nil {
  127. t.Fatal(err)
  128. } else if id1 != id0 {
  129. t.Error("Mismatch in old -> new direction")
  130. }
  131. }
  132. var resStr string
  133. func BenchmarkLuhnify(b *testing.B) {
  134. str := "ABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJAB"
  135. var err error
  136. for i := 0; i < b.N; i++ {
  137. resStr, err = luhnify(str)
  138. if err != nil {
  139. b.Fatal(err)
  140. }
  141. }
  142. }
  143. func BenchmarkUnluhnify(b *testing.B) {
  144. str, _ := luhnify("ABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJAB")
  145. var err error
  146. for i := 0; i < b.N; i++ {
  147. resStr, err = unluhnify(str)
  148. if err != nil {
  149. b.Fatal(err)
  150. }
  151. }
  152. }
  153. func BenchmarkChunkify(b *testing.B) {
  154. str := "ABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJAB"
  155. for i := 0; i < b.N; i++ {
  156. resStr = chunkify(str)
  157. }
  158. }
  159. func BenchmarkUnchunkify(b *testing.B) {
  160. str := chunkify("ABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJAB")
  161. for i := 0; i < b.N; i++ {
  162. resStr = unchunkify(str)
  163. }
  164. }