mirror of
https://github.com/harness/drone.git
synced 2025-05-19 10:29:55 +08:00
Merge pull request #52 from antonlindstrom/feature-deploy-git
Implement feature git deploy
This commit is contained in:
commit
0c36b42f69
@ -12,6 +12,7 @@ type Deploy struct {
|
|||||||
CloudControl *CloudControl `yaml:"cloudcontrol,omitempty"`
|
CloudControl *CloudControl `yaml:"cloudcontrol,omitempty"`
|
||||||
CloudFoundry *CloudFoundry `yaml:"cloudfoundry,omitempty"`
|
CloudFoundry *CloudFoundry `yaml:"cloudfoundry,omitempty"`
|
||||||
EngineYard *EngineYard `yaml:"engineyard,omitempty"`
|
EngineYard *EngineYard `yaml:"engineyard,omitempty"`
|
||||||
|
Git *Git `yaml:"git,omitempty"`
|
||||||
Heroku *Heroku `yaml:"heroku,omitempty"`
|
Heroku *Heroku `yaml:"heroku,omitempty"`
|
||||||
Nodejitsu *Nodejitsu `yaml:"nodejitsu,omitempty"`
|
Nodejitsu *Nodejitsu `yaml:"nodejitsu,omitempty"`
|
||||||
Openshift *Openshift `yaml:"openshift,omitempty"`
|
Openshift *Openshift `yaml:"openshift,omitempty"`
|
||||||
@ -30,6 +31,9 @@ func (d *Deploy) Write(f *buildfile.Buildfile) {
|
|||||||
if d.EngineYard != nil {
|
if d.EngineYard != nil {
|
||||||
d.EngineYard.Write(f)
|
d.EngineYard.Write(f)
|
||||||
}
|
}
|
||||||
|
if d.Git != nil {
|
||||||
|
d.Git.Write(f)
|
||||||
|
}
|
||||||
if d.Heroku != nil {
|
if d.Heroku != nil {
|
||||||
d.Heroku.Write(f)
|
d.Heroku.Write(f)
|
||||||
}
|
}
|
||||||
|
@ -1 +1,38 @@
|
|||||||
package deploy
|
package deploy
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"github.com/drone/drone/pkg/build/buildfile"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Git struct {
|
||||||
|
Target string `yaml:"target,omitempty"`
|
||||||
|
Force bool `yaml:"force,omitempty"`
|
||||||
|
Branch string `yaml:"branch,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (g *Git) Write(f *buildfile.Buildfile) {
|
||||||
|
// get the current commit hash
|
||||||
|
f.WriteCmdSilent("COMMIT=$(git rev-parse HEAD)")
|
||||||
|
|
||||||
|
// set the git user and email based on the individual
|
||||||
|
// that made the commit.
|
||||||
|
f.WriteCmdSilent("git config --global user.name $(git --no-pager log -1 --pretty=format:'%an')")
|
||||||
|
f.WriteCmdSilent("git config --global user.email $(git --no-pager log -1 --pretty=format:'%ae')")
|
||||||
|
|
||||||
|
// add target as a git remote
|
||||||
|
f.WriteCmd(fmt.Sprintf("git remote add deploy %s", g.Target))
|
||||||
|
|
||||||
|
switch g.Force {
|
||||||
|
case true:
|
||||||
|
// this is useful when the there are artifacts generated
|
||||||
|
// by the build script, such as less files converted to css,
|
||||||
|
// that need to be deployed to git remote.
|
||||||
|
f.WriteCmd(fmt.Sprintf("git add -A"))
|
||||||
|
f.WriteCmd(fmt.Sprintf("git commit -m 'add build artifacts'"))
|
||||||
|
f.WriteCmd(fmt.Sprintf("git push deploy $COMMIT:master --force"))
|
||||||
|
case false:
|
||||||
|
// otherwise we just do a standard git push
|
||||||
|
f.WriteCmd(fmt.Sprintf("git push deploy $COMMIT:master"))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user