summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlex Goodman <wagoodman@gmail.com>2019-10-07 17:44:52 -0400
committerAlex Goodman <wagoodman@gmail.com>2019-10-07 17:44:52 -0400
commit4714aca12302324254969fc70c3f9410767a9051 (patch)
treee05009c34933cdccbf58a2d8be1307e67c254247
parent7f786eb725c3d8e774d888fe7a45ce8ce5e76439 (diff)
fix tests
-rw-r--r--dive/image/docker/testing.go8
-rw-r--r--dive/image/image.go5
-rw-r--r--runtime/export/export.go25
-rw-r--r--runtime/export/export_test.go20
-rw-r--r--runtime/export/layer.go1
-rw-r--r--runtime/ui/filetree_viewmodel_test.go8
6 files changed, 47 insertions, 20 deletions
diff --git a/dive/image/docker/testing.go b/dive/image/docker/testing.go
index 423d8ad..f6d1777 100644
--- a/dive/image/docker/testing.go
+++ b/dive/image/docker/testing.go
@@ -12,8 +12,12 @@ func TestLoadDockerImageTar(tarPath string) (*image.AnalysisResult, error) {
}
defer f.Close()
- resolver := NewResolver()
- img, err := resolver.Fetch("dive-test:latest")
+ archive, err := NewImageArchive(f)
+ if err != nil {
+ return nil, err
+ }
+
+ img, err := archive.ToImage()
if err != nil {
return nil, err
}
diff --git a/dive/image/image.go b/dive/image/image.go
index e875efa..de72c7b 100644
--- a/dive/image/image.go
+++ b/dive/image/image.go
@@ -22,9 +22,8 @@ func (img *Image) Analyze() (*AnalysisResult, error) {
}
var wastedBytes uint64
- for idx := 0; idx < len(inefficiencies); idx++ {
- fileData := inefficiencies[len(inefficiencies)-1-idx]
- wastedBytes += uint64(fileData.CumulativeSize)
+ for _, file := range inefficiencies {
+ wastedBytes += uint64(file.CumulativeSize)
}
return &AnalysisResult{
diff --git a/runtime/export/export.go b/runtime/export/export.go
index f94ac8b..44e09d7 100644
--- a/runtime/export/export.go
+++ b/runtime/export/export.go
@@ -12,27 +12,28 @@ type export struct {
}
func NewExport(analysis *diveImage.AnalysisResult) *export {
- data := export{}
- data.Layer = make([]layer, len(analysis.Layers))
- data.Image.InefficientFiles = make([]fileReference, len(analysis.Inefficiencies))
+ data := export{
+ Layer: make([]layer, len(analysis.Layers)),
+ Image: image {
+ InefficientFiles: make([]fileReference, len(analysis.Inefficiencies)),
+ SizeBytes: analysis.SizeBytes,
+ EfficiencyScore: analysis.Efficiency,
+ InefficientBytes: analysis.WastedBytes,
+ },
+ }
// export layers in order
- for revIdx := len(analysis.Layers) - 1; revIdx >= 0; revIdx-- {
- curLayer := analysis.Layers[revIdx]
- idx := (len(analysis.Layers) - 1) - revIdx
-
+ for idx, curLayer := range analysis.Layers {
data.Layer[idx] = layer{
Index: curLayer.Index,
- DigestID: curLayer.Id,
+ ID: curLayer.Id,
+ DigestID: curLayer.Digest,
SizeBytes: curLayer.Size,
Command: curLayer.Command,
}
}
- data.Image.SizeBytes = analysis.SizeBytes
- data.Image.EfficiencyScore = analysis.Efficiency
- data.Image.InefficientBytes = analysis.WastedBytes
-
+ // add file references
for idx := 0; idx < len(analysis.Inefficiencies); idx++ {
fileData := analysis.Inefficiencies[len(analysis.Inefficiencies)-1-idx]
diff --git a/runtime/export/export_test.go b/runtime/export/export_test.go
index c7cf97d..78cd2bc 100644
--- a/runtime/export/export_test.go
+++ b/runtime/export/export_test.go
@@ -1,6 +1,7 @@
package export
import (
+ "github.com/sergi/go-diff/diffmatchpatch"
"github.com/wagoodman/dive/dive/image/docker"
"testing"
)
@@ -21,84 +22,98 @@ func Test_Export(t *testing.T) {
"layer": [
{
"index": 0,
+ "id": "28cfe03618aa2e914e81fdd90345245c15f4478e35252c06ca52d238fd3cc694",
"digestId": "sha256:23bc2b70b2014dec0ac22f27bb93e9babd08cdd6f1115d0c955b9ff22b382f5a",
"sizeBytes": 1154361,
"command": "#(nop) ADD file:ce026b62356eec3ad1214f92be2c9dc063fe205bd5e600be3492c4dfb17148bd in / "
},
{
"index": 1,
+ "id": "1871059774abe6914075e4a919b778fa1561f577d620ae52438a9635e6241936",
"digestId": "sha256:a65b7d7ac139a0e4337bc3c73ce511f937d6140ef61a0108f7d4b8aab8d67274",
"sizeBytes": 6405,
"command": "#(nop) ADD file:139c3708fb6261126453e34483abd8bf7b26ed16d952fd976994d68e72d93be2 in /somefile.txt "
},
{
"index": 2,
+ "id": "49fe2a475548bfa4d493fc796fce41f30704e3d4cbff3e45dd3e06f463236d1d",
"digestId": "sha256:93e208d471756ffbac88cf9c25feb442007f221d3bd73231e27b747a0a68927c",
"sizeBytes": 0,
"command": "mkdir -p /root/example/really/nested"
},
{
"index": 3,
+ "id": "80cd2ca1ffc89962b9349c80280c2bc551acbd11e09b16badb0669f8e2369020",
"digestId": "sha256:4abad3abe3cb99ad7a492a9d9f6b3d66287c1646843c74128bbbec4f7be5aa9e",
"sizeBytes": 6405,
"command": "cp /somefile.txt /root/example/somefile1.txt"
},
{
"index": 4,
+ "id": "c99e2f8d3f6282668f0d30dc1db5e67a51d7a1dcd7ff6ddfa0f90760836778ec",
"digestId": "sha256:14c9a6ffcb6a0f32d1035f97373b19608e2d307961d8be156321c3f1c1504cbf",
"sizeBytes": 6405,
"command": "chmod 444 /root/example/somefile1.txt"
},
{
"index": 5,
+ "id": "5eca617bdc3bc06134fe957a30da4c57adb7c340a6d749c8edc4c15861c928d7",
"digestId": "sha256:778fb5770ef466f314e79cc9dc418eba76bfc0a64491ce7b167b76aa52c736c4",
"sizeBytes": 6405,
"command": "cp /somefile.txt /root/example/somefile2.txt"
},
{
"index": 6,
+ "id": "f07c3eb887572395408f8e11a07af945e4da5f02b3188bb06b93fad713ca0b99",
"digestId": "sha256:f275b8a31a71deb521cc048e6021e2ff6fa52bedb25c9b7bbe129a0195ddca5f",
"sizeBytes": 6405,
"command": "cp /somefile.txt /root/example/somefile3.txt"
},
{
"index": 7,
+ "id": "461885fc22589158dee3c5b9f01cc41c87805439f58b4399d733b51aa305cbf9",
"digestId": "sha256:dd1effc5eb19894c3e9b57411c98dd1cf30fa1de4253c7fae53c9cea67267d83",
"sizeBytes": 6405,
"command": "mv /root/example/somefile3.txt /root/saved.txt"
},
{
"index": 8,
+ "id": "a10327f68ffed4afcba78919052809a8f774978a6b87fc117d39c53c4842f72c",
"digestId": "sha256:8d1869a0a066cdd12e48d648222866e77b5e2814f773bb3bd8774ab4052f0f1d",
"sizeBytes": 6405,
"command": "cp /root/saved.txt /root/.saved.txt"
},
{
"index": 9,
+ "id": "f2fc54e25cb7966dc9732ec671a77a1c5c104e732bd15ad44a2dc1ac42368f84",
"digestId": "sha256:bc2e36423fa31a97223fd421f22c35466220fa160769abf697b8eb58c896b468",
"sizeBytes": 0,
"command": "rm -rf /root/example/"
},
{
"index": 10,
+ "id": "aad36d0b05e71c7e6d4dfe0ca9ed6be89e2e0d8995dafe83438299a314e91071",
"digestId": "sha256:7f648d45ee7b6de2292162fba498b66cbaaf181da9004fcceef824c72dbae445",
"sizeBytes": 2187,
"command": "#(nop) ADD dir:7ec14b81316baa1a31c38c97686a8f030c98cba2035c968412749e33e0c4427e in /root/.data/ "
},
{
"index": 11,
+ "id": "3d4ad907517a021d86a4102d2764ad2161e4818bbd144e41d019bfc955434181",
"digestId": "sha256:a4b8f95f266d5c063c9a9473c45f2f85ddc183e37941b5e6b6b9d3c00e8e0457",
"sizeBytes": 6405,
"command": "cp /root/saved.txt /tmp/saved.again1.txt"
},
{
"index": 12,
+ "id": "81b1b002d4b4c1325a9cad9990b5277e7f29f79e0f24582344c0891178f95905",
"digestId": "sha256:22a44d45780a541e593a8862d80f3e14cb80b6bf76aa42ce68dc207a35bf3a4a",
"sizeBytes": 6405,
"command": "cp /root/saved.txt /root/.data/saved.again2.txt"
},
{
"index": 13,
+ "id": "cfb35bb5c127d848739be5ca726057e6e2c77b2849f588e7aebb642c0d3d4b7b",
"digestId": "sha256:ba689cac6a98c92d121fa5c9716a1bab526b8bb1fd6d43625c575b79e97300c5",
"sizeBytes": 6405,
"command": "chmod +x /root/saved.txt"
@@ -129,6 +144,9 @@ func Test_Export(t *testing.T) {
}`
actualResult := string(payload)
if expectedResult != actualResult {
- t.Errorf("Test_Export: unexpected export result:\n%v", actualResult)
+ dmp := diffmatchpatch.New()
+ diffs := dmp.DiffMain(expectedResult, actualResult, false)
+
+ t.Errorf("Test_Export: unexpected export result:\n%v", dmp.DiffPrettyText(diffs))
}
}
diff --git a/runtime/export/layer.go b/runtime/export/layer.go
index b360f48..cdbba5b 100644
--- a/runtime/export/layer.go
+++ b/runtime/export/layer.go
@@ -2,6 +2,7 @@ package export
type layer struct {
Index int `json:"index"`
+ ID string `json:"id"`
DigestID string `json:"digestId"`
SizeBytes uint64 `json:"sizeBytes"`
Command string `json:"command"`
diff --git a/runtime/ui/filetree_viewmodel_test.go b/runtime/ui/filetree_viewmodel_test.go
index ba1d86c..af2bbb0 100644
--- a/runtime/ui/filetree_viewmodel_test.go
+++ b/runtime/ui/filetree_viewmodel_test.go
@@ -87,9 +87,13 @@ func initializeTestViewModel(t *testing.T) *FileTreeViewModel {
treeStack, err := filetree.StackTreeRange(result.RefTrees, 0, 0)
if err != nil {
- t.Fatalf("%s: unable to create tree ViewModel: %v", t.Name(), err)
+ t.Fatalf("%s: unable to stack trees: %v", t.Name(), err)
}
- return NewFileTreeViewModel(treeStack, result.RefTrees, cache)
+ vm, err := NewFileTreeViewModel(treeStack, result.RefTrees, cache)
+ if err != nil {
+ t.Fatalf("%s: unable to create tree ViewModel: %+v", t.Name(), err)
+ }
+ return vm
}
func runTestCase(t *testing.T, vm *FileTreeViewModel, width, height int, filterRegex *regexp.Regexp) {