utils_test.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. // Go MySQL Driver - A MySQL-Driver for Go's database/sql package
  2. //
  3. // Copyright 2013 Julien Schmidt. All rights reserved.
  4. // http://www.julienschmidt.com
  5. //
  6. // This Source Code Form is subject to the terms of the Mozilla Public
  7. // License, v. 2.0. If a copy of the MPL was not distributed with this file,
  8. // You can obtain one at http://mozilla.org/MPL/2.0/.
  9. package mysql
  10. import (
  11. "fmt"
  12. "testing"
  13. "time"
  14. )
  15. func TestDSNParser(t *testing.T) {
  16. var testDSNs = []struct {
  17. in string
  18. out string
  19. loc *time.Location
  20. }{
  21. {"username:password@protocol(address)/dbname?param=value", "&{user:username passwd:password net:protocol addr:address dbname:dbname params:map[param:value] loc:%p}", time.UTC},
  22. {"user@unix(/path/to/socket)/dbname?charset=utf8", "&{user:user passwd: net:unix addr:/path/to/socket dbname:dbname params:map[charset:utf8] loc:%p}", time.UTC},
  23. {"user:password@tcp(localhost:5555)/dbname?charset=utf8", "&{user:user passwd:password net:tcp addr:localhost:5555 dbname:dbname params:map[charset:utf8] loc:%p}", time.UTC},
  24. {"user:password@tcp(localhost:5555)/dbname?charset=utf8mb4,utf8", "&{user:user passwd:password net:tcp addr:localhost:5555 dbname:dbname params:map[charset:utf8mb4,utf8] loc:%p}", time.UTC},
  25. {"user:password@/dbname?loc=UTC", "&{user:user passwd:password net:tcp addr:127.0.0.1:3306 dbname:dbname params:map[loc:UTC] loc:%p}", time.UTC},
  26. {"user:p@ss(word)@tcp([de:ad:be:ef::ca:fe]:80)/dbname?loc=Local", "&{user:user passwd:p@ss(word) net:tcp addr:[de:ad:be:ef::ca:fe]:80 dbname:dbname params:map[loc:Local] loc:%p}", time.Local},
  27. {"/dbname", "&{user: passwd: net:tcp addr:127.0.0.1:3306 dbname:dbname params:map[] loc:%p}", time.UTC},
  28. {"/", "&{user: passwd: net:tcp addr:127.0.0.1:3306 dbname: params:map[] loc:%p}", time.UTC},
  29. {"user:p@/ssword@/", "&{user:user passwd:p@/ssword net:tcp addr:127.0.0.1:3306 dbname: params:map[] loc:%p}", time.UTC},
  30. }
  31. var cfg *config
  32. var err error
  33. var res string
  34. for i, tst := range testDSNs {
  35. cfg, err = parseDSN(tst.in)
  36. if err != nil {
  37. t.Error(err.Error())
  38. }
  39. res = fmt.Sprintf("%+v", cfg)
  40. if res != fmt.Sprintf(tst.out, tst.loc) {
  41. t.Errorf("%d. parseDSN(%q) => %q, want %q", i, tst.in, res, fmt.Sprintf(tst.out, tst.loc))
  42. }
  43. }
  44. }
  45. func TestScanNullTime(t *testing.T) {
  46. var scanTests = []struct {
  47. in interface{}
  48. error bool
  49. valid bool
  50. time time.Time
  51. }{
  52. {tDate, false, true, tDate},
  53. {sDate, false, true, tDate},
  54. {[]byte(sDate), false, true, tDate},
  55. {tDateTime, false, true, tDateTime},
  56. {sDateTime, false, true, tDateTime},
  57. {[]byte(sDateTime), false, true, tDateTime},
  58. {tDate0, false, true, tDate0},
  59. {sDate0, false, true, tDate0},
  60. {[]byte(sDate0), false, true, tDate0},
  61. {sDateTime0, false, true, tDate0},
  62. {[]byte(sDateTime0), false, true, tDate0},
  63. {"", true, false, tDate0},
  64. {"1234", true, false, tDate0},
  65. {0, true, false, tDate0},
  66. }
  67. var nt = NullTime{}
  68. var err error
  69. for _, tst := range scanTests {
  70. err = nt.Scan(tst.in)
  71. if (err != nil) != tst.error {
  72. t.Errorf("%v: expected error status %b, got %b", tst.in, tst.error, (err != nil))
  73. }
  74. if nt.Valid != tst.valid {
  75. t.Errorf("%v: expected valid status %b, got %b", tst.in, tst.valid, nt.Valid)
  76. }
  77. if nt.Time != tst.time {
  78. t.Errorf("%v: expected time %v, got %v", tst.in, tst.time, nt.Time)
  79. }
  80. }
  81. }