73 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package test
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/DATA-DOG/go-sqlmock"
 | |
| )
 | |
| 
 | |
| func Test_SQLFromFile(t *testing.T) {
 | |
| 	ctx := context.TODO()
 | |
| 	db, c, err := sqlmock.New()
 | |
| 	if err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 	defer db.Close()
 | |
| 
 | |
| 	if err = SQLFromFile(c, "testdata/result/01_firstcase/Call_db.csv"); err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 
 | |
| 	tx, err := db.BeginTx(ctx, nil)
 | |
| 	if err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 
 | |
| 	rows, err := tx.QueryContext(ctx, "select * from test;")
 | |
| 	if err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 	for rows.Next() {
 | |
| 		var id int64
 | |
| 		var name string
 | |
| 		err = rows.Scan(&id, &name)
 | |
| 		if err != nil {
 | |
| 			t.Fatal(err)
 | |
| 		}
 | |
| 		if id != 1 || name != "test" {
 | |
| 			t.Fatalf("invalid rows %v %v", id, name)
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if err = rows.Close(); err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 
 | |
| 	if err = rows.Err(); err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 
 | |
| 	if err = tx.Commit(); err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 	if err = c.ExpectationsWereMet(); err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func Test_GetCases(t *testing.T) {
 | |
| 	files, err := GetCases("testdata/", nil)
 | |
| 	if err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 
 | |
| 	if len(files) == 0 {
 | |
| 		t.Fatalf("no files matching")
 | |
| 	}
 | |
| 
 | |
| 	if n := len(files); n != 1 {
 | |
| 		t.Fatalf("invalid number of test cases %d", n)
 | |
| 	}
 | |
| }
 |