analyze-local-images : fix race condition on intial testing

This commit is contained in:
Mark de Villiers 2015-11-24 07:33:37 -08:00
parent 73f2221955
commit a0954df2fb

View File

@ -14,6 +14,7 @@ import (
"os/exec" "os/exec"
"strconv" "strconv"
"strings" "strings"
"sync"
"time" "time"
) )
@ -86,15 +87,50 @@ func main() {
// Analyze layers // Analyze layers
fmt.Printf("Analyzing %d layers\n", len(layerIDs)) fmt.Printf("Analyzing %d layers\n", len(layerIDs))
for i := 0; i < len(layerIDs); i++ { for i := 0; i < len(layerIDs); i++ {
fmt.Printf("- Analyzing %s\n", layerIDs[i])
layerTarFile := path + "/" + layerIDs[i] + "/layer.tar"
fmt.Printf("- Analyzing %s at %s\n", layerIDs[i], layerTarFile)
var err error var err error
if i > 0 { var wg sync.WaitGroup
err = analyzeLayer(*endpoint, path+"/"+layerIDs[i]+"/layer.tar", layerIDs[i], layerIDs[i-1])
} else { wg.Add(1)
err = analyzeLayer(*endpoint, path+"/"+layerIDs[i]+"/layer.tar", layerIDs[i], "")
go func() {
retrys := 0
for {
//retry until layer is unzipped
if _, err := os.Stat(layerTarFile); err == nil {
break
}
retrys++
fmt.Printf("\nretrying : %d", retrys)
time.Sleep(1 * time.Second)
if retrys == 10 {
err = errors.New("Time out waiting for layer being untarred.")
break
}
}
wg.Done()
}()
wg.Wait()
if err != nil {
log.Fatalf("- Could not analyze layer: %s\n", err)
} }
if i > 0 {
err = analyzeLayer(*endpoint, layerTarFile, layerIDs[i], layerIDs[i-1])
} else {
err = analyzeLayer(*endpoint, layerTarFile, layerIDs[i], "")
}
if err != nil { if err != nil {
log.Fatalf("- Could not analyze layer: %s\n", err) log.Fatalf("- Could not analyze layer: %s\n", err)
} }
@ -143,6 +179,10 @@ func save(imageName string) (string, error) {
return "", errors.New(stderr.String()) return "", errors.New(stderr.String())
} }
err = pipe.Close()
if err != nil {
return "", errors.New(stderr.String())
}
return path, nil return path, nil
} }