2024-12-02 05:14:52 -06:00
|
|
|
package forgepb
|
|
|
|
|
|
|
|
import (
|
2024-12-03 13:24:41 -06:00
|
|
|
"strings"
|
|
|
|
|
2024-12-02 05:14:52 -06:00
|
|
|
"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 {
|
2024-12-02 05:14:52 -06:00
|
|
|
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 13:24:41 -06:00
|
|
|
if ok, err := check.ParseGoSum(); !ok {
|
2024-12-03 03:19:12 -06:00
|
|
|
log.Info("FinalGoDepsCheckOk() error", err)
|
|
|
|
return false
|
|
|
|
}
|
2024-12-02 05:14:52 -06:00
|
|
|
|
2024-12-02 07:01:09 -06:00
|
|
|
if check.GoDepsLen() == 0 {
|
|
|
|
// this is a primitive
|
|
|
|
check.GoPrimitive = true
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
2024-12-02 05:14:52 -06:00
|
|
|
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 {
|
2024-12-03 13:24:41 -06:00
|
|
|
if f.checkOverride(depRepo.GetGoPath()) {
|
|
|
|
// skip this gopath because it's probably broken forever
|
|
|
|
continue
|
|
|
|
}
|
2024-12-02 05:14:52 -06:00
|
|
|
log.Info("not found:", depRepo.GetGoPath())
|
2024-12-03 13:24:41 -06:00
|
|
|
good = false
|
|
|
|
continue
|
2024-12-02 05:14:52 -06:00
|
|
|
}
|
|
|
|
// log.Info("found dep", depRepo.GetGoPath())
|
2024-12-02 07:01:09 -06:00
|
|
|
if depRepo.GetVersion() != found.GetTargetVersion() {
|
2024-12-03 13:24:41 -06:00
|
|
|
check := f.Repos.FindByGoPath(depRepo.GoPath)
|
|
|
|
if f.IsReadOnly(check) {
|
2024-12-02 05:14:52 -06:00
|
|
|
log.Printf("%-48s ok error %10s vs %10s (ignoring read-only repo)", depRepo.GetGoPath(), depRepo.GetVersion(), found.GetMasterVersion())
|
|
|
|
} else {
|
2024-12-03 13:24:41 -06:00
|
|
|
if f.checkOverride(depRepo.GetGoPath()) {
|
|
|
|
log.Printf("%-48s ok error %10s vs %10s (forge.checkOverride())", depRepo.GetGoPath(), depRepo.GetVersion(), found.GetMasterVersion())
|
|
|
|
// skip this gopath because it's probably broken forever
|
|
|
|
continue
|
|
|
|
} else {
|
|
|
|
log.Printf("%-48s error %10s vs %10s", depRepo.GetGoPath(), depRepo.GetVersion(), found.GetMasterVersion())
|
|
|
|
good = false
|
|
|
|
}
|
2024-12-02 05:14:52 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return good
|
|
|
|
}
|
2024-12-03 13:24:41 -06:00
|
|
|
|
|
|
|
func (f *Forge) checkOverride(gopath string) bool {
|
|
|
|
if gopath == "cloud.google.com/go" {
|
|
|
|
log.Info("checkOverride() is ignoring", gopath)
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
if strings.HasPrefix(gopath, "github.com/go-gl") {
|
|
|
|
log.Info("checkOverride() is ignoring", gopath)
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|