Skip to content

Commit

Permalink
Fix not to recreate labels when update
Browse files Browse the repository at this point in the history
Close #173.
  • Loading branch information
shouichi committed Oct 21, 2019
1 parent 0a3a420 commit 4806d30
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 17 deletions.
28 changes: 14 additions & 14 deletions github/resource_github_issue_label.go
Original file line number Diff line number Diff line change
Expand Up @@ -80,10 +80,23 @@ func resourceGithubIssueLabelCreateOrUpdate(d *schema.ResourceData, meta interfa
ctx = context.WithValue(ctx, ctxId, d.Id())
}

// Pull out the original name. If we already have a resource, this is the
// parsed ID. If not, it's the value given to the resource.
var originalName string
if d.Id() == "" {
originalName = name
} else {
var err error
_, originalName, err = parseTwoPartID(d.Id())
if err != nil {
return err
}
}

log.Printf("[DEBUG] Querying label existence: %s (%s/%s)",
name, orgName, repoName)
existing, resp, err := client.Issues.GetLabel(ctx,
orgName, repoName, name)
orgName, repoName, originalName)
if err != nil && resp.StatusCode != http.StatusNotFound {
return err
}
Expand All @@ -94,19 +107,6 @@ func resourceGithubIssueLabelCreateOrUpdate(d *schema.ResourceData, meta interfa
log.Printf("[DEBUG] Updating label: %s:%s (%s/%s)",
name, color, orgName, repoName)

// Pull out the original name. If we already have a resource, this is the
// parsed ID. If not, it's the value given to the resource.
var originalName string
if d.Id() == "" {
originalName = name
} else {
var err error
_, originalName, err = parseTwoPartID(d.Id())
if err != nil {
return err
}
}

_, _, err := client.Issues.EditLabel(ctx,
orgName, repoName, originalName, label)
if err != nil {
Expand Down
16 changes: 13 additions & 3 deletions github/resource_github_issue_label_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import (
)

func TestAccGithubIssueLabel_basic(t *testing.T) {
var label github.Label
var label, updatedLabel github.Label

rn := "github_issue_label.test"
rString := acctest.RandString(5)
Expand All @@ -33,8 +33,9 @@ func TestAccGithubIssueLabel_basic(t *testing.T) {
{
Config: testAccGithubIssueLabelUpdateConfig(repoName),
Check: resource.ComposeTestCheckFunc(
testAccCheckGithubIssueLabelExists(rn, &label),
testAccCheckGithubIssueLabelAttributes(&label, "bar", "FFFFFF"),
testAccCheckGithubIssueLabelExists(rn, &updatedLabel),
testAccCheckGithubIssueLabelAttributes(&updatedLabel, "bar", "FFFFFF"),
testAccCheckGithubIssueLabelIDUnchanged(&label, &updatedLabel),
),
},
{
Expand Down Expand Up @@ -168,6 +169,15 @@ func testAccCheckGithubIssueLabelAttributes(label *github.Label, name, color str
}
}

func testAccCheckGithubIssueLabelIDUnchanged(label, updatedLabel *github.Label) resource.TestCheckFunc {
return func(_ *terraform.State) error {
if *label.ID != *updatedLabel.ID {
return fmt.Errorf("label was recreated")
}
return nil
}
}

func testAccGithubIssueLabelDestroy(s *terraform.State) error {
conn := testAccProvider.Meta().(*Organization).client

Expand Down

0 comments on commit 4806d30

Please sign in to comment.