Fix old stale tests junk

master
Bel LaPointe 2020-07-23 21:13:58 -06:00
parent d572cb5c87
commit d650db5206
7 changed files with 57 additions and 297 deletions

View File

@ -3,6 +3,7 @@ package storage
import ( import (
"context" "context"
"fmt" "fmt"
"io/ioutil"
"local/dndex/storage/entity" "local/dndex/storage/entity"
"local/dndex/storage/operator" "local/dndex/storage/operator"
"os" "os"
@ -13,12 +14,14 @@ import (
) )
func TestIntegration(t *testing.T) { func TestIntegration(t *testing.T) {
if len(os.Getenv("INTEGRATION")) == 0 {
t.Logf("skipping because $INTEGRATION unset")
return
}
os.Args = os.Args[:1] os.Args = os.Args[:1]
f, err := ioutil.TempFile(os.TempDir(), "pattern*")
if err != nil {
t.Fatal(err)
}
f.Close()
defer os.Remove(f.Name())
os.Setenv("DBURI", f.Name())
graph := NewGraph() graph := NewGraph()
ctx, can := context.WithCancel(context.TODO()) ctx, can := context.WithCancel(context.TODO())
defer can() defer can()

View File

@ -1,49 +0,0 @@
package view
import (
"fmt"
"io/ioutil"
"local/dndex/storage"
"local/dndex/storage/entity"
"local/dndex/storage/operator"
"net/http"
"path"
"github.com/buger/jsonparser"
)
func httpisnow(g storage.Graph, w http.ResponseWriter, r *http.Request) error {
namespace := path.Base(r.URL.Path)
b, err := ioutil.ReadAll(r.Body)
if err != nil {
return err
}
name, err := jsonparser.GetString(b, entity.JSONName)
if err != nil {
return fmt.Errorf("cannot find %q: %v", entity.JSONName, err)
}
if name == "" {
http.Error(w, `{"error":"must provide a name"}`, http.StatusBadRequest)
return nil
}
key, err := jsonparser.GetString(b, "set", "key")
if err != nil {
return fmt.Errorf("cannot find %q: %v", "set.key", err)
}
if key == "" {
http.Error(w, `{"error":"must provide a set.key"}`, http.StatusBadRequest)
return nil
}
value, err := jsonparser.GetString(b, "set", "value")
if err != nil {
return fmt.Errorf("cannot find %q: %v", "set.value", err)
}
operator := operator.Set{Key: key, Value: value}
return g.Update(r.Context(), namespace, entity.One{Name: name}, operator)
}

View File

@ -1,13 +0,0 @@
package view
import (
"local/dndex/storage"
"net/http"
"path"
)
func httpmeet(g storage.Graph, w http.ResponseWriter, r *http.Request) error {
namespace := path.Base(r.URL.Path)
w.Write([]byte(namespace))
return nil
}

View File

@ -1,73 +0,0 @@
package view
import (
"context"
"encoding/json"
"local/dndex/storage"
"local/dndex/storage/entity"
"log"
"net/http"
"path"
"strings"
)
func httpwho(g storage.Graph, w http.ResponseWriter, r *http.Request) error {
namespace := strings.TrimLeft(r.URL.Path, path.Dir(r.URL.Path))
if len(namespace) == 0 {
http.NotFound(w, r)
return nil
}
ids := r.URL.Query()["id"]
_, verbose := r.URL.Query()["v"]
_, one := r.URL.Query()["one"]
results := make(map[string]entity.One)
for i := 0; i < len(ids); i++ {
id := ids[i]
one, err := httpwhoOne(r.Context(), g, namespace, id, verbose)
if err != nil {
return err
}
results[id] = one
}
var marshalme interface{}
if one {
for k := range results {
marshalme = results[k]
break
}
} else {
marshalme = results
}
log.Printf("id=%+v, one=%v, verbose=%v, results:%+v", ids, one, verbose, marshalme)
enc := json.NewEncoder(w)
enc.SetIndent("", " ")
return enc.Encode(marshalme)
}
func httpwhoOne(ctx context.Context, g storage.Graph, namespace, id string, verbose bool) (entity.One, error) {
ones, err := g.List(ctx, namespace, id)
if err != nil {
return entity.One{}, err
}
if len(ones) != 1 {
ones = append(ones, entity.One{})
}
one := ones[0]
if verbose {
ones, err := g.List(ctx, namespace, one.Peers()...)
if err != nil {
return entity.One{}, err
}
for _, another := range ones {
another.Connections = nil
another.Text = ""
for j := range one.Connections {
if one.Connections[j].Name == another.Name {
another.Relationship = one.Connections[j].Relationship
one.Connections[j] = another
}
}
}
}
return one, nil
}

View File

@ -1,156 +0,0 @@
package view
import (
"context"
"encoding/json"
"fmt"
"io/ioutil"
"local/dndex/config"
"local/dndex/storage"
"local/dndex/storage/entity"
"net/http"
"net/http/httptest"
"os"
"strings"
"testing"
"time"
"github.com/google/uuid"
)
func TestJSON(t *testing.T) {
if len(os.Getenv("INTEGRATION")) == 0 {
t.Logf("skipping because $INTEGRATION unset")
return
}
os.Args = os.Args[:1]
t.Logf("config: %+v", config.New())
g := storage.NewGraph()
ones := fillDB(t, g)
want := ones[len(ones)-1]
handler := jsonHandler(g)
t.Run("404 on /who", func(t *testing.T) {
r := httptest.NewRequest("GET", "/who", strings.NewReader(``))
w := httptest.NewRecorder()
handler.ServeHTTP(w, r)
if w.Code != http.StatusNotFound {
t.Error(w.Code)
}
})
t.Run("404 on /who/", func(t *testing.T) {
r := httptest.NewRequest("GET", "/who/", strings.NewReader(``))
w := httptest.NewRecorder()
handler.ServeHTTP(w, r)
if w.Code != http.StatusNotFound {
t.Error(w.Code)
}
})
req, err := http.NewRequest(http.MethodGet, fmt.Sprintf("http://localhost:%d/who/col?id=%s&v", config.New().Port, want.Name), strings.NewReader(``))
if err != nil {
t.Fatal(err)
}
w := httptest.NewRecorder()
handler.ServeHTTP(w, req)
var v interface{}
if b, err := ioutil.ReadAll(w.Body); err != nil {
t.Fatalf("failed to read all resp body: %v: %s", err, b)
} else if err := json.Unmarshal(b, &v); err != nil {
t.Fatalf("err unmarshalling response: %v: %s", err, b)
}
b, err := json.MarshalIndent(v, "", " ")
if err != nil {
t.Fatal(err)
}
var gotOnes map[string]entity.One
if err := json.Unmarshal(b, &gotOnes); err != nil {
t.Fatal(err)
}
if len(gotOnes) != 1 {
t.Fatal("too many results: ", len(gotOnes))
}
var o entity.One
for _, v := range gotOnes {
o = v
}
for i := range want.Connections {
found := false
for j := range o.Connections {
if want.Connections[i].Name == o.Connections[j].Name {
found = true
if want.Connections[i].Relationship != o.Connections[j].Relationship {
t.Errorf("connection is wrong: want %+v, got %+v", want.Connections[i], o.Connections[j])
}
}
}
if !found {
t.Errorf("didn't find connection %+v in %+v", want.Connections[i], o.Connections)
}
}
if o.Image != want.Image {
t.Errorf("wrong image: want %q, got %q", want.Image, o.Image)
}
if o.Text != want.Text {
t.Errorf("wrong text: want %q, got %q", want.Text, o.Text)
}
if o.Title != want.Title {
t.Errorf("wrong title: want %q, got %q", want.Title, o.Title)
}
if o.Type != want.Type {
t.Errorf("wrong type: want %q, got %q", want.Type, o.Type)
}
if o.Name != want.Name {
t.Errorf("wrong name: want %q, got %q", want.Name, o.Name)
}
t.Logf("\n%s\n", b)
}
func fillDB(t *testing.T, g storage.Graph) []entity.One {
ones := make([]entity.One, 5)
for i := range ones {
ones[i] = randomOne()
if i > 0 {
ones[i].Connections[ones[i-1].Name] = entity.One{
Name: ones[i-1].Name,
Relationship: ":D",
}
}
}
for i := range ones {
if err := g.Insert(context.TODO(), "col", ones[i]); err != nil {
t.Fatal(err)
}
if results, err := g.List(context.TODO(), "col", ones[i].Name); err != nil {
t.Fatal(err)
} else if len(results) != 1 {
t.Fatal(len(results))
} else if len(results[0].Connections) != len(ones[i].Connections) {
t.Fatal(len(results[0].Connections), len(ones[i].Connections))
} else if len(results[0].Connections) > 0 {
for k, v := range results[0].Connections {
if k == "" || v.Name == "" {
t.Fatalf("name is gone: %q:%+v", k, v)
}
}
}
}
return ones
}
func randomOne() entity.One {
return entity.One{
Name: "name-" + uuid.New().String()[:5],
Type: "type-" + uuid.New().String()[:5],
Title: "titl-" + uuid.New().String()[:5],
Image: "imge-" + uuid.New().String()[:5],
Text: "text-" + uuid.New().String()[:5],
Modified: time.Now().UnixNano(),
Connections: map[string]entity.One{},
}
}

View File

@ -109,7 +109,7 @@ func whoPut(namespace string, g storage.Graph, w http.ResponseWriter, r *http.Re
delete(op, k) delete(op, k)
} }
} }
if err := g.Update(r.Context(), namespace, entity.One{Name: id}, operator.SetMany{op}); err != nil { if err := g.Update(r.Context(), namespace, entity.One{Name: id}, operator.SetMany{Value: op}); err != nil {
return err return err
} }

View File

@ -2,6 +2,7 @@ package view
import ( import (
"bytes" "bytes"
"context"
"encoding/json" "encoding/json"
"fmt" "fmt"
"io/ioutil" "io/ioutil"
@ -13,6 +14,9 @@ import (
"os" "os"
"strings" "strings"
"testing" "testing"
"time"
"github.com/google/uuid"
) )
func TestWho(t *testing.T) { func TestWho(t *testing.T) {
@ -153,3 +157,47 @@ func TestWho(t *testing.T) {
t.Logf("POST POST:\n%s", b) t.Logf("POST POST:\n%s", b)
}) })
} }
func fillDB(t *testing.T, g storage.Graph) []entity.One {
ones := make([]entity.One, 5)
for i := range ones {
ones[i] = randomOne()
if i > 0 {
ones[i].Connections[ones[i-1].Name] = entity.One{
Name: ones[i-1].Name,
Relationship: ":D",
}
}
}
for i := range ones {
if err := g.Insert(context.TODO(), "col", ones[i]); err != nil {
t.Fatal(err)
}
if results, err := g.List(context.TODO(), "col", ones[i].Name); err != nil {
t.Fatal(err)
} else if len(results) != 1 {
t.Fatal(len(results))
} else if len(results[0].Connections) != len(ones[i].Connections) {
t.Fatal(len(results[0].Connections), len(ones[i].Connections))
} else if len(results[0].Connections) > 0 {
for k, v := range results[0].Connections {
if k == "" || v.Name == "" {
t.Fatalf("name is gone: %q:%+v", k, v)
}
}
}
}
return ones
}
func randomOne() entity.One {
return entity.One{
Name: "name-" + uuid.New().String()[:5],
Type: "type-" + uuid.New().String()[:5],
Title: "titl-" + uuid.New().String()[:5],
Image: "imge-" + uuid.New().String()[:5],
Text: "text-" + uuid.New().String()[:5],
Modified: time.Now().UnixNano(),
Connections: map[string]entity.One{},
}
}