2018-12-27 21:49:59 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"gitto.work/shortcut/scsusers"
|
|
|
|
"github.com/jmoiron/sqlx"
|
|
|
|
"flag"
|
|
|
|
"os"
|
|
|
|
"fmt"
|
|
|
|
_ "github.com/mattn/go-sqlite3"
|
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
var email string
|
|
|
|
|
|
|
|
flag.StringVar(&email, "email", "", "Email address to use for registration test")
|
|
|
|
flag.Parse()
|
|
|
|
|
2018-12-27 22:09:23 +00:00
|
|
|
db, err:=sqlx.Open("sqlite3", ":memory:")
|
2018-12-27 21:49:59 +00:00
|
|
|
if err!=nil {
|
|
|
|
fmt.Println("Couldn't open sqlite3 in-memory db:" + err.Error())
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
|
|
|
|
err=db.Ping()
|
|
|
|
if err!=nil {
|
|
|
|
fmt.Println("Couldn't ping sqlite3 in-memory db:" + err.Error())
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
schema:=`CREATE TABLE test_auth (
|
2018-12-27 22:09:23 +00:00
|
|
|
username text NOT NULL ,
|
|
|
|
password text NOT NULL,
|
|
|
|
email text NOT NULL unique,
|
2018-12-27 21:49:59 +00:00
|
|
|
recovery text NOT NULL DEFAULT '',
|
|
|
|
recoverytime timestamp null,
|
2018-12-27 22:09:23 +00:00
|
|
|
registration_date timestamp not null,
|
|
|
|
registration_ip text not null,
|
2018-12-27 21:49:59 +00:00
|
|
|
lastseen timestamp );`
|
|
|
|
_ ,err=db.Exec(schema)
|
|
|
|
if err != nil {
|
|
|
|
fmt.Println("Schema creation failed: " + err.Error())
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
|
|
|
|
scsusers.Init(db, "test", "Example Test", "nobody@nowhere.com")
|
|
|
|
a:=scsusers.UsernameAvailable("testuser")
|
|
|
|
fmt.Printf("Initial test of username available: %v\n", a)
|
|
|
|
a=scsusers.Register("testuser", email, "127.0.0.1")
|
|
|
|
fmt.Printf("Register returned %v\n",a)
|
|
|
|
fmt.Printf("Enter code from email:")
|
|
|
|
var code string
|
|
|
|
fmt.Scan(&code)
|
|
|
|
a=scsusers.Login("testuser", code)
|
|
|
|
fmt.Printf("Login returned %v\n",a)
|
|
|
|
|
|
|
|
|
|
|
|
}
|