benchmark_test.go 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. package mysql
  2. import (
  3. "database/sql"
  4. "strings"
  5. "testing"
  6. )
  7. var (
  8. // dsn from driver_test.go
  9. sample = []byte(strings.Repeat("0123456789abcdef", 1024*1024))
  10. min, max = 16, len(sample)
  11. )
  12. func BenchmarkRoundtripText(b *testing.B) {
  13. db, err := sql.Open("mysql", dsn)
  14. if err != nil {
  15. b.Fatalf("crashed")
  16. }
  17. defer db.Close()
  18. var result string
  19. for i := 0; i < b.N; i++ {
  20. length := min + i
  21. if length > max {
  22. length = max
  23. }
  24. test := string(sample[0:length])
  25. rows, err := db.Query("SELECT \"" + test + "\"")
  26. if err != nil {
  27. b.Fatalf("crashed")
  28. }
  29. if !rows.Next() {
  30. rows.Close()
  31. b.Fatalf("crashed")
  32. }
  33. err = rows.Scan(&result)
  34. if err != nil {
  35. rows.Close()
  36. b.Fatalf("crashed")
  37. }
  38. if result != test {
  39. rows.Close()
  40. b.Errorf("mismatch")
  41. }
  42. rows.Close()
  43. }
  44. }
  45. func BenchmarkRoundtripPrepared(b *testing.B) {
  46. db, err := sql.Open("mysql", dsn)
  47. if err != nil {
  48. b.Fatalf("crashed")
  49. }
  50. defer db.Close()
  51. var result string
  52. stmt, err := db.Prepare("SELECT ?")
  53. if err != nil {
  54. b.Fatalf("crashed")
  55. }
  56. for i := 0; i < b.N; i++ {
  57. length := min + i
  58. if length > max {
  59. length = max
  60. }
  61. test := string(sample[0:length])
  62. rows, err := stmt.Query(test)
  63. if err != nil {
  64. b.Fatalf("crashed")
  65. }
  66. if !rows.Next() {
  67. rows.Close()
  68. b.Fatalf("crashed")
  69. }
  70. err = rows.Scan(&result)
  71. if err != nil {
  72. rows.Close()
  73. b.Fatalf("crashed")
  74. }
  75. if result != test {
  76. rows.Close()
  77. b.Errorf("mismatch")
  78. }
  79. rows.Close()
  80. }
  81. }