Add --query-timeout and --connection-timeout options (#293)
This commit is contained in:
@@ -21,6 +21,13 @@ import (
|
||||
_ "github.com/scylladb/gocqlx/v3/table"
|
||||
)
|
||||
|
||||
var defaultClusterConfig = gocql.NewCluster()
|
||||
|
||||
var (
|
||||
defaultQueryTimeout = defaultClusterConfig.Timeout
|
||||
defaultConnectionTimeout = defaultClusterConfig.ConnectTimeout
|
||||
)
|
||||
|
||||
var (
|
||||
cmd = flag.NewFlagSet(os.Args[0], flag.ExitOnError)
|
||||
flagCluster = cmd.String("cluster", "127.0.0.1", "a comma-separated list of host:port tuples")
|
||||
@@ -31,6 +38,8 @@ var (
|
||||
flagPassword = cmd.String("password", "", "password for password authentication")
|
||||
flagIgnoreNames = cmd.String("ignore-names", "", "a comma-separated list of table, view or index names to ignore")
|
||||
flagIgnoreIndexes = cmd.Bool("ignore-indexes", false, "don't generate types for indexes")
|
||||
flagQueryTimeout = cmd.Duration("query-timeout", defaultQueryTimeout, "query timeout ( in seconds )")
|
||||
flagConnectionTimeout = cmd.Duration("connection-timeout", defaultConnectionTimeout, "connection timeout ( in seconds )")
|
||||
)
|
||||
|
||||
//go:embed keyspace.tmpl
|
||||
@@ -152,6 +161,12 @@ func createSession() (gocqlx.Session, error) {
|
||||
Password: *flagPassword,
|
||||
}
|
||||
}
|
||||
if *flagQueryTimeout >= 0 {
|
||||
cluster.Timeout = *flagQueryTimeout
|
||||
}
|
||||
if *flagConnectionTimeout >= 0 {
|
||||
cluster.ConnectTimeout = *flagConnectionTimeout
|
||||
}
|
||||
return gocqlx.WrapSession(cluster.CreateSession())
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user