mirror of
https://github.com/rocky-linux/peridot.git
synced 2024-06-12 23:40:15 +00:00
106 lines
3.9 KiB
Go
106 lines
3.9 KiB
Go
|
// Copyright (c) All respective contributors to the Peridot Project. All rights reserved.
|
||
|
// Copyright (c) 2021-2022 Rocky Enterprise Software Foundation, Inc. All rights reserved.
|
||
|
// Copyright (c) 2021-2022 Ctrl IQ, Inc. All rights reserved.
|
||
|
//
|
||
|
// Redistribution and use in source and binary forms, with or without
|
||
|
// modification, are permitted provided that the following conditions are met:
|
||
|
//
|
||
|
// 1. Redistributions of source code must retain the above copyright notice,
|
||
|
// this list of conditions and the following disclaimer.
|
||
|
//
|
||
|
// 2. Redistributions in binary form must reproduce the above copyright notice,
|
||
|
// this list of conditions and the following disclaimer in the documentation
|
||
|
// and/or other materials provided with the distribution.
|
||
|
//
|
||
|
// 3. Neither the name of the copyright holder nor the names of its contributors
|
||
|
// may be used to endorse or promote products derived from this software without
|
||
|
// specific prior written permission.
|
||
|
//
|
||
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||
|
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||
|
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||
|
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||
|
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||
|
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||
|
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||
|
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||
|
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||
|
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||
|
// POSSIBILITY OF SUCH DAMAGE.
|
||
|
|
||
|
package main
|
||
|
|
||
|
import (
|
||
|
"github.com/spf13/cobra"
|
||
|
"log"
|
||
|
"openapi.peridot.resf.org/peridotopenapi"
|
||
|
"time"
|
||
|
)
|
||
|
|
||
|
var buildPackage = &cobra.Command{
|
||
|
Use: "package [name]",
|
||
|
Args: cobra.ExactArgs(1),
|
||
|
Run: buildPackageMn,
|
||
|
}
|
||
|
|
||
|
var (
|
||
|
scmHash string
|
||
|
disableChecks bool
|
||
|
branches []string
|
||
|
moduleVariant bool
|
||
|
sideNvrs []string
|
||
|
setInactive bool
|
||
|
)
|
||
|
|
||
|
func init() {
|
||
|
build.Flags().StringVar(&scmHash, "scm-hash", "", "SCM hash to build")
|
||
|
build.Flags().BoolVar(&disableChecks, "disable-checks", false, "Disable checks / tests")
|
||
|
build.Flags().StringSliceVar(&branches, "branches", []string{}, "Branches to build (only for module builds)")
|
||
|
build.Flags().BoolVar(&moduleVariant, "module-variant", false, "Build a module variant")
|
||
|
build.Flags().StringSliceVar(&sideNvrs, "side-nvrs", []string{}, "Side NVRs to include")
|
||
|
build.Flags().BoolVar(&setInactive, "set-inactive", false, "Set build as inactive")
|
||
|
}
|
||
|
|
||
|
func buildPackageMn(_ *cobra.Command, args []string) {
|
||
|
// Ensure project id exists
|
||
|
projectId := mustGetProjectID()
|
||
|
|
||
|
buildCl := getClient(serviceBuild).(peridotopenapi.BuildServiceApi)
|
||
|
body := peridotopenapi.InlineObject2{
|
||
|
PackageName: &args[0],
|
||
|
DisableChecks: &disableChecks,
|
||
|
Branches: &branches,
|
||
|
ModuleVariant: &moduleVariant,
|
||
|
SideNvrs: &sideNvrs,
|
||
|
SetInactive: &setInactive,
|
||
|
}
|
||
|
if scmHash != "" {
|
||
|
body.ScmHash = &scmHash
|
||
|
}
|
||
|
req := buildCl.SubmitBuild(getContext(), projectId).Body(body)
|
||
|
buildRes, _, err := req.Execute()
|
||
|
errFatal(err)
|
||
|
|
||
|
// Wait for build to finish
|
||
|
taskCl := getClient(serviceTask).(peridotopenapi.TaskServiceApi)
|
||
|
log.Printf("Waiting for build %s to finish\n", buildRes.GetTaskId())
|
||
|
for {
|
||
|
res, _, err := taskCl.GetTask(getContext(), projectId, buildRes.GetTaskId()).Execute()
|
||
|
if err != nil {
|
||
|
log.Printf("Error getting task: %s", err.Error())
|
||
|
time.Sleep(5 * time.Second)
|
||
|
}
|
||
|
task := res.GetTask()
|
||
|
if task.GetDone() {
|
||
|
if task.GetSubtasks()[0].GetStatus() == peridotopenapi.SUCCEEDED {
|
||
|
log.Printf("Build %s finished successfully\n", buildRes.GetTaskId())
|
||
|
break
|
||
|
} else {
|
||
|
log.Fatalf("Build %s failed with status %s\n", buildRes.GetTaskId(), task.GetSubtasks()[0].GetStatus())
|
||
|
}
|
||
|
}
|
||
|
|
||
|
time.Sleep(5 * time.Second)
|
||
|
}
|
||
|
}
|