migration + tests
This commit is contained in:
parent
6e21abab6b
commit
91163b7b0e
9 changed files with 202 additions and 1 deletions
3
.gitignore
vendored
3
.gitignore
vendored
|
@ -15,3 +15,6 @@
|
||||||
# Dependency directories (remove the comment below to include it)
|
# Dependency directories (remove the comment below to include it)
|
||||||
# vendor/
|
# vendor/
|
||||||
|
|
||||||
|
/tags
|
||||||
|
/testdata/sunny1/
|
||||||
|
/.idea/
|
||||||
|
|
|
@ -1,3 +1,6 @@
|
||||||
# zord-tree
|
# zord-tree
|
||||||
|
|
||||||
Library for golang to build articles tree from file system.
|
Library for golang to build articles tree from file system.
|
||||||
|
|
||||||
|
|
||||||
|
## Notes
|
||||||
|
|
5
go.mod
Normal file
5
go.mod
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
module g.arns.lt/zordsdavini/zord-tree
|
||||||
|
|
||||||
|
go 1.16
|
||||||
|
|
||||||
|
require github.com/otiai10/copy v1.5.1
|
7
go.sum
Normal file
7
go.sum
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
github.com/otiai10/copy v1.5.1 h1:a/cs2E1/1V0az8K5nblbl+ymEa4E11AfaOLMar8V34w=
|
||||||
|
github.com/otiai10/copy v1.5.1/go.mod h1:XWfuS3CrI0R6IE0FbgHsEazaXO8G0LpMp9o8tos0x4E=
|
||||||
|
github.com/otiai10/curr v0.0.0-20150429015615-9b4961190c95/go.mod h1:9qAhocn7zKJG+0mI8eUu6xqkFDYS2kb2saOteoSB3cE=
|
||||||
|
github.com/otiai10/curr v1.0.0/go.mod h1:LskTG5wDwr8Rs+nNQ+1LlxRjAtTZZjtJW4rMXl6j4vs=
|
||||||
|
github.com/otiai10/mint v1.3.0/go.mod h1:F5AjcsTsWUqX+Na9fpHb52P8pcRX2CI6A3ctIT91xUo=
|
||||||
|
github.com/otiai10/mint v1.3.2 h1:VYWnrP5fXmz1MXvjuUvcBrXSjGE6xjON+axB/UrpO3E=
|
||||||
|
github.com/otiai10/mint v1.3.2/go.mod h1:/yxELlJQ0ufhjUwhshSj+wFjZ78CnZ48/1wtmBH1OTc=
|
10
testdata/sunny/file1.md
vendored
Normal file
10
testdata/sunny/file1.md
vendored
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
tags: t1,t2
|
||||||
|
description: Če test file __va__
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
# Če kažkas torietom būtė
|
||||||
|
|
||||||
|
* lists
|
||||||
|
|
||||||
|
__va__
|
8
testdata/sunny/file2.md
vendored
Normal file
8
testdata/sunny/file2.md
vendored
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
tags: t1
|
||||||
|
description: Če test 2
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
# Če kažkas torietom būtė 2
|
||||||
|
|
||||||
|
ale nie
|
10
testdata/sunny/subcategory/file3.md
vendored
Normal file
10
testdata/sunny/subcategory/file3.md
vendored
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
tags: t1
|
||||||
|
description: Če test 3
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
# Če kažkas torietom būtė 3
|
||||||
|
|
||||||
|
* vëns
|
||||||
|
* do
|
||||||
|
* trīs
|
109
tree.go
Normal file
109
tree.go
Normal file
|
@ -0,0 +1,109 @@
|
||||||
|
package zord_tree
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bufio"
|
||||||
|
"io/fs"
|
||||||
|
"io/ioutil"
|
||||||
|
"os"
|
||||||
|
"path"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
type File struct {
|
||||||
|
id string
|
||||||
|
name string
|
||||||
|
fullPath string
|
||||||
|
category []string
|
||||||
|
tags []string
|
||||||
|
meta map[string]string
|
||||||
|
description string
|
||||||
|
lang string
|
||||||
|
}
|
||||||
|
|
||||||
|
type Tree struct {
|
||||||
|
path string
|
||||||
|
dirs []Tree
|
||||||
|
files []File
|
||||||
|
}
|
||||||
|
|
||||||
|
func BuildTree(dirPath string) (Tree, error) {
|
||||||
|
return readPath(dirPath, []string{})
|
||||||
|
}
|
||||||
|
|
||||||
|
func readPath( dirPath string, category []string ) (Tree, error) {
|
||||||
|
tree := Tree{}
|
||||||
|
|
||||||
|
tree.path = dirPath
|
||||||
|
|
||||||
|
files, err := ioutil.ReadDir(dirPath)
|
||||||
|
if err != nil {
|
||||||
|
return tree, err
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, file := range files {
|
||||||
|
fullPath := path.Join(dirPath, file.Name())
|
||||||
|
if file.IsDir() {
|
||||||
|
nextDir, err := readPath(fullPath, append(category, file.Name()))
|
||||||
|
if err != nil {
|
||||||
|
return tree, err
|
||||||
|
}
|
||||||
|
tree.dirs = append(tree.dirs, nextDir)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err := ioutil.ReadFile(fullPath)
|
||||||
|
if err != nil {
|
||||||
|
return tree, err
|
||||||
|
}
|
||||||
|
nextFile, err := readFile(file, fullPath, category)
|
||||||
|
if err != nil {
|
||||||
|
return tree, err
|
||||||
|
}
|
||||||
|
tree.files = append(tree.files, nextFile)
|
||||||
|
}
|
||||||
|
|
||||||
|
return tree, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func readFile(file fs.FileInfo, fullPath string, category []string) (File, error) {
|
||||||
|
f := File{
|
||||||
|
name: file.Name(),
|
||||||
|
fullPath: fullPath,
|
||||||
|
category: category,
|
||||||
|
}
|
||||||
|
|
||||||
|
osf, err := os.Open(fullPath)
|
||||||
|
if err != nil {
|
||||||
|
return File{}, err
|
||||||
|
}
|
||||||
|
scanner := bufio.NewScanner(osf)
|
||||||
|
scanner.Split(bufio.ScanLines)
|
||||||
|
for scanner.Scan() {
|
||||||
|
line := scanner.Text()
|
||||||
|
if line == "---" {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
if strings.HasPrefix(line, "tags:") {
|
||||||
|
line = strings.TrimPrefix(line, "tags:")
|
||||||
|
t := strings.Split(line, ",")
|
||||||
|
tags := []string{}
|
||||||
|
for _, tag := range t {
|
||||||
|
tags = append(tags, strings.Trim(tag, " "))
|
||||||
|
}
|
||||||
|
|
||||||
|
f.tags = tags
|
||||||
|
}
|
||||||
|
if strings.HasPrefix(line, "description:") {
|
||||||
|
line = strings.TrimPrefix(line, "description:")
|
||||||
|
f.description = strings.Trim(line, " ")
|
||||||
|
}
|
||||||
|
if strings.HasPrefix(line, "lang:") {
|
||||||
|
line = strings.TrimPrefix(line, "lang:")
|
||||||
|
f.lang = strings.Trim(line, " ")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
osf.Close()
|
||||||
|
|
||||||
|
return f, nil
|
||||||
|
}
|
46
tree_test.go
Normal file
46
tree_test.go
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
package zord_tree
|
||||||
|
|
||||||
|
import (
|
||||||
|
cp "github.com/otiai10/copy"
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestFromNotExistingDirectory(t *testing.T) {
|
||||||
|
_, err := BuildTree("./testing/i_dont_exist")
|
||||||
|
if err == nil {
|
||||||
|
t.Error("Not existing directory should return error, got NIL.")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestSunny(t *testing.T) {
|
||||||
|
err := os.Remove("./testdata/sunny1")
|
||||||
|
if err != nil {
|
||||||
|
}
|
||||||
|
err = cp.Copy("./testdata/sunny", "./testdata/sunny1")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal("Couldn't prepare data for testing")
|
||||||
|
}
|
||||||
|
tree, err := BuildTree("./testdata/sunny1")
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Got error: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(tree.dirs) != 1 {
|
||||||
|
t.Errorf("Should be 1 subdirectory, got %v", len(tree.dirs))
|
||||||
|
}
|
||||||
|
|
||||||
|
if tree.dirs[0].files[0].name != "file3.md" {
|
||||||
|
t.Errorf("File should be 'file3.md', got %v", tree.dirs[0].files[0].name)
|
||||||
|
}
|
||||||
|
if tree.files[0].name != "file1.md" {
|
||||||
|
t.Errorf("File should be 'file1.md', got %v", tree.files[0].name)
|
||||||
|
}
|
||||||
|
if len(tree.files[0].tags) != 2 {
|
||||||
|
t.Errorf("File 'file1.md' should have 2 tags, got %v", len(tree.files[0].tags))
|
||||||
|
}
|
||||||
|
if tree.files[0].tags[1] != "t2" {
|
||||||
|
t.Errorf("File 'file1.md' 2nd tag 't2', got %v", tree.files[0].tags[1])
|
||||||
|
}
|
||||||
|
t.Log(tree)
|
||||||
|
}
|
Loading…
Reference in a new issue