benchmark_test.go 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  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. )
  11. func BenchmarkRoundtripText(b *testing.B) {
  12. db, err := sql.Open("mysql", dsn)
  13. if err != nil {
  14. b.Fatalf("crashed")
  15. }
  16. var result string
  17. for i := 0; i < b.N; i++ {
  18. length := 16 + i%(4*b.N)
  19. test := string(sample[0:length])
  20. rows, err := db.Query("SELECT \"" + test + "\"")
  21. if err != nil {
  22. b.Fatalf("crashed")
  23. }
  24. if !rows.Next() {
  25. rows.Close()
  26. b.Fatalf("crashed")
  27. }
  28. err = rows.Scan(&result)
  29. if err != nil {
  30. rows.Close()
  31. b.Fatalf("crashed")
  32. }
  33. if result != test {
  34. rows.Close()
  35. b.Errorf("mismatch")
  36. }
  37. rows.Close()
  38. }
  39. }
  40. func BenchmarkRoundtripPrepared(b *testing.B) {
  41. db, err := sql.Open("mysql", dsn)
  42. if err != nil {
  43. b.Fatalf("crashed")
  44. }
  45. var result string
  46. stmt, err := db.Prepare("SELECT ?")
  47. if err != nil {
  48. b.Fatalf("crashed")
  49. }
  50. for i := 0; i < b.N; i++ {
  51. length := 16 + i%(4*b.N)
  52. test := string(sample[0:length])
  53. rows, err := stmt.Query(test)
  54. if err != nil {
  55. b.Fatalf("crashed")
  56. }
  57. if !rows.Next() {
  58. rows.Close()
  59. b.Fatalf("crashed")
  60. }
  61. err = rows.Scan(&result)
  62. if err != nil {
  63. rows.Close()
  64. b.Fatalf("crashed")
  65. }
  66. if result != test {
  67. rows.Close()
  68. b.Errorf("mismatch")
  69. }
  70. rows.Close()
  71. }
  72. }