make space and organization optional

This commit is contained in:
Ke Zhu 2014-04-20 10:35:50 -04:00
parent a0fce08fc3
commit 25f167b34a
2 changed files with 64 additions and 43 deletions

View file

@ -17,19 +17,19 @@ type CloudFoundry struct {
func (cf *CloudFoundry) Write(f *buildfile.Buildfile) {
// login
loginCmd := "cf login -a %s -u %s -p %s -o %s -s %s"
loginCmd := "cf login -a %s -u %s -p %s"
organization := cf.Org
if organization == "" {
organization = cf.Username
if organization != "" {
loginCmd += fmt.Sprintf(" -o %s", organization)
}
space := cf.Space
if space == "" {
space = "dev"
if space != "" {
loginCmd += fmt.Sprintf(" -s %s", space)
}
f.WriteCmdSilent(fmt.Sprintf(loginCmd, cf.Target, cf.Username, cf.Password, organization, space))
f.WriteCmdSilent(fmt.Sprintf(loginCmd, cf.Target, cf.Username, cf.Password))
// push app
pushCmd := "cf push %s"

View file

@ -31,6 +31,16 @@ deploy:
org: custom-org
`
var sampleYmlWithSpace = `
deploy:
cloudfoundry:
target: https://api.example.com
username: foo
password: bar
org: custom-org
space: dev
`
var sampleYmlWithAppName = `
deploy:
cloudfoundry:
@ -57,8 +67,8 @@ func TestCloudFoundryDeployment(t *testing.T) {
t.Fatalf("Can't unmarshal deploy script: %s", err)
}
if !strings.Contains(bscr, "cf login -a https://api.example.com -u foo -p bar -o foo -s dev") {
t.Error("Expect login script to contains default space")
if !strings.Contains(bscr, "cf login -a https://api.example.com -u foo -p bar") {
t.Error("Expect login script to contains username and password")
}
if !strings.Contains(bscr, "cf push") {
@ -77,6 +87,17 @@ func TestCloudFoundryDeploymentWithOrg(t *testing.T) {
}
}
func TestCloudFoundryDeploymentWithSpace(t *testing.T) {
bscr, err := setUpWithCF(sampleYmlWithSpace)
if err != nil {
t.Fatalf("Can't unmarshal deploy script: %s", err)
}
if !strings.Contains(bscr, "cf login -a https://api.example.com -u foo -p bar -o custom-org -s dev") {
t.Error("Expect login script to contains space")
}
}
func TestCloudFoundryDeploymentWithApp(t *testing.T) {
bscr, err := setUpWithCF(sampleYmlWithAppName)
if err != nil {