2024-02-09 11:50:16 -06:00
|
|
|
// This is a simple example
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"strings"
|
2024-12-11 01:19:07 -06:00
|
|
|
"time"
|
2024-02-09 11:50:16 -06:00
|
|
|
|
2024-11-08 06:45:12 -06:00
|
|
|
"github.com/go-cmd/cmd"
|
|
|
|
|
2024-02-14 16:06:52 -06:00
|
|
|
"go.wit.com/lib/gui/shell"
|
2024-02-09 11:50:16 -06:00
|
|
|
"go.wit.com/log"
|
|
|
|
)
|
|
|
|
|
2024-11-07 05:15:54 -06:00
|
|
|
func doRelease() bool {
|
|
|
|
log.Info("doRelease() on", me.current.Name())
|
2024-12-11 01:19:07 -06:00
|
|
|
if !findOk {
|
|
|
|
log.Info("doRelease() immediately end something went wrong last time. findOk == false")
|
|
|
|
return false
|
|
|
|
}
|
2024-02-14 12:14:33 -06:00
|
|
|
// double check release version logic
|
2024-02-20 16:11:00 -06:00
|
|
|
if me.release.releaseVersionB.String() != "release version "+me.release.version.String() {
|
|
|
|
log.Warn("something went wrong with the release.version:", me.release.version.String())
|
2024-02-09 11:50:16 -06:00
|
|
|
return false
|
|
|
|
}
|
2024-02-20 16:11:00 -06:00
|
|
|
if strings.HasPrefix(me.release.version.String(), "v") {
|
|
|
|
log.Warn("everything is ok. version starts with v.", me.release.version.String())
|
2024-02-09 11:50:16 -06:00
|
|
|
} else {
|
2024-02-20 16:11:00 -06:00
|
|
|
log.Warn("version does not start with v.", me.release.version.String())
|
2024-02-09 11:50:16 -06:00
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2024-11-16 04:59:21 -06:00
|
|
|
if shell.Exists("go.mod") {
|
|
|
|
log.Info("go.mod exists ok")
|
|
|
|
} else {
|
2024-12-13 19:00:20 -06:00
|
|
|
pwd, _ := os.Getwd()
|
|
|
|
log.Info("go.mod missing in working dir", pwd)
|
2024-12-02 05:13:17 -06:00
|
|
|
return false
|
2024-11-16 04:59:21 -06:00
|
|
|
}
|
|
|
|
|
2024-02-20 16:11:00 -06:00
|
|
|
curName := me.current.Status.GetCurrentBranchName()
|
|
|
|
mName := me.current.Status.GetMasterBranchName()
|
2024-02-09 11:50:16 -06:00
|
|
|
if curName != mName {
|
|
|
|
log.Info("\trepo is not working from main branch", curName, "!=", mName)
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2024-12-02 05:13:17 -06:00
|
|
|
check := me.forge.Repos.FindByGoPath(me.current.GoPath())
|
|
|
|
if check == nil {
|
|
|
|
log.Info("boo, you didn't git clone", me.current.GoPath())
|
|
|
|
return false
|
|
|
|
}
|
2024-12-02 08:45:13 -06:00
|
|
|
if !me.forge.FinalGoDepsCheckOk(check) {
|
|
|
|
log.Info("the go.mod file is wrong. fix it here?", check.GetGoPath())
|
|
|
|
os.Exit(-1)
|
2024-02-20 06:53:07 -06:00
|
|
|
return false
|
|
|
|
}
|
2024-12-13 20:32:07 -06:00
|
|
|
if check.GoPath == me.startRepo.GoPath {
|
|
|
|
log.Info("CAN NOT SELF UPDATE.", check.GoPath, "is the same as os.Getwd()")
|
|
|
|
log.Info("go get must be run from somewhere else other than startRepo")
|
|
|
|
log.Info("chdir to autotypist if it exists")
|
|
|
|
os.Exit(-1)
|
|
|
|
}
|
|
|
|
if !me.startRepo.Exists("go.mod") {
|
|
|
|
log.Info("go.sum missing in", me.startRepo.GoPath)
|
|
|
|
log.Info("pick a different repo here")
|
|
|
|
log.Info("todo: error out earlier knowing this will upgrade")
|
|
|
|
log.Info("versions", me.startRepo.GetTargetVersion(), me.startRepo.GetMasterVersion())
|
|
|
|
panic("redo go.sum")
|
|
|
|
}
|
2024-02-20 06:53:07 -06:00
|
|
|
|
2024-02-20 16:11:00 -06:00
|
|
|
log.Info("\ttag and push", curName, me.release.version.String(), me.releaseReasonS)
|
2024-02-09 11:50:16 -06:00
|
|
|
|
2024-12-13 16:19:12 -06:00
|
|
|
if err := check.ValidGoSum(); err != nil {
|
|
|
|
log.Info("ValidGoSum() error", check.GoPath, err)
|
|
|
|
os.Exit(-1)
|
|
|
|
}
|
|
|
|
|
2024-02-09 11:50:16 -06:00
|
|
|
var all [][]string
|
2024-12-13 16:19:12 -06:00
|
|
|
var autogen []string
|
2024-02-09 11:50:16 -06:00
|
|
|
all = append(all, []string{"git", "add", "-f", "go.mod"})
|
2024-12-13 16:19:12 -06:00
|
|
|
autogen = append(autogen, "go.mod")
|
|
|
|
if check.GoPrimitive {
|
2024-02-09 11:50:16 -06:00
|
|
|
// don't add go.sum here. TODO: check for go.sum file and fail
|
|
|
|
} else {
|
|
|
|
all = append(all, []string{"git", "add", "-f", "go.sum"})
|
2024-12-13 16:19:12 -06:00
|
|
|
autogen = append(autogen, "go.sum")
|
2024-02-09 11:50:16 -06:00
|
|
|
}
|
2024-11-29 23:18:03 -06:00
|
|
|
if ok, compiled, err := me.current.IsProtobuf(); ok {
|
2024-11-05 05:57:59 -06:00
|
|
|
log.Info("\tIsProtobuf() == true")
|
|
|
|
if err != nil {
|
|
|
|
log.Info("\tERROR: There are protobuf files, but they are not compiled")
|
|
|
|
log.Info("\tERROR: can not continue")
|
2024-11-06 20:28:31 -06:00
|
|
|
os.Exit(-1)
|
2024-11-05 05:57:59 -06:00
|
|
|
}
|
|
|
|
log.Info("\tshould add the protobuf files here")
|
2024-11-06 20:28:31 -06:00
|
|
|
log.Info("\tcompiled files found:", compiled)
|
|
|
|
for _, s := range compiled {
|
|
|
|
log.Info("\tcompiled file found:", s)
|
|
|
|
all = append(all, []string{"git", "add", "-f", s})
|
2024-12-13 16:19:12 -06:00
|
|
|
autogen = append(autogen, s)
|
2024-11-06 20:28:31 -06:00
|
|
|
}
|
2024-11-05 05:57:59 -06:00
|
|
|
} else {
|
|
|
|
log.Info("\tIsProtobuf() == false")
|
2024-11-05 04:46:59 -06:00
|
|
|
}
|
2024-02-09 11:50:16 -06:00
|
|
|
all = append(all, []string{"git", "commit", "-m", me.releaseReasonS})
|
|
|
|
all = append(all, []string{"git", "push"})
|
2024-02-20 16:11:00 -06:00
|
|
|
all = append(all, []string{"git", "tag", "-m", me.releaseReasonS, me.release.version.String()})
|
|
|
|
all = append(all, []string{"git", "push", "origin", me.release.version.String()})
|
2024-02-09 11:50:16 -06:00
|
|
|
|
2024-12-13 16:19:12 -06:00
|
|
|
// save the autogenerated files in git metadata (aka: notes)
|
|
|
|
cname := check.GetCurrentBranchName()
|
|
|
|
if err := check.AutogenSave(autogen, cname, true); err != nil {
|
|
|
|
log.Info("AutogenSave() error", err)
|
|
|
|
os.Exit(-1)
|
|
|
|
}
|
|
|
|
|
2024-02-20 16:11:00 -06:00
|
|
|
if !me.current.Status.DoAll(all) {
|
|
|
|
log.Info("failed to make new release", me.release.version.String())
|
2024-12-11 01:19:07 -06:00
|
|
|
findOk = false
|
2024-02-14 12:14:33 -06:00
|
|
|
return false
|
|
|
|
}
|
|
|
|
log.Info("RELEASE OK")
|
|
|
|
|
|
|
|
// 'publish' the version to the golang package versioning system
|
|
|
|
if !doPublishVersion() {
|
2024-12-11 01:19:07 -06:00
|
|
|
time.Sleep(3 * time.Second)
|
|
|
|
// this can fail to update, try it again after sleep(3s)
|
|
|
|
if !doPublishVersion() {
|
|
|
|
log.Info("PUBLISH FAILED")
|
|
|
|
findOk = false
|
|
|
|
return false
|
|
|
|
}
|
2024-02-14 12:14:33 -06:00
|
|
|
}
|
|
|
|
|
2024-12-02 07:00:28 -06:00
|
|
|
pb := me.forge.Repos.FindByGoPath(me.current.GoPath())
|
|
|
|
if pb != nil {
|
|
|
|
pb.UpdatePublished()
|
2024-12-03 22:35:19 -06:00
|
|
|
/* remove. earlier protected against nil
|
|
|
|
if !pb.IsPrimitive() {
|
2024-12-02 07:00:28 -06:00
|
|
|
loop := pb.Published.SortByGoPath()
|
|
|
|
for loop.Scan() {
|
|
|
|
t := loop.Next()
|
|
|
|
log.Info("new Published dep:", t.GetGoPath(), t.GetVersion())
|
|
|
|
}
|
|
|
|
}
|
2024-12-03 22:35:19 -06:00
|
|
|
*/
|
2024-12-02 07:00:28 -06:00
|
|
|
me.forge.Repos.ConfigSave()
|
|
|
|
}
|
|
|
|
|
2024-02-14 12:14:33 -06:00
|
|
|
log.Info("PUBLISH OK")
|
2024-02-29 21:57:13 -06:00
|
|
|
// me.current.SetGoState("RELEASED")
|
2024-02-14 12:14:33 -06:00
|
|
|
|
|
|
|
// unwind and re-tag. Now that the go.mod and go.sum are published, revert
|
|
|
|
// to the development branch
|
2024-02-20 16:11:00 -06:00
|
|
|
if !me.current.Status.RevertMasterToDevel() {
|
2024-02-14 12:14:33 -06:00
|
|
|
log.Info("Revert Failed")
|
2024-12-11 01:19:07 -06:00
|
|
|
findOk = false
|
2024-02-14 12:14:33 -06:00
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
// update tag
|
|
|
|
var retag [][]string
|
2024-02-20 16:11:00 -06:00
|
|
|
retag = append(retag, []string{"git", "tag", "--delete", me.release.version.String()})
|
|
|
|
retag = append(retag, []string{"git", "push", "--delete", "origin", me.release.version.String()})
|
|
|
|
retag = append(retag, []string{"git", "tag", "-m", me.releaseReasonS, me.release.version.String()})
|
|
|
|
retag = append(retag, []string{"git", "push", "origin", me.release.version.String()})
|
2024-02-14 12:14:33 -06:00
|
|
|
|
2024-12-13 16:19:12 -06:00
|
|
|
if err := check.AutogenRestore(cname); err != nil {
|
|
|
|
log.Info("AutogenRestore() failed", err)
|
|
|
|
}
|
|
|
|
|
2024-02-20 16:11:00 -06:00
|
|
|
if !me.current.Status.DoAll(retag) {
|
2024-02-14 12:14:33 -06:00
|
|
|
log.Info("retag failed")
|
2024-12-11 01:19:07 -06:00
|
|
|
findOk = false
|
2024-02-14 12:14:33 -06:00
|
|
|
return false
|
|
|
|
}
|
2024-02-20 16:11:00 -06:00
|
|
|
log.Info("EVERYTHING OK. RERELEASED", me.current.Name())
|
2024-02-14 12:14:33 -06:00
|
|
|
|
2024-12-13 19:00:20 -06:00
|
|
|
// save autogen files under the tag version (for example: "v0.2.3")
|
|
|
|
newtag := me.release.version.String()
|
|
|
|
if err := check.AutogenSave(autogen, newtag, true); err != nil {
|
|
|
|
log.Info("AutogenSave() error", err)
|
|
|
|
os.Exit(-1)
|
|
|
|
}
|
|
|
|
|
2024-12-02 08:45:13 -06:00
|
|
|
// it's necessary to recreate the the files here
|
|
|
|
// safe to do this here. everything has been published
|
2024-12-03 03:18:27 -06:00
|
|
|
fixGodeps(check)
|
2024-12-02 07:00:28 -06:00
|
|
|
|
2024-02-14 12:14:33 -06:00
|
|
|
// update the values in the GUI
|
2024-02-20 16:11:00 -06:00
|
|
|
me.current.NewScan()
|
2024-02-14 12:14:33 -06:00
|
|
|
|
|
|
|
// attempt to find another repo to release
|
2024-02-14 16:06:52 -06:00
|
|
|
if !doReleaseFindNext() {
|
2024-12-13 20:32:07 -06:00
|
|
|
log.Info("doReleaseFindNext() could not find a new", findCounter)
|
|
|
|
log.Info("THIS PROBABLY MEANS THAT ACTUALLY WE ARE TOTALLY DONE?", findCounter)
|
|
|
|
count := PrintReleaseReport("", "")
|
|
|
|
log.Info("count =", count)
|
2024-11-17 06:26:25 -06:00
|
|
|
os.Setenv("FindNextDone", "true")
|
2024-02-14 12:14:33 -06:00
|
|
|
return false
|
|
|
|
}
|
2024-02-20 16:11:00 -06:00
|
|
|
log.Info("GOOD TO RUN ANOTHER DAY ON:", me.current.Name())
|
2024-02-14 12:14:33 -06:00
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
// try to figure out if there is another package to update
|
2024-12-02 08:45:13 -06:00
|
|
|
// returns true if it finds something
|
2024-02-14 12:14:33 -06:00
|
|
|
func doReleaseFindNext() bool {
|
|
|
|
// scan for new repo
|
2024-02-20 20:42:54 -06:00
|
|
|
if findNext() {
|
|
|
|
log.Info("findNext() found something")
|
2024-02-14 12:14:33 -06:00
|
|
|
} else {
|
2024-12-02 10:43:48 -06:00
|
|
|
// this means findNext() didn't find anything but there are
|
|
|
|
// still packages to release. start trying to fix the go.sum files
|
|
|
|
if findCounter != 0 {
|
|
|
|
findFix = true
|
|
|
|
}
|
2024-02-20 20:42:54 -06:00
|
|
|
log.Info("findNext() could not find anything")
|
2024-02-14 12:14:33 -06:00
|
|
|
return false
|
|
|
|
}
|
2024-12-02 05:13:17 -06:00
|
|
|
check := me.forge.Repos.FindByGoPath(me.current.GoPath())
|
|
|
|
if check == nil {
|
|
|
|
log.Info("boo, you didn't git clone", me.current.GoPath())
|
|
|
|
return false
|
|
|
|
}
|
2024-12-02 10:43:48 -06:00
|
|
|
if findFix {
|
2024-12-03 03:18:27 -06:00
|
|
|
fixGodeps(check)
|
2024-12-02 10:43:48 -06:00
|
|
|
}
|
2024-12-02 08:45:13 -06:00
|
|
|
if me.forge.FinalGoDepsCheckOk(check) {
|
|
|
|
// the go.sum file is ok to release
|
2024-02-14 12:14:33 -06:00
|
|
|
return true
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
// this pulls the new tag from the golang package repository
|
|
|
|
// to insert the new version
|
|
|
|
func doPublishVersion() bool {
|
2024-02-20 16:11:00 -06:00
|
|
|
gopath := me.current.GoPath()
|
2024-11-08 06:45:12 -06:00
|
|
|
docmd := []string{"go", "get", "-v", gopath + "@" + me.release.version.String()}
|
|
|
|
log.Info("SHOULD RUN cmd HERE:", docmd)
|
2024-02-14 12:14:33 -06:00
|
|
|
|
2024-02-23 11:31:07 -06:00
|
|
|
if me.current.Status.IsPrivate() {
|
|
|
|
// do not self update private repos
|
2024-11-08 06:45:12 -06:00
|
|
|
log.Info("This is a private repo and can not be self checked")
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
// try to pull from google
|
|
|
|
var result cmd.Status
|
2024-12-13 19:30:12 -06:00
|
|
|
if gopath == me.startRepo.GoPath {
|
2024-11-08 06:45:12 -06:00
|
|
|
log.Info("CAN NOT SELF UPDATE. cmd =", docmd)
|
2024-12-13 20:32:07 -06:00
|
|
|
log.Info("go get must be run from somewhere else other than startRepo")
|
2024-11-22 21:22:07 -06:00
|
|
|
log.Info("chdir to autotypist if it exists")
|
2024-12-13 19:30:12 -06:00
|
|
|
os.Exit(-1)
|
2024-11-08 06:45:12 -06:00
|
|
|
}
|
2024-12-13 19:30:12 -06:00
|
|
|
// publish go.mod & go.sum for use with go
|
|
|
|
os.Unsetenv("GO111MODULE")
|
|
|
|
log.Info("TRYING TO SELF UPDATE HERE. cmd =", docmd)
|
|
|
|
result = me.startRepo.Run(docmd)
|
|
|
|
|
2024-11-08 06:45:12 -06:00
|
|
|
if result.Error != nil {
|
|
|
|
log.Info("SELF UPDATE FAILED. error =", result.Error)
|
|
|
|
log.Info("SELF UPDATE FAILED. exit =", result.Exit)
|
|
|
|
log.Info("SELF UPDATE FAILED. out =", result.Stdout)
|
|
|
|
log.Info("SELF UPDATE FAILED")
|
|
|
|
return false
|
2024-02-14 12:14:33 -06:00
|
|
|
}
|
2024-11-08 06:45:12 -06:00
|
|
|
if result.Exit != 0 {
|
|
|
|
log.Info("SELF UPDATE FAILED. error =", result.Error)
|
|
|
|
log.Info("SELF UPDATE FAILED. exit =", result.Exit)
|
|
|
|
log.Info("SELF UPDATE FAILED. out =", result.Stdout)
|
|
|
|
log.Info("SELF UPDATE FAILED")
|
|
|
|
return false
|
2024-02-14 12:14:33 -06:00
|
|
|
}
|
2024-12-13 19:30:12 -06:00
|
|
|
log.Info("SELF UPDATE OK. out =", strings.Join(result.Stdout, "\n"))
|
2024-11-08 06:45:12 -06:00
|
|
|
log.Info("SELF UPDATE WORKED")
|
|
|
|
return true
|
2024-02-09 11:50:16 -06:00
|
|
|
}
|