Commit 85cfd686 authored by gwenn's avatar gwenn

Tests virtual table with an intarray Go impl.

parent e10dbb7e
...@@ -7,21 +7,21 @@ package sqlite_test ...@@ -7,21 +7,21 @@ package sqlite_test
import ( import (
"fmt" "fmt"
. "github.com/gwenn/gosqlite" . "github.com/gwenn/gosqlite"
"strconv"
"testing" "testing"
) )
type testModule struct { type testModule struct {
t *testing.T t *testing.T
intarray []int
} }
type testVTab struct { type testVTab struct {
eof bool intarray []int
} }
type testVTabCursor struct { type testVTabCursor struct {
vTab *testVTab vTab *testVTab
pos int64 index int /* Current cursor position */
} }
func (m testModule) Create(c *Conn, args []string) (VTab, error) { func (m testModule) Create(c *Conn, args []string) (VTab, error) {
...@@ -37,7 +37,7 @@ func (m testModule) Create(c *Conn, args []string) (VTab, error) { ...@@ -37,7 +37,7 @@ func (m testModule) Create(c *Conn, args []string) (VTab, error) {
if err != nil { if err != nil {
return nil, err return nil, err
} }
return &testVTab{}, nil return &testVTab{m.intarray}, nil
} }
func (m testModule) Connect(c *Conn, args []string) (VTab, error) { func (m testModule) Connect(c *Conn, args []string) (VTab, error) {
//println("testVTab.Connect") //println("testVTab.Connect")
...@@ -71,48 +71,54 @@ func (vc *testVTabCursor) Close() error { ...@@ -71,48 +71,54 @@ func (vc *testVTabCursor) Close() error {
} }
func (vc *testVTabCursor) Filter( /*idxNum int, idxStr string, int argc, sqlite3_value **argv*/) error { func (vc *testVTabCursor) Filter( /*idxNum int, idxStr string, int argc, sqlite3_value **argv*/) error {
//fmt.Printf("testVTabCursor.Filter: %v\n", vc) //fmt.Printf("testVTabCursor.Filter: %v\n", vc)
vc.vTab.eof = false vc.index = 0
return vc.Next() return nil
} }
func (vc *testVTabCursor) Next() error { func (vc *testVTabCursor) Next() error {
//fmt.Printf("testVTabCursor.Next: %v\n", vc) //fmt.Printf("testVTabCursor.Next: %v\n", vc)
if vc.vTab.eof { vc.index++
return fmt.Errorf("Next() called after EOF!")
}
if vc.pos == 1 {
vc.vTab.eof = true
}
vc.pos++
return nil return nil
} }
func (vc *testVTabCursor) Eof() bool { func (vc *testVTabCursor) Eof() bool {
//fmt.Printf("testVTabCursor.Eof: %v\n", vc) //fmt.Printf("testVTabCursor.Eof: %v\n", vc)
return vc.vTab.eof return vc.index >= len(vc.vTab.intarray)
} }
func (vc *testVTabCursor) Column(c *Context, col int) error { func (vc *testVTabCursor) Column(c *Context, col int) error {
//fmt.Printf("testVTabCursor.Column(%d): %v\n", col, vc) //fmt.Printf("testVTabCursor.Column(%d): %v\n", col, vc)
if col != 0 { if col != 0 {
return fmt.Errorf("Column index out of bounds: %d", col) return fmt.Errorf("Column index out of bounds: %d", col)
} }
c.ResultText(strconv.FormatInt(vc.pos, 10)) c.ResultInt(vc.vTab.intarray[vc.index])
return nil return nil
} }
func (vc *testVTabCursor) Rowid() (int64, error) { func (vc *testVTabCursor) Rowid() (int64, error) {
//fmt.Printf("testVTabCursor.Rowid: %v\n", vc) //fmt.Printf("testVTabCursor.Rowid: %v\n", vc)
return vc.pos, nil return int64(vc.index), nil
} }
func TestCreateModule(t *testing.T) { func TestCreateModule(t *testing.T) {
db := open(t) db := open(t)
defer db.Close() defer db.Close()
err := db.CreateModule("test", testModule{t}) intarray := []int{1, 2, 3}
err := db.CreateModule("test", testModule{t, intarray})
checkNoError(t, err, "couldn't create module: %s") checkNoError(t, err, "couldn't create module: %s")
err = db.Exec("CREATE VIRTUAL TABLE vtab USING test('1', 2, three)") err = db.Exec("CREATE VIRTUAL TABLE vtab USING test('1', 2, three)")
checkNoError(t, err, "couldn't create virtual table: %s") checkNoError(t, err, "couldn't create virtual table: %s")
var value string
err = db.OneValue("SELECT * from vtab", &value) s, err := db.Prepare("SELECT * from vtab")
checkNoError(t, err, "couldn't select from virtual table: %s")
defer s.Finalize()
var i, value int
err = s.Select(func(s *Stmt) (err error) {
if err = s.Scan(&value); err != nil {
return
}
assertEquals(t, "Expected '%d' but got '%d'", intarray[i], value)
i++
return
})
checkNoError(t, err, "couldn't select from virtual table: %s") checkNoError(t, err, "couldn't select from virtual table: %s")
assertEquals(t, "Expected '%s' but got '%s'", "1", value)
err = db.Exec("DROP TABLE vtab") err = db.Exec("DROP TABLE vtab")
checkNoError(t, err, "couldn't drop virtual table: %s") checkNoError(t, err, "couldn't drop virtual table: %s")
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment