-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Thomas Osterbind
committed
Jan 16, 2018
1 parent
a631d09
commit 329a79f
Showing
12 changed files
with
215 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
version: '2' | ||
jobs: | ||
build: | ||
working_directory: /go/src/github.com/qri-io/datasetDiffer | ||
docker: | ||
- image: circleci/golang:1.9 | ||
environment: | ||
GOLANG_ENV: test | ||
PORT: 3000 | ||
environment: | ||
TEST_RESULTS: /tmp/test-results | ||
steps: | ||
- checkout | ||
- run: mkdir -p $TEST_RESULTS | ||
- run: go get github.com/jstemmer/go-junit-report github.com/golang/lint/golint | ||
- run: | ||
name: Install deps | ||
command: > | ||
go get -v -d -u | ||
github.com/jstemmer/go-junit-report | ||
- run: | ||
name: Run Lint Tests | ||
command: golint ./... | ||
- run: | ||
name: Run Tests | ||
command: | | ||
trap "go-junit-report <${TEST_RESULTS}/go-test.out > ${TEST_RESULTS}/go-test-report.xml" EXIT | ||
./.circleci/cover.test.sh | tee ${TEST_RESULTS}/go-test.out | ||
- run: | ||
name: Publish coverage info to codecov.io | ||
command: bash <(curl -s https://codecov.io/bash) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
#!/usr/bin/env bash | ||
|
||
set -e | ||
echo "" > coverage.txt | ||
go test -v -race -coverprofile=profile.out -covermode=atomic github.com/qri-io/datasetDiffer | ||
if [ -f profile.out ]; then | ||
cat profile.out >> coverage.txt | ||
rm profile.out | ||
fi |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,10 @@ | ||
[data:image/s3,"s3://crabby-images/50160/501607d254098984c115ad9e9c30f32e03aa818f" alt="Qri"](https://qri.io) | ||
[data:image/s3,"s3://crabby-images/d132e/d132eb4abd9e34d4df3be873d0f7554339a7871c" alt="GoDoc"](http://godoc.org/github.com/qri-io/datasetDiffer) | ||
[data:image/s3,"s3://crabby-images/cbdbb/cbdbbcbbec005a9ab46b13c17d326a9973e92170" alt="License"](./LICENSE) | ||
[data:image/s3,"s3://crabby-images/97445/97445594ab91eb5cd582e32f48395d60066c0c73" alt="Codecov"](https://codecov.io/gh/qri-io/datasetDiffer) | ||
[data:image/s3,"s3://crabby-images/deba8/deba8654aaf14297a1ce9587df85ac3af8e88d56" alt="CI"](https://circleci.com/gh/qri-io/datasetDiffer) | ||
[data:image/s3,"s3://crabby-images/207e6/207e628e4774bb8105a905f469e14f4e6f8e0b23" alt="Go Report Card"](https://goreportcard.com/report/github.com/qri-io/datasetDiffer) | ||
|
||
# datasetDiffer | ||
|
||
Utility for Diffing Datasets, currently a very basic placeholder |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
codecov: | ||
ci: | ||
- "ci/circle-ci" | ||
notify: | ||
require_ci_to_pass: no | ||
after_n_builds: 2 | ||
coverage: | ||
range: "80...100" | ||
comment: off |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
package datasetDiffer | ||
|
||
import ( | ||
"fmt" | ||
|
||
"github.com/qri-io/dataset" | ||
) | ||
|
||
// Diff contains a string description of a diff | ||
type Diff string | ||
|
||
// DiffList contains a slice of diffs in order of descending scope | ||
type DiffList struct { | ||
diffs []Diff | ||
} | ||
|
||
// String returns the first (largest scope) change as a string | ||
func (diffList DiffList) String() string { | ||
if len(diffList.diffs) > 0 { | ||
return string(diffList.diffs[0]) | ||
} | ||
return "" | ||
} | ||
|
||
// DiffDatasets calculates diffs between two datasets and returns a | ||
// dataset. Differences are checked in order of descending scope | ||
// - dataset.Dataset.path | ||
// - dataset.Dataset.Structure.path | ||
// - dataset.Dataset.Data.path | ||
// TODO: make diffs non-trivial | ||
func DiffDatasets(a, b *dataset.Dataset) (*DiffList, error) { | ||
diffList := &DiffList{} | ||
diffDescription := Diff("") | ||
if len(a.Structure.Path().String()) <= 1 || len(b.Structure.Path().String()) <= 1 { | ||
return nil, fmt.Errorf("error: structure path cannot be empty string") | ||
} | ||
if len(a.DataPath) <= 1 || len(b.DataPath) <= 1 { | ||
return nil, fmt.Errorf("error: data path cannot be empty string") | ||
} | ||
if a.Structure.Path() != b.Structure.Path() { | ||
diffDescription = Diff("Structure Changed.") | ||
diffList.diffs = append(diffList.diffs, diffDescription) | ||
} | ||
if a.DataPath != b.DataPath { | ||
diffDescription = Diff("Data Changed.") | ||
diffList.diffs = append(diffList.diffs, diffDescription) | ||
} | ||
return diffList, nil | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,73 @@ | ||
package datasetDiffer | ||
|
||
import ( | ||
"fmt" | ||
"io/ioutil" | ||
// "path/filepath" | ||
"testing" | ||
// "github.com/qri-io/qri" | ||
// testrepo "github.com/qri-io/qri/repo/test" | ||
"github.com/qri-io/dataset" | ||
) | ||
|
||
func loadTestData(path string) (*dataset.Dataset, error) { | ||
dataBytes, err := ioutil.ReadFile(path) | ||
if err != nil { | ||
return nil, err | ||
} | ||
d := &dataset.Dataset{} | ||
err = d.UnmarshalJSON(dataBytes) | ||
if err != nil { | ||
return nil, fmt.Errorf("unable to unmarshal dataset: %s", err.Error()) | ||
} | ||
return d, nil | ||
} | ||
|
||
func TestDiffDataset(t *testing.T) { | ||
//setup | ||
|
||
//test cases | ||
cases := []struct { | ||
dsPathA string | ||
dsPathB string | ||
expected string | ||
err string | ||
}{ | ||
{"testdata/exampleData_orig.json", "testdata/exampleData_orig.json", "", ""}, | ||
{"testdata/exampleData_orig.json", "testdata/exampleData_newData.json", "Data Changed.", ""}, | ||
{"testdata/exampleData_orig.json", "testdata/exampleData_newStructure.json", "Structure Changed.", ""}, | ||
{"testdata/exampleData_orig.json", "testdata/exampleData_newDataAndStructure.json", "Structure Changed.", ""}, | ||
{"testdata/exampleData_orig.json", "testdata/exampleData_blankStructure.json", "", "error: structure path cannot be empty string"}, | ||
{"testdata/exampleData_orig.json", "testdata/exampleData_blankData.json", "", "error: data path cannot be empty string"}, | ||
} | ||
// load files and execute tests | ||
for i, c := range cases { | ||
pathA := c.dsPathA | ||
pathB := c.dsPathB | ||
//load data | ||
dsA, err := loadTestData(pathA) | ||
if err != nil { | ||
t.Errorf("case %d error: error loading file '%s'", i, pathA) | ||
return | ||
} | ||
dsB, err := loadTestData(pathB) | ||
if err != nil { | ||
t.Errorf("case %d error: error loading file '%s'", i, pathB) | ||
return | ||
} | ||
got, err := DiffDatasets(dsA, dsB) | ||
if err != nil { | ||
if err.Error() == c.err { | ||
continue | ||
} else { | ||
t.Errorf("case %d error mismatch: expected '%s', got '%s'", i, c.err, err.Error()) | ||
return | ||
} | ||
|
||
} | ||
if got.String() != c.expected { | ||
t.Errorf("case %d response mismatch. expected '%s', got '%s'", i, c.expected, got.String()) | ||
continue | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
{ | ||
"kind": "qri:ds:0", | ||
"DataPath": "", | ||
"path": "123", | ||
"structure": "abc" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
{ | ||
"kind": "qri:ds:0", | ||
"DataPath": "def", | ||
"path": "123", | ||
"structure": "" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
{ | ||
"kind": "qri:ds:0", | ||
"DataPath": "def", | ||
"path": "123", | ||
"structure": "abc" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
{ | ||
"kind": "qri:ds:0", | ||
"DataPath": "abc......", | ||
"path": "123", | ||
"structure": "abc......" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
{ | ||
"kind": "qri:ds:0", | ||
"DataPath": "abc", | ||
"path": "123", | ||
"structure": "def" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
{ | ||
"kind": "qri:ds:0", | ||
"DataPath": "abc", | ||
"path": "123", | ||
"structure": "abc" | ||
} |