forgepb/goDebCheck.go

55 lines
1.6 KiB
Go
Raw Normal View History

package forgepb
import (
"go.wit.com/lib/protobuf/gitpb"
"go.wit.com/log"
)
// this is a final check to make sure, before pushing
// a golang repo, that the go.sum file has the correct
// and current version of every package
//
// it re-scans the go.sum file. DOES NOT MODIFY ANYTHING
// this is the last thing to run to double check everything
// before 'git tag' or git push --tags
2024-12-02 08:45:27 -06:00
func (f *Forge) FinalGoDepsCheckOk(check *gitpb.Repo) bool {
var good bool = true
if check == nil {
log.Info("boo, check == nil")
return false
}
// clear out the protobuf and rescan from the file
check.GoDeps = nil
2024-12-03 03:19:12 -06:00
if ok, err := check.ParseGoSum(); ! ok {
log.Info("FinalGoDepsCheckOk() error", err)
return false
}
2024-12-02 07:01:09 -06:00
if check.GoDepsLen() == 0 {
// this is a primitive
check.GoPrimitive = true
return true
}
log.Printf("current repo %s go dependancy count: %d", check.GetGoPath(), check.GoDepsLen())
deps := check.GoDeps.SortByGoPath()
for deps.Scan() {
depRepo := deps.Next()
found := f.Repos.FindByGoPath(depRepo.GetGoPath())
if found == nil {
log.Info("not found:", depRepo.GetGoPath())
return false
}
// log.Info("found dep", depRepo.GetGoPath())
2024-12-02 07:01:09 -06:00
if depRepo.GetVersion() != found.GetTargetVersion() {
if f.IsReadOnly(depRepo.GetGoPath()) {
log.Printf("%-48s ok error %10s vs %10s (ignoring read-only repo)", depRepo.GetGoPath(), depRepo.GetVersion(), found.GetMasterVersion())
} else {
2024-12-02 08:45:27 -06:00
log.Printf("%-48s error %10s vs %10s", depRepo.GetGoPath(), depRepo.GetVersion(), found.GetMasterVersion())
good = false
}
}
}
return good
}