forked from JamesStewy/go-mysqldump
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathpostgres_test.go
42 lines (35 loc) · 916 Bytes
/
postgres_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
package sqldump_test
import (
"database/sql"
"os"
"path/filepath"
"testing"
"github.com/grimdork/sqldump"
_ "github.com/lib/pq"
)
const pgtest = "pg-test"
func TestPostgres(t *testing.T) {
// Open connection to database
db, err := sql.Open("postgres", "host=localhost port=5432 dbname=orb user=orb password=admin sslmode=disable")
if err != nil {
t.Errorf("Error opening databse: %s\n", err.Error())
t.FailNow()
}
// Register database with mysqldump
os.Remove(filepath.Join(os.TempDir(), pgtest))
dumper, err := sqldump.NewDumper(db, os.TempDir(), pgtest)
dumper.SetMaxRows(1)
if err != nil {
t.Errorf("Error registering databse: %s\n", err.Error())
t.FailNow()
}
// Dump database to file
t.Logf("Dumping to %s", dumper.Path())
err = dumper.Dump()
if err != nil {
t.Errorf("Error dumping: %s\n", err.Error())
return
}
// Close dumper and connected database
dumper.Close()
}