whatcanGOwrong

This commit is contained in:
2024-09-19 21:38:24 -04:00
commit d0ae4d841d
17908 changed files with 4096831 additions and 0 deletions
@@ -0,0 +1,29 @@
# pkger
```go
package main
import (
"errors"
"log"
"github.com/golang-migrate/migrate/v4"
"github.com/markbates/pkger"
_ "github.com/golang-migrate/migrate/v4/database/postgres"
_ "github.com/golang-migrate/migrate/v4/source/pkger"
_ "github.com/lib/pq"
)
func main() {
pkger.Include("/module/path/to/migrations")
m, err := migrate.New("pkger:///module/path/to/migrations", "postgres://postgres@localhost/postgres?sslmode=disable")
if err != nil {
log.Fatalln(err)
}
if err := m.Up(); errors.Is(err, migrate.ErrNoChange) {
log.Println(err)
} else if err != nil {
log.Fatalln(err)
}
}
```
@@ -0,0 +1,83 @@
package pkger
import (
"fmt"
"net/http"
stdurl "net/url"
"github.com/golang-migrate/migrate/v4/source"
"github.com/golang-migrate/migrate/v4/source/httpfs"
"github.com/markbates/pkger"
"github.com/markbates/pkger/pkging"
)
func init() {
source.Register("pkger", &Pkger{})
}
// Pkger is a source.Driver that reads migrations from instances of
// pkging.Pkger.
type Pkger struct {
httpfs.PartialDriver
}
// Open implements source.Driver. The path component of url will be used as the
// relative location of migrations. The returned driver will use the package
// scoped pkger.Open to access migrations. The relative root and any
// migrations must be added to the global pkger.Pkger instance by calling
// pkger.Apply. Refer to Pkger documentation for more information.
func (p *Pkger) Open(url string) (source.Driver, error) {
u, err := stdurl.Parse(url)
if err != nil {
return nil, err
}
// wrap pkger to implement http.FileSystem.
fs := fsFunc(func(name string) (http.File, error) {
f, err := pkger.Open(name)
if err != nil {
return nil, err
}
return f.(http.File), nil
})
if err := p.Init(fs, u.Path); err != nil {
return nil, fmt.Errorf("failed to init driver with relative path %q: %w", u.Path, err)
}
return p, nil
}
// WithInstance returns a source.Driver that is backed by an instance of
// pkging.Pkger. The relative location of migrations is indicated by path. The
// path must exist on the pkging.Pkger instance for the driver to initialize
// successfully.
func WithInstance(instance pkging.Pkger, path string) (source.Driver, error) {
if instance == nil {
return nil, fmt.Errorf("expected instance of pkging.Pkger")
}
// wrap pkger to implement http.FileSystem.
fs := fsFunc(func(name string) (http.File, error) {
f, err := instance.Open(name)
if err != nil {
return nil, err
}
return f.(http.File), nil
})
var p Pkger
if err := p.Init(fs, path); err != nil {
return nil, fmt.Errorf("failed to init driver with relative path %q: %w", path, err)
}
return &p, nil
}
type fsFunc func(name string) (http.File, error)
// Open implements http.FileSystem.
func (f fsFunc) Open(name string) (http.File, error) {
return f(name)
}
@@ -0,0 +1,196 @@
package pkger
import (
"errors"
"os"
"testing"
"github.com/gobuffalo/here"
st "github.com/golang-migrate/migrate/v4/source/testing"
"github.com/markbates/pkger"
"github.com/markbates/pkger/pkging"
"github.com/markbates/pkger/pkging/mem"
)
func Test(t *testing.T) {
t.Run("WithInstance", func(t *testing.T) {
i := testInstance(t)
createPkgerFile(t, i, "/1_foobar.up.sql")
createPkgerFile(t, i, "/1_foobar.down.sql")
createPkgerFile(t, i, "/3_foobar.up.sql")
createPkgerFile(t, i, "/4_foobar.up.sql")
createPkgerFile(t, i, "/4_foobar.down.sql")
createPkgerFile(t, i, "/5_foobar.down.sql")
createPkgerFile(t, i, "/7_foobar.up.sql")
createPkgerFile(t, i, "/7_foobar.down.sql")
d, err := WithInstance(i, "/")
if err != nil {
t.Fatal(err)
}
st.Test(t, d)
})
t.Run("Open", func(t *testing.T) {
i := testInstance(t)
createPkgerFile(t, i, "/1_foobar.up.sql")
createPkgerFile(t, i, "/1_foobar.down.sql")
createPkgerFile(t, i, "/3_foobar.up.sql")
createPkgerFile(t, i, "/4_foobar.up.sql")
createPkgerFile(t, i, "/4_foobar.down.sql")
createPkgerFile(t, i, "/5_foobar.down.sql")
createPkgerFile(t, i, "/7_foobar.up.sql")
createPkgerFile(t, i, "/7_foobar.down.sql")
registerPackageLevelInstance(t, i)
d, err := (&Pkger{}).Open("pkger:///")
if err != nil {
t.Fatal(err)
}
st.Test(t, d)
})
}
func TestWithInstance(t *testing.T) {
t.Run("Subdir", func(t *testing.T) {
i := testInstance(t)
// Make sure the relative root exists so that httpfs.PartialDriver can
// initialize.
createPkgerSubdir(t, i, "/subdir")
_, err := WithInstance(i, "/subdir")
if err != nil {
t.Fatal("")
}
})
t.Run("NilInstance", func(t *testing.T) {
_, err := WithInstance(nil, "")
if err == nil {
t.Fatal(err)
}
})
t.Run("FailInit", func(t *testing.T) {
i := testInstance(t)
_, err := WithInstance(i, "/fail")
if err == nil {
t.Fatal(err)
}
})
t.Run("FailWithoutMigrations", func(t *testing.T) {
i := testInstance(t)
createPkgerSubdir(t, i, "/")
d, err := WithInstance(i, "/")
if err != nil {
t.Fatal(err)
}
if _, err := d.First(); !errors.Is(err, os.ErrNotExist) {
t.Fatal(err)
}
})
}
func TestOpen(t *testing.T) {
t.Run("InvalidURL", func(t *testing.T) {
_, err := (&Pkger{}).Open(":///")
if err == nil {
t.Fatal(err)
}
})
t.Run("Root", func(t *testing.T) {
_, err := (&Pkger{}).Open("pkger:///")
if err != nil {
t.Fatal(err)
}
})
t.Run("FailInit", func(t *testing.T) {
_, err := (&Pkger{}).Open("pkger:///subdir")
if err == nil {
t.Fatal(err)
}
})
i := testInstance(t)
createPkgerSubdir(t, i, "/subdir")
// Note that this registers the instance globally so anything run after
// this will have access to everything container in the registered
// instance.
registerPackageLevelInstance(t, i)
t.Run("Subdir", func(t *testing.T) {
_, err := (&Pkger{}).Open("pkger:///subdir")
if err != nil {
t.Fatal(err)
}
})
}
func TestClose(t *testing.T) {
d, err := (&Pkger{}).Open("pkger:///")
if err != nil {
t.Fatal(err)
}
if err := d.Close(); err != nil {
t.Fatal(err)
}
}
func registerPackageLevelInstance(t *testing.T, pkg pkging.Pkger) {
if err := pkger.Apply(pkg, nil); err != nil {
t.Fatalf("failed to register pkger instance: %v\n", err)
}
}
func testInstance(t *testing.T) pkging.Pkger {
pkg, err := inMemoryPkger()
if err != nil {
t.Fatalf("failed to create an pkging.Pkger instance: %v\n", err)
}
return pkg
}
func createPkgerSubdir(t *testing.T, pkg pkging.Pkger, subdir string) {
if err := pkg.MkdirAll(subdir, os.ModePerm); err != nil {
t.Fatalf("failed to create pkger subdir %q: %v\n", subdir, err)
}
}
func createPkgerFile(t *testing.T, pkg pkging.Pkger, name string) {
_, err := pkg.Create(name)
if err != nil {
t.Fatalf("failed to create pkger file %q: %v\n", name, err)
}
}
func inMemoryPkger() (*mem.Pkger, error) {
info, err := here.New().Current()
if err != nil {
return nil, err
}
pkg, err := mem.New(info)
if err != nil {
return nil, err
}
return pkg, nil
}