github.com/bishtawi/migrate/v4@v4.8.11/database/sqlite3/sqlite3_test.go (about)

     1  package sqlite3
     2  
     3  import (
     4  	"database/sql"
     5  	"fmt"
     6  	"io/ioutil"
     7  	"os"
     8  	"path/filepath"
     9  	"testing"
    10  
    11  	"github.com/bishtawi/migrate/v4"
    12  	dt "github.com/bishtawi/migrate/v4/database/testing"
    13  	_ "github.com/bishtawi/migrate/v4/source/file"
    14  	_ "github.com/mattn/go-sqlite3"
    15  )
    16  
    17  func Test(t *testing.T) {
    18  	dir, err := ioutil.TempDir("", "sqlite3-driver-test")
    19  	if err != nil {
    20  		return
    21  	}
    22  	defer func() {
    23  		if err := os.RemoveAll(dir); err != nil {
    24  			t.Error(err)
    25  		}
    26  	}()
    27  	t.Logf("DB path : %s\n", filepath.Join(dir, "sqlite3.db"))
    28  	p := &Sqlite{}
    29  	addr := fmt.Sprintf("sqlite3://%s", filepath.Join(dir, "sqlite3.db"))
    30  	d, err := p.Open(addr)
    31  	if err != nil {
    32  		t.Fatal(err)
    33  	}
    34  	dt.Test(t, d, []byte("CREATE TABLE t (Qty int, Name string);"))
    35  }
    36  
    37  func TestMigrate(t *testing.T) {
    38  	dir, err := ioutil.TempDir("", "sqlite3-driver-test")
    39  	if err != nil {
    40  		return
    41  	}
    42  	defer func() {
    43  		if err := os.RemoveAll(dir); err != nil {
    44  			t.Error(err)
    45  		}
    46  	}()
    47  	t.Logf("DB path : %s\n", filepath.Join(dir, "sqlite3.db"))
    48  
    49  	db, err := sql.Open("sqlite3", filepath.Join(dir, "sqlite3.db"))
    50  	if err != nil {
    51  		return
    52  	}
    53  	defer func() {
    54  		if err := db.Close(); err != nil {
    55  			return
    56  		}
    57  	}()
    58  	driver, err := WithInstance(db, &Config{})
    59  	if err != nil {
    60  		t.Fatal(err)
    61  	}
    62  
    63  	m, err := migrate.NewWithDatabaseInstance(
    64  		"file://./examples/migrations",
    65  		"ql", driver)
    66  	if err != nil {
    67  		t.Fatal(err)
    68  	}
    69  	dt.TestMigrate(t, m)
    70  }
    71  
    72  func TestMigrationTable(t *testing.T) {
    73  	dir, err := ioutil.TempDir("", "sqlite3-driver-test-migration-table")
    74  	if err != nil {
    75  		return
    76  	}
    77  	defer func() {
    78  		if err := os.RemoveAll(dir); err != nil {
    79  			t.Error(err)
    80  		}
    81  	}()
    82  
    83  	t.Logf("DB path : %s\n", filepath.Join(dir, "sqlite3.db"))
    84  
    85  	db, err := sql.Open("sqlite3", filepath.Join(dir, "sqlite3.db"))
    86  	if err != nil {
    87  		return
    88  	}
    89  	defer func() {
    90  		if err := db.Close(); err != nil {
    91  			return
    92  		}
    93  	}()
    94  
    95  	config := &Config{
    96  		MigrationsTable: "my_migration_table",
    97  	}
    98  	driver, err := WithInstance(db, config)
    99  	if err != nil {
   100  		t.Fatal(err)
   101  	}
   102  	m, err := migrate.NewWithDatabaseInstance(
   103  		"file://./examples/migrations",
   104  		"ql", driver)
   105  	if err != nil {
   106  		t.Fatal(err)
   107  	}
   108  	t.Log("UP")
   109  	err = m.Up()
   110  	if err != nil {
   111  		t.Fatal(err)
   112  	}
   113  
   114  	_, err = db.Query(fmt.Sprintf("SELECT * FROM %s", config.MigrationsTable))
   115  	if err != nil {
   116  		t.Fatal(err)
   117  	}
   118  }