fix tests,

master
Bel LaPointe 2021-07-29 07:08:49 -06:00
parent 2d16bf0ad5
commit f2175e41a9
4 changed files with 44 additions and 28 deletions

View File

@ -42,7 +42,7 @@ func TestComment(t *testing.T) {
t.Error(err) t.Error(err)
} }
if err := n.Comment(fpath, 10000, "big line no"); err == nil { if err := n.Comment(fpath, 10000, "big line no"); err != nil {
t.Error(err) t.Error(err)
} }

View File

@ -1,11 +1,16 @@
package notes package notes
import ( import (
"fmt"
"local/notes-server/filetree" "local/notes-server/filetree"
"os" "os"
) )
func (n *Notes) Delete(urlPath string) error { func (n *Notes) Delete(urlPath string) error {
p := filetree.NewPathFromURL(urlPath) p := filetree.NewPathFromURL(urlPath)
return os.Remove(p.Local) err := os.Remove(p.Local)
if err != nil {
err = fmt.Errorf("failed to delete %q => %q: %v", urlPath, p.Local, err)
}
return err
} }

View File

@ -4,6 +4,7 @@ import (
"io/ioutil" "io/ioutil"
"local/notes-server/config" "local/notes-server/config"
"os" "os"
"path"
"testing" "testing"
) )
@ -11,33 +12,43 @@ func TestDelete(t *testing.T) {
config.Root = "/tmp" config.Root = "/tmp"
ioutil.WriteFile("/tmp/a", []byte("hi"), os.ModePerm) ioutil.WriteFile("/tmp/a", []byte("hi"), os.ModePerm)
n := &Notes{} n := &Notes{}
if err := n.Delete("/notes/a"); err != nil {
t.Error(err)
}
if _, err := os.Stat("/tmp/a"); err == nil {
t.Error(err)
}
d, err := ioutil.TempDir(os.TempDir(), "trydel*") t.Run("delete 404", func(t *testing.T) {
if err != nil { if err := n.Delete("/notes/a"); err != nil {
t.Fatal(err) t.Error(err)
} }
for i := 0; i < 3; i++ { if _, err := os.Stat("/tmp/a"); err == nil {
f, err := ioutil.TempFile(d, "file*") t.Error(err)
}
})
t.Run("delete w. content", func(t *testing.T) {
d, err := ioutil.TempDir(os.TempDir(), "trydel*")
if err != nil { if err != nil {
t.Fatal(err) t.Fatal(err)
} }
f.Close() config.Root = path.Dir(d)
} for i := 0; i < 3; i++ {
if err := n.Delete(d); err == nil { f, err := ioutil.TempFile(d, "file*")
t.Error(err) if err != nil {
} t.Fatal(err)
}
f.Close()
}
if err := n.Delete("/abc/" + path.Base(d)); err == nil {
t.Error(err)
}
})
e, err := ioutil.TempDir(os.TempDir(), "trydel*") t.Run("delete empty dir", func(t *testing.T) {
if err != nil { d2p := os.TempDir()
t.Fatal(err) d2, err := ioutil.TempDir(d2p, "trydel*")
} config.Root = path.Dir(d2p)
if err := n.Delete(e); err != nil { if err != nil {
t.Error(err) t.Fatal(err)
} }
if err := n.Delete("/abc/" + path.Base(d2)); err != nil {
t.Errorf("failed to del empty dir %s in %s: %v", d2, d2p, err)
}
})
} }

View File

@ -63,7 +63,7 @@ func (n *Notes) Search(phrase string) (string, error) {
if size := info.Size(); size < 1 || size > (5*1024*1024) { if size := info.Size(); size < 1 || size > (5*1024*1024) {
return nil return nil
} }
ok, err := grepFile(walked, searcher) ok, err := searcher.file(walked)
if err != nil && err.Error() == "bufio.Scanner: token too long" { if err != nil && err.Error() == "bufio.Scanner: token too long" {
err = nil err = nil
} }
@ -79,7 +79,7 @@ func (n *Notes) Search(phrase string) (string, error) {
return filetree.Paths(*files).List(true), err return filetree.Paths(*files).List(true), err
} }
func grepFile(file string, searcher *searcher) (bool, error) { func (searcher *searcher) file(file string) (bool, error) {
if d := path.Base(path.Dir(file)); strings.HasPrefix(d, ".") && strings.HasSuffix(d, ".attachments") { if d := path.Base(path.Dir(file)); strings.HasPrefix(d, ".") && strings.HasSuffix(d, ".attachments") {
return false, nil return false, nil
} }