forgepb/goDebCheck.go

85 lines
2.4 KiB
Go
Raw Normal View History

package forgepb
import (
2024-12-03 13:24:41 -06:00
"strings"
"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 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 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 {
2024-12-03 13:24:41 -06:00
if f.checkOverride(depRepo.GetGoPath()) {
// skip this gopath because it's probably broken forever
continue
}
log.Info("not found:", depRepo.GetGoPath())
2024-12-03 13:24:41 -06:00
good = false
continue
}
// 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-03 15:17:35 -06:00
log.Printf("%-48s ok error .%s. vs .%s. (ignoring read-only repo)", depRepo.GetGoPath(), depRepo.GetVersion(), found.GetTargetVersion())
} else {
2024-12-03 13:24:41 -06:00
if f.checkOverride(depRepo.GetGoPath()) {
2024-12-03 15:17:35 -06:00
log.Printf("%-48s ok error .%s. vs .%s. (forge.checkOverride())", depRepo.GetGoPath(), depRepo.GetVersion(), found.GetTargetVersion())
2024-12-03 13:24:41 -06:00
// skip this gopath because it's probably broken forever
continue
} else {
2024-12-03 15:17:35 -06:00
log.Printf("%-48s error %10s vs %10s", depRepo.GetGoPath(), depRepo.GetVersion(), found.GetTargetVersion())
2024-12-03 13:24:41 -06:00
good = false
}
}
}
}
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
}
2024-12-03 15:17:35 -06:00
if gopath == "github.com/posener/complete/v2" {
log.Info("checkOverride() is ignoring", gopath)
return false
}
2024-12-03 13:24:41 -06:00
return false
}