command/plan: refresh by default
This commit is contained in:
parent
fa3ac806cc
commit
0a8cebdb82
|
@ -19,9 +19,11 @@ type PlanCommand struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *PlanCommand) Run(args []string) int {
|
func (c *PlanCommand) Run(args []string) int {
|
||||||
|
var refresh bool
|
||||||
var statePath string
|
var statePath string
|
||||||
|
|
||||||
cmdFlags := flag.NewFlagSet("plan", flag.ContinueOnError)
|
cmdFlags := flag.NewFlagSet("plan", flag.ContinueOnError)
|
||||||
|
cmdFlags.BoolVar(&refresh, "refresh", true, "refresh")
|
||||||
cmdFlags.StringVar(&statePath, "state", "", "path")
|
cmdFlags.StringVar(&statePath, "state", "", "path")
|
||||||
cmdFlags.Usage = func() { c.Ui.Error(c.Help()) }
|
cmdFlags.Usage = func() { c.Ui.Error(c.Help()) }
|
||||||
if err := cmdFlags.Parse(args); err != nil {
|
if err := cmdFlags.Parse(args); err != nil {
|
||||||
|
@ -66,6 +68,14 @@ func (c *PlanCommand) Run(args []string) int {
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if refresh {
|
||||||
|
state, err = tf.Refresh(b, state)
|
||||||
|
if err != nil {
|
||||||
|
c.Ui.Error(fmt.Sprintf("Error refreshing state: %s", err))
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
plan, err := tf.Plan(b, state, nil)
|
plan, err := tf.Plan(b, state, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
c.Ui.Error(fmt.Sprintf("Error running plan: %s", err))
|
c.Ui.Error(fmt.Sprintf("Error running plan: %s", err))
|
||||||
|
@ -90,6 +100,8 @@ Usage: terraform plan [options] [terraform.tf]
|
||||||
|
|
||||||
Options:
|
Options:
|
||||||
|
|
||||||
|
-refresh=true Update state prior to checking for differences.
|
||||||
|
|
||||||
-state=statefile Path to a Terraform state file to use to look
|
-state=statefile Path to a Terraform state file to use to look
|
||||||
up Terraform-managed resources.
|
up Terraform-managed resources.
|
||||||
|
|
||||||
|
|
|
@ -25,6 +25,11 @@ func TestPlan_noState(t *testing.T) {
|
||||||
t.Fatalf("bad: %d\n\n%s", code, ui.ErrorWriter.String())
|
t.Fatalf("bad: %d\n\n%s", code, ui.ErrorWriter.String())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Verify that refresh was called
|
||||||
|
if !p.RefreshCalled {
|
||||||
|
t.Fatal("refresh should be called")
|
||||||
|
}
|
||||||
|
|
||||||
// Verify that the provider was called with the existing state
|
// Verify that the provider was called with the existing state
|
||||||
expectedState := &terraform.ResourceState{
|
expectedState := &terraform.ResourceState{
|
||||||
Type: "test_instance",
|
Type: "test_instance",
|
||||||
|
@ -34,6 +39,27 @@ func TestPlan_noState(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestPlan_refresh(t *testing.T) {
|
||||||
|
p := testProvider()
|
||||||
|
ui := new(cli.MockUi)
|
||||||
|
c := &PlanCommand{
|
||||||
|
TFConfig: testTFConfig(p),
|
||||||
|
Ui: ui,
|
||||||
|
}
|
||||||
|
|
||||||
|
args := []string{
|
||||||
|
"-refresh=false",
|
||||||
|
testFixturePath("plan"),
|
||||||
|
}
|
||||||
|
if code := c.Run(args); code != 0 {
|
||||||
|
t.Fatalf("bad: %d\n\n%s", code, ui.ErrorWriter.String())
|
||||||
|
}
|
||||||
|
|
||||||
|
if p.RefreshCalled {
|
||||||
|
t.Fatal("refresh should not be called")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func TestPlan_state(t *testing.T) {
|
func TestPlan_state(t *testing.T) {
|
||||||
// Write out some prior state
|
// Write out some prior state
|
||||||
tf, err := ioutil.TempFile("", "tf")
|
tf, err := ioutil.TempFile("", "tf")
|
||||||
|
|
Loading…
Reference in New Issue