62 lines
1.3 KiB
Go
62 lines
1.3 KiB
Go
// Copyright (C) 2017 ScyllaDB
|
|
// Use of this source code is governed by a ALv2-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package gocqlx_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
gocql "github.com/apache/cassandra-gocql-driver/v2"
|
|
|
|
"github.com/scylladb/gocqlx/v3"
|
|
)
|
|
|
|
func BenchmarkCompileNamedQuery(b *testing.B) {
|
|
q := []byte("INSERT INTO cycling.cyclist_name (id, user_uuid, firstname, stars) VALUES (:id, :user_uuid, :firstname, :stars)")
|
|
b.ResetTimer()
|
|
for i := 0; i < b.N; i++ {
|
|
_, _, err := gocqlx.CompileNamedQuery(q)
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
}
|
|
}
|
|
|
|
func BenchmarkQueryxBindStruct(b *testing.B) {
|
|
q := gocqlx.Queryx{
|
|
Names: []string{"name", "age", "first", "last"},
|
|
Mapper: gocqlx.DefaultMapper,
|
|
Query: &gocql.Query{},
|
|
}
|
|
type t struct {
|
|
Name string
|
|
Age int
|
|
First string
|
|
Last string
|
|
}
|
|
am := t{"Jason Moiron", 30, "Jason", "Moiron"}
|
|
b.ResetTimer()
|
|
for i := 0; i < b.N; i++ {
|
|
q.BindStruct(am)
|
|
}
|
|
}
|
|
|
|
func BenchmarkBindMap(b *testing.B) {
|
|
q := gocqlx.Queryx{
|
|
Names: []string{"name", "age", "first", "last"},
|
|
Mapper: gocqlx.DefaultMapper,
|
|
Query: &gocql.Query{},
|
|
}
|
|
am := map[string]interface{}{
|
|
"name": "Jason Moiron",
|
|
"age": 30,
|
|
"first": "Jason",
|
|
"last": "Moiron",
|
|
}
|
|
b.ResetTimer()
|
|
for i := 0; i < b.N; i++ {
|
|
q.BindMap(am)
|
|
}
|
|
}
|