summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeff Carr <[email protected]>2024-12-01 15:10:55 -0600
committerJeff Carr <[email protected]>2024-12-01 15:10:55 -0600
commit82935ae6b2d413322b18a9b487973e5ab04e6efd (patch)
tree347ae7e15eea4c5186cfe4c307be67d488a533dd
parentfd3b806b4a1f647103c7ecb417cf1ffced9c4cb1 (diff)
attempt to detect new package dependancy versionsv0.0.14
-rw-r--r--currentVersions.go6
-rw-r--r--goDep.redoGoMod.go42
-rw-r--r--validate/argv.go6
-rw-r--r--validate/main.go42
4 files changed, 88 insertions, 8 deletions
diff --git a/currentVersions.go b/currentVersions.go
index 4cbaa72..d5a2212 100644
--- a/currentVersions.go
+++ b/currentVersions.go
@@ -35,7 +35,7 @@ func (repo *Repo) GetLastTag() string {
return result.Stdout[0]
}
-func (repo *Repo) GitMasterVersion() string {
+func (repo *Repo) GetMasterVersion() string {
bname := repo.GetMasterBranchName()
v, err := repo.gitVersionByName(bname)
/*
@@ -54,7 +54,7 @@ func (repo *Repo) GitMasterVersion() string {
}
}
-func (repo *Repo) GitDevelVersion() string {
+func (repo *Repo) GetDevelVersion() string {
bname := repo.GetDevelBranchName()
v, err := repo.gitVersionByName(bname)
if err == nil {
@@ -65,7 +65,7 @@ func (repo *Repo) GitDevelVersion() string {
}
}
-func (repo *Repo) GitUserVersion() string {
+func (repo *Repo) GetUserVersion() string {
bname := repo.GetUserBranchName()
if bname != "jcarr" {
panic("not jcarr bname =" + bname)
diff --git a/goDep.redoGoMod.go b/goDep.redoGoMod.go
index db64a1e..72249fe 100644
--- a/goDep.redoGoMod.go
+++ b/goDep.redoGoMod.go
@@ -202,3 +202,45 @@ func (repo *Repo) UpdatePublished() (bool, error) {
}
return true, nil
}
+
+// returns true if the last published
+func (repo *Repo) GoDepsLen() int {
+ if repo.GoDeps == nil {
+ return 0
+ }
+ return repo.GoDeps.Len()
+}
+
+// returns true if the last published
+func (repo *Repo) PublishedLen() int {
+ if repo.Published == nil {
+ return 0
+ }
+ return repo.Published.Len()
+}
+
+// returns true if the last published
+func (all *Repos) GoDepsChanged(repo *Repo) (bool, error) {
+ var match bool = true
+
+ if repo.GoDeps == nil {
+ repo.RedoGoMod()
+ }
+ if repo.GoDeps.Len() == 0 {
+ repo.RedoGoMod()
+ }
+ log.Printf("current repo %s go dependancy count: %d", repo.GetGoPath(), repo.GoDeps.Len())
+ deps := repo.GoDeps.SortByGoPath()
+ for deps.Scan() {
+ depRepo := deps.Next()
+ if repo.Published == nil {
+ return false, errors.New("repo published deps info is nil")
+ }
+ found := repo.Published.FindByGoPath(depRepo.GetGoPath())
+ if found == nil {
+ return true, errors.New("new repo added " + depRepo.GetGoPath())
+ }
+ log.Printf("deps %-50s %-10s vs %-10s", depRepo.GetGoPath(), depRepo.GetVersion(), found.GetVersion())
+ }
+ return match, nil
+}
diff --git a/validate/argv.go b/validate/argv.go
index b4150b4..c46149b 100644
--- a/validate/argv.go
+++ b/validate/argv.go
@@ -9,9 +9,9 @@ import (
var argv args
type args struct {
- List bool `arg:"--list" default:"false" help:"list repos in your config"`
- SaveConfig bool `arg:"--save" default:"false" help:"save your config file at the end"`
- Interesting bool `arg:"--interesting" default:"false" help:"something you decided was cool"`
+ List bool `arg:"--list" default:"false" help:"list repos in your config"`
+ SaveConfig bool `arg:"--save" default:"false" help:"save your config file at the end"`
+ Interesting bool `arg:"--interesting" default:"false" help:"something you decided was cool"`
}
func (a args) Description() string {
diff --git a/validate/main.go b/validate/main.go
index da709e0..57329ef 100644
--- a/validate/main.go
+++ b/validate/main.go
@@ -1,6 +1,7 @@
package main
import (
+ "fmt"
"os"
"go.wit.com/dev/alexflint/arg"
@@ -34,12 +35,49 @@ func main() {
repos := forge.Repos.SortByGoPath()
for repos.Scan() {
repo := repos.Next()
- forge.VerifyBranchNames(repo)
+ // forge.VerifyBranchNames(repo)
fullpath := repo.GetFullPath()
mName := repo.GetMasterBranchName()
dName := repo.GetDevelBranchName()
uName := repo.GetUserBranchName()
- log.Printf("repo: %-60s %-8s %-8s %-8s\n", fullpath, mName, dName, uName)
+ dlen := repo.GoDepsLen()
+ plen := repo.PublishedLen()
+ var ds, ps string
+ if dlen == 0 {
+ ds = ""
+ } else {
+ ds = fmt.Sprintf("%2d", dlen)
+ }
+ if plen == 0 {
+ ps = ""
+ } else {
+ ps = fmt.Sprintf("%2d", plen)
+ }
+ log.Printf("repo: %-60s %-10s %-8s %-8s %s %s\n", fullpath, mName, dName, uName, ds, ps)
+ /*
+ if repo.GoDepsChanged() {
+ log.Printf("\tdependancy checks indicate a new release is needed for %s\n", repo.GetGoPath())
+ } else {
+ log.Printf("\tdependancies have not changed for %s\n", repo.GetGoPath())
+ }
+ */
+ }
+
+ goclone := forge.Repos.FindByGoPath("go.wit.com/apps/go-clone")
+ if goclone == nil {
+ log.Info("boo, you didn't git go-clone?")
+ os.Exit(-1)
+ }
+
+ match, err := forge.Repos.GoDepsChanged(goclone)
+ if err != nil {
+ log.Info("dependancy checks failed", goclone.GetGoPath(), err)
+ os.Exit(-1)
+ }
+ if match {
+ log.Printf("dependancy checks indicate a new release is needed for %s\n", goclone.GetGoPath())
+ } else {
+ log.Printf("dependancies have not changed for %s\n", goclone.GetGoPath())
}
if argv.SaveConfig {