whatcanGOwrong
This commit is contained in:
@@ -0,0 +1,50 @@
|
||||
//go:build go1.10
|
||||
// +build go1.10
|
||||
|
||||
package pq
|
||||
|
||||
import (
|
||||
"database/sql"
|
||||
"database/sql/driver"
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestConnectorWithNoticeHandler_Simple(t *testing.T) {
|
||||
b, err := NewConnector("")
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
var notice *Error
|
||||
// Make connector w/ handler to set the local var
|
||||
c := ConnectorWithNoticeHandler(b, func(n *Error) { notice = n })
|
||||
raiseNotice(c, t, "Test notice #1")
|
||||
if notice == nil || notice.Message != "Test notice #1" {
|
||||
t.Fatalf("Expected notice w/ message, got %v", notice)
|
||||
}
|
||||
// Unset the handler on the same connector
|
||||
prevC := c
|
||||
if c = ConnectorWithNoticeHandler(c, nil); c != prevC {
|
||||
t.Fatalf("Expected to not create new connector but did")
|
||||
}
|
||||
raiseNotice(c, t, "Test notice #2")
|
||||
if notice == nil || notice.Message != "Test notice #1" {
|
||||
t.Fatalf("Expected notice to not change, got %v", notice)
|
||||
}
|
||||
// Set it back on the same connector
|
||||
if c = ConnectorWithNoticeHandler(c, func(n *Error) { notice = n }); c != prevC {
|
||||
t.Fatal("Expected to not create new connector but did")
|
||||
}
|
||||
raiseNotice(c, t, "Test notice #3")
|
||||
if notice == nil || notice.Message != "Test notice #3" {
|
||||
t.Fatalf("Expected notice w/ message, got %v", notice)
|
||||
}
|
||||
}
|
||||
|
||||
func raiseNotice(c driver.Connector, t *testing.T, escapedNotice string) {
|
||||
db := sql.OpenDB(c)
|
||||
defer db.Close()
|
||||
sql := "DO language plpgsql $$ BEGIN RAISE NOTICE '" + escapedNotice + "'; END $$"
|
||||
if _, err := db.Exec(sql); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user