mirror of
https://github.com/SAP/jenkins-library.git
synced 2024-12-14 11:03:09 +02:00
147 lines
4.1 KiB
Go
147 lines
4.1 KiB
Go
|
package versioning
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
"io/ioutil"
|
||
|
"os"
|
||
|
"regexp"
|
||
|
"strings"
|
||
|
|
||
|
"github.com/pkg/errors"
|
||
|
)
|
||
|
|
||
|
const (
|
||
|
// NameRegex is used to match the pip descriptor artifact name
|
||
|
NameRegex = "(?s)(.*)name=['\"](.*?)['\"](.*)"
|
||
|
// VersionRegex is used to match the pip descriptor artifact version
|
||
|
VersionRegex = "(?s)(.*)version=['\"](.*?)['\"](.*)"
|
||
|
)
|
||
|
|
||
|
// PipDescriptor holds the unique identifier combination for pip built Python artifacts
|
||
|
type PipDescriptor struct {
|
||
|
GroupID string
|
||
|
ArtifactID string
|
||
|
Version string
|
||
|
Packaging string
|
||
|
}
|
||
|
|
||
|
// Pip utility to interact with Python specific versioning
|
||
|
type Pip struct {
|
||
|
path string
|
||
|
readFile func(string) ([]byte, error)
|
||
|
writeFile func(string, []byte, os.FileMode) error
|
||
|
fileExists func(string) (bool, error)
|
||
|
buildDescriptorContent string
|
||
|
}
|
||
|
|
||
|
func (p *Pip) init() error {
|
||
|
if p.readFile == nil {
|
||
|
p.readFile = ioutil.ReadFile
|
||
|
}
|
||
|
|
||
|
if p.writeFile == nil {
|
||
|
p.writeFile = ioutil.WriteFile
|
||
|
}
|
||
|
|
||
|
if len(p.buildDescriptorContent) > 0 {
|
||
|
content, err := p.readFile(p.path)
|
||
|
if err != nil {
|
||
|
return errors.Wrapf(err, "failed to read file '%v'", p.path)
|
||
|
}
|
||
|
p.buildDescriptorContent = string(content)
|
||
|
}
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
// GetVersion returns the Pip descriptor version property
|
||
|
func (p *Pip) GetVersion() (string, error) {
|
||
|
buildDescriptorFilePath := p.path
|
||
|
var err error
|
||
|
if strings.Contains(p.path, "setup.py") {
|
||
|
buildDescriptorFilePath, err = searchDescriptor([]string{"version.txt", "VERSION"}, p.fileExists)
|
||
|
if err != nil {
|
||
|
err = p.init()
|
||
|
if err != nil {
|
||
|
return "", errors.Wrapf(err, "failed to read file '%v'", p.path)
|
||
|
}
|
||
|
if evaluateResult(p.buildDescriptorContent, VersionRegex) {
|
||
|
compile := regexp.MustCompile(VersionRegex)
|
||
|
values := compile.FindStringSubmatch(p.buildDescriptorContent)
|
||
|
return values[2], nil
|
||
|
}
|
||
|
return "", errors.Wrap(err, "failed to retrieve version")
|
||
|
}
|
||
|
}
|
||
|
artifact := &Versionfile{
|
||
|
path: buildDescriptorFilePath,
|
||
|
versioningScheme: p.VersioningScheme(),
|
||
|
}
|
||
|
return artifact.GetVersion()
|
||
|
}
|
||
|
|
||
|
// SetVersion sets the Pip descriptor version property
|
||
|
func (p *Pip) SetVersion(v string) error {
|
||
|
buildDescriptorFilePath := p.path
|
||
|
var err error
|
||
|
if strings.Contains(p.path, "setup.py") {
|
||
|
buildDescriptorFilePath, err = searchDescriptor([]string{"version.txt", "VERSION"}, p.fileExists)
|
||
|
if err != nil {
|
||
|
err = p.init()
|
||
|
if err != nil {
|
||
|
return errors.Wrapf(err, "failed to read file '%v'", p.path)
|
||
|
}
|
||
|
if evaluateResult(p.buildDescriptorContent, VersionRegex) {
|
||
|
compile := regexp.MustCompile(VersionRegex)
|
||
|
values := compile.FindStringSubmatch(p.buildDescriptorContent)
|
||
|
p.buildDescriptorContent = strings.ReplaceAll(p.buildDescriptorContent, fmt.Sprintf("version='%v'", values[2]), fmt.Sprintf("version='%v'", v))
|
||
|
p.buildDescriptorContent = strings.ReplaceAll(p.buildDescriptorContent, fmt.Sprintf("version=\"%v\"", values[2]), fmt.Sprintf("version=\"%v\"", v))
|
||
|
p.writeFile(p.path, []byte(p.buildDescriptorContent), 0600)
|
||
|
} else {
|
||
|
return errors.Wrap(err, "failed to retrieve version")
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
artifact := &Versionfile{
|
||
|
path: buildDescriptorFilePath,
|
||
|
versioningScheme: p.VersioningScheme(),
|
||
|
}
|
||
|
return artifact.SetVersion(v)
|
||
|
}
|
||
|
|
||
|
// VersioningScheme returns the relevant versioning scheme
|
||
|
func (p *Pip) VersioningScheme() string {
|
||
|
return "pep440"
|
||
|
}
|
||
|
|
||
|
// GetCoordinates returns the pip build descriptor coordinates
|
||
|
func (p *Pip) GetCoordinates() (Coordinates, error) {
|
||
|
err := p.init()
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
|
||
|
descriptor := &PipDescriptor{}
|
||
|
if evaluateResult(p.buildDescriptorContent, NameRegex) {
|
||
|
compile := regexp.MustCompile(NameRegex)
|
||
|
values := compile.FindStringSubmatch(p.buildDescriptorContent)
|
||
|
descriptor.ArtifactID = values[2]
|
||
|
} else {
|
||
|
descriptor.ArtifactID = ""
|
||
|
}
|
||
|
|
||
|
descriptor.Version, err = p.GetVersion()
|
||
|
if err != nil {
|
||
|
return nil, errors.Wrap(err, "failed to retrieve coordinates")
|
||
|
}
|
||
|
|
||
|
return descriptor, nil
|
||
|
}
|
||
|
|
||
|
func evaluateResult(value, regex string) bool {
|
||
|
if len(value) > 0 {
|
||
|
match, _ := regexp.MatchString(regex, value)
|
||
|
return match
|
||
|
}
|
||
|
return true
|
||
|
}
|