Fix updating user records to use correct API

This commit is contained in:
Gavin Bunney
2019-10-18 11:13:15 -07:00
parent 3cc9bb1285
commit ec0c3ad91b
2 changed files with 32 additions and 6 deletions
+18 -4
View File
@@ -18,6 +18,12 @@ type User struct {
DisplayName string `json:"displayName,omitempty"` DisplayName string `json:"displayName,omitempty"`
} }
type UserUpdate struct {
Name string `json:"name,omitempty"`
EmailAddress string `json:"email,omitempty"`
DisplayName string `json:"displayName,omitempty"`
}
func resourceUser() *schema.Resource { func resourceUser() *schema.Resource {
return &schema.Resource{ return &schema.Resource{
Create: resourceUserCreate, Create: resourceUserCreate,
@@ -83,9 +89,19 @@ func newUserFromResource(d *schema.ResourceData) *User {
return user return user
} }
func newUserUpdateFromResource(d *schema.ResourceData) *UserUpdate {
user := &UserUpdate{
Name: d.Get("name").(string),
EmailAddress: d.Get("email_address").(string),
DisplayName: d.Get("display_name").(string),
}
return user
}
func resourceUserUpdate(d *schema.ResourceData, m interface{}) error { func resourceUserUpdate(d *schema.ResourceData, m interface{}) error {
client := m.(*BitbucketServerProvider).BitbucketClient client := m.(*BitbucketServerProvider).BitbucketClient
user := newUserFromResource(d) user := newUserUpdateFromResource(d)
bytedata, err := json.Marshal(user) bytedata, err := json.Marshal(user)
@@ -93,9 +109,7 @@ func resourceUserUpdate(d *schema.ResourceData, m interface{}) error {
return err return err
} }
_, err = client.Put(fmt.Sprintf("/rest/api/1.0/admin/users/%s", _, err = client.Put("/rest/api/1.0/admin/users", bytes.NewBuffer(bytedata))
user.Name,
), bytes.NewBuffer(bytedata))
if err != nil { if err != nil {
return err return err
+14 -2
View File
@@ -3,6 +3,7 @@ package bitbucket
import ( import (
"fmt" "fmt"
"math/rand" "math/rand"
"strings"
"testing" "testing"
"time" "time"
@@ -12,7 +13,7 @@ import (
func TestAccBitbucketUser(t *testing.T) { func TestAccBitbucketUser(t *testing.T) {
userRand := fmt.Sprintf("%v", rand.New(rand.NewSource(time.Now().UnixNano())).Int()) userRand := fmt.Sprintf("%v", rand.New(rand.NewSource(time.Now().UnixNano())).Int())
testAccBitbucketUserConfig := fmt.Sprintf(` config := fmt.Sprintf(`
resource "bitbucketserver_user" "test" { resource "bitbucketserver_user" "test" {
name = "admin%v" name = "admin%v"
display_name = "Admin %v" display_name = "Admin %v"
@@ -20,13 +21,15 @@ func TestAccBitbucketUser(t *testing.T) {
} }
`, userRand, userRand, userRand) `, userRand, userRand, userRand)
configModified := strings.ReplaceAll(config, "Admin ", "Admin Updated ")
resource.Test(t, resource.TestCase{ resource.Test(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) }, PreCheck: func() { testAccPreCheck(t) },
Providers: testAccProviders, Providers: testAccProviders,
CheckDestroy: testAccCheckBitbucketUserDestroy, CheckDestroy: testAccCheckBitbucketUserDestroy,
Steps: []resource.TestStep{ Steps: []resource.TestStep{
{ {
Config: testAccBitbucketUserConfig, Config: config,
Check: resource.ComposeTestCheckFunc( Check: resource.ComposeTestCheckFunc(
resource.TestCheckResourceAttr("bitbucketserver_user.test", "name", "admin"+userRand), resource.TestCheckResourceAttr("bitbucketserver_user.test", "name", "admin"+userRand),
resource.TestCheckResourceAttr("bitbucketserver_user.test", "display_name", "Admin "+userRand), resource.TestCheckResourceAttr("bitbucketserver_user.test", "display_name", "Admin "+userRand),
@@ -34,6 +37,15 @@ func TestAccBitbucketUser(t *testing.T) {
resource.TestCheckResourceAttrSet("bitbucketserver_user.test", "initial_password"), resource.TestCheckResourceAttrSet("bitbucketserver_user.test", "initial_password"),
), ),
}, },
{
Config: configModified,
Check: resource.ComposeTestCheckFunc(
resource.TestCheckResourceAttr("bitbucketserver_user.test", "name", "admin"+userRand),
resource.TestCheckResourceAttr("bitbucketserver_user.test", "display_name", "Admin Updated "+userRand),
resource.TestCheckResourceAttr("bitbucketserver_user.test", "email_address", "admin"+userRand+"@example.com"),
resource.TestCheckResourceAttrSet("bitbucketserver_user.test", "initial_password"),
),
},
}, },
}) })
} }