You've already forked go-semantic-release
feat(internal/releaser): add SetReleaseType Method to Releaser interface
This commit is contained in:
@@ -19,11 +19,12 @@ const GITHUB = "github"
|
|||||||
|
|
||||||
// Client type struct
|
// Client type struct
|
||||||
type Client struct {
|
type Client struct {
|
||||||
config *config.GitHubProvider
|
config *config.GitHubProvider
|
||||||
client *github.Client
|
client *github.Client
|
||||||
context context.Context
|
context context.Context
|
||||||
release *github.RepositoryRelease
|
release *github.RepositoryRelease
|
||||||
baseURL string
|
draft, prerelease bool
|
||||||
|
baseURL string
|
||||||
}
|
}
|
||||||
|
|
||||||
// New initialize a new GitHubRelease
|
// New initialize a new GitHubRelease
|
||||||
@@ -64,6 +65,18 @@ func (g Client) GetCompareURL(oldVersion, newVersion string) string {
|
|||||||
return fmt.Sprintf("%s/%s/%s/compare/%s...%s", g.baseURL, g.config.User, g.config.Repo, oldVersion, newVersion)
|
return fmt.Sprintf("%s/%s/%s/compare/%s...%s", g.baseURL, g.config.User, g.config.Repo, oldVersion, newVersion)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//SetReleaseType sets the provider release type
|
||||||
|
func (g Client) SetReleaseType(releaseVersion *shared.ReleaseVersion) {
|
||||||
|
if !releaseVersion.Next.Draft {
|
||||||
|
log.Debugf("Set release as draft")
|
||||||
|
g.draft = true
|
||||||
|
}
|
||||||
|
if releaseVersion.Next.Prerelease() != "" {
|
||||||
|
log.Debugf("Set release as prerelease")
|
||||||
|
g.prerelease = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//ValidateConfig for github
|
//ValidateConfig for github
|
||||||
func (g Client) ValidateConfig() error {
|
func (g Client) ValidateConfig() error {
|
||||||
log.Debugf("validate GitHub provider config")
|
log.Debugf("validate GitHub provider config")
|
||||||
@@ -83,16 +96,16 @@ func (g Client) ValidateConfig() error {
|
|||||||
// CreateRelease creates release on remote
|
// CreateRelease creates release on remote
|
||||||
func (g Client) CreateRelease(releaseVersion *shared.ReleaseVersion, generatedChangelog *shared.GeneratedChangelog) error {
|
func (g Client) CreateRelease(releaseVersion *shared.ReleaseVersion, generatedChangelog *shared.GeneratedChangelog) error {
|
||||||
|
|
||||||
tag := releaseVersion.Next.Version.String()
|
tag := releaseVersion.Next.String()
|
||||||
log.Debugf("create relase with for version %s", tag)
|
log.Debugf("create release witth version %s", tag)
|
||||||
prerelease := releaseVersion.Next.Version.Prerelease() != ""
|
|
||||||
release, resp, err := g.client.Repositories.CreateRelease(g.context, g.config.User, g.config.Repo, &github.RepositoryRelease{
|
release, resp, err := g.client.Repositories.CreateRelease(g.context, g.config.User, g.config.Repo, &github.RepositoryRelease{
|
||||||
TagName: &tag,
|
TagName: &tag,
|
||||||
TargetCommitish: &releaseVersion.Branch,
|
TargetCommitish: &releaseVersion.Branch,
|
||||||
Name: &generatedChangelog.Title,
|
Name: &generatedChangelog.Title,
|
||||||
Body: &generatedChangelog.Content,
|
Body: &generatedChangelog.Content,
|
||||||
Draft: &prerelease,
|
Draft: &g.draft,
|
||||||
Prerelease: &prerelease,
|
Prerelease: &g.prerelease,
|
||||||
})
|
})
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|||||||
@@ -22,6 +22,7 @@ type Releaser interface {
|
|||||||
UploadAssets(assets []config.Asset) error
|
UploadAssets(assets []config.Asset) error
|
||||||
GetCommitURL() string
|
GetCommitURL() string
|
||||||
GetCompareURL(oldVersion, newVersion string) string
|
GetCompareURL(oldVersion, newVersion string) string
|
||||||
|
SetReleaseType(*shared.ReleaseVersion)
|
||||||
}
|
}
|
||||||
|
|
||||||
// New initialize a Relerser
|
// New initialize a Relerser
|
||||||
|
|||||||
@@ -242,6 +242,8 @@ func (s *SemanticRelease) Release(force bool) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
releaser.SetReleaseType(releaseVersion)
|
||||||
|
|
||||||
if err = releaser.CreateRelease(releaseVersion, generatedChanglog); err != nil {
|
if err = releaser.CreateRelease(releaseVersion, generatedChanglog); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user