Skip to content

Commit

Permalink
New Resource: azurerm_eventgrid_domain_topic (#6859)
Browse files Browse the repository at this point in the history
Adds new resource azurerm_eventgrid_domain_topic

Fixes #4097
  • Loading branch information
jrauschenbusch authored May 14, 2020
1 parent b39893a commit cc979d4
Show file tree
Hide file tree
Showing 7 changed files with 416 additions and 0 deletions.
5 changes: 5 additions & 0 deletions azurerm/internal/services/eventgrid/client/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import (

type Client struct {
DomainsClient *eventgrid.DomainsClient
DomainTopicsClient *eventgrid.DomainTopicsClient
EventSubscriptionsClient *eventgrid.EventSubscriptionsClient
TopicsClient *eventgrid.TopicsClient
}
Expand All @@ -15,6 +16,9 @@ func NewClient(o *common.ClientOptions) *Client {
DomainsClient := eventgrid.NewDomainsClientWithBaseURI(o.ResourceManagerEndpoint, o.SubscriptionId)
o.ConfigureClient(&DomainsClient.Client, o.ResourceManagerAuthorizer)

DomainTopicsClient := eventgrid.NewDomainTopicsClient(o.SubscriptionId)
o.ConfigureClient(&DomainTopicsClient.Client, o.ResourceManagerAuthorizer)

EventSubscriptionsClient := eventgrid.NewEventSubscriptionsClientWithBaseURI(o.ResourceManagerEndpoint, o.SubscriptionId)
o.ConfigureClient(&EventSubscriptionsClient.Client, o.ResourceManagerAuthorizer)

Expand All @@ -24,6 +28,7 @@ func NewClient(o *common.ClientOptions) *Client {
return &Client{
DomainsClient: &DomainsClient,
EventSubscriptionsClient: &EventSubscriptionsClient,
DomainTopicsClient: &DomainTopicsClient,
TopicsClient: &TopicsClient,
}
}
153 changes: 153 additions & 0 deletions azurerm/internal/services/eventgrid/eventgrid_domain_topic_resource.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,153 @@
package eventgrid

import (
"fmt"
"log"
"time"

"github.com/hashicorp/go-azure-helpers/response"
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/helpers/azure"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/helpers/tf"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/internal/clients"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/internal/features"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/internal/services/eventgrid/parse"
azSchema "github.com/terraform-providers/terraform-provider-azurerm/azurerm/internal/tf/schema"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/internal/timeouts"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/utils"
)

func resourceArmEventGridDomainTopic() *schema.Resource {
return &schema.Resource{
Create: resourceArmEventGridDomainTopicCreate,
Read: resourceArmEventGridDomainTopicRead,
Delete: resourceArmEventGridDomainTopicDelete,

Timeouts: &schema.ResourceTimeout{
Create: schema.DefaultTimeout(30 * time.Minute),
Read: schema.DefaultTimeout(5 * time.Minute),
Delete: schema.DefaultTimeout(30 * time.Minute),
},

Importer: azSchema.ValidateResourceIDPriorToImport(func(id string) error {
_, err := parse.EventGridDomainTopicID(id)
return err
}),

Schema: map[string]*schema.Schema{
"name": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
},

"domain_name": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
},

"resource_group_name": azure.SchemaResourceGroupName(),
},
}
}

func resourceArmEventGridDomainTopicCreate(d *schema.ResourceData, meta interface{}) error {
client := meta.(*clients.Client).EventGrid.DomainTopicsClient
ctx, cancel := timeouts.ForCreateUpdate(meta.(*clients.Client).StopContext, d)
defer cancel()

name := d.Get("name").(string)
domainName := d.Get("domain_name").(string)
resourceGroup := d.Get("resource_group_name").(string)

if features.ShouldResourcesBeImported() && d.IsNewResource() {
existing, err := client.Get(ctx, resourceGroup, domainName, name)
if err != nil {
if !utils.ResponseWasNotFound(existing.Response) {
return fmt.Errorf("Error checking for presence of existing EventGrid Domain Topic %q (Resource Group %q): %s", name, resourceGroup, err)
}
}

if existing.ID != nil && *existing.ID != "" {
return tf.ImportAsExistsError("azurerm_eventgrid_domain_topic", *existing.ID)
}
}

future, err := client.CreateOrUpdate(ctx, resourceGroup, domainName, name)
if err != nil {
return fmt.Errorf("Error creating/updating EventGrid Domain Topic %q (Resource Group %q): %s", name, resourceGroup, err)
}

if err = future.WaitForCompletionRef(ctx, client.Client); err != nil {
return fmt.Errorf("Error waiting for EventGrid Domain Topic %q (Resource Group %q) to become available: %s", name, resourceGroup, err)
}

read, err := client.Get(ctx, resourceGroup, domainName, name)
if err != nil {
return fmt.Errorf("Error retrieving EventGrid Domain Topic %q (Resource Group %q): %s", name, resourceGroup, err)
}
if read.ID == nil {
return fmt.Errorf("Cannot read EventGrid Domain Topic %q (resource group %s) ID", name, resourceGroup)
}

d.SetId(*read.ID)

return resourceArmEventGridDomainTopicRead(d, meta)
}

func resourceArmEventGridDomainTopicRead(d *schema.ResourceData, meta interface{}) error {
client := meta.(*clients.Client).EventGrid.DomainTopicsClient
ctx, cancel := timeouts.ForRead(meta.(*clients.Client).StopContext, d)
defer cancel()

id, err := parse.EventGridDomainTopicID(d.Id())
if err != nil {
return err
}

resp, err := client.Get(ctx, id.ResourceGroup, id.Domain, id.Name)
if err != nil {
if utils.ResponseWasNotFound(resp.Response) {
log.Printf("[WARN] EventGrid Domain Topic %q was not found (Resource Group %q)", id.Name, id.ResourceGroup)
d.SetId("")
return nil
}

return fmt.Errorf("Error making Read request on EventGrid Domain Topic %q: %+v", id.Name, err)
}

d.Set("name", resp.Name)
d.Set("domain_name", id.Domain)
d.Set("resource_group_name", id.ResourceGroup)

return nil
}

func resourceArmEventGridDomainTopicDelete(d *schema.ResourceData, meta interface{}) error {
client := meta.(*clients.Client).EventGrid.DomainTopicsClient
ctx, cancel := timeouts.ForDelete(meta.(*clients.Client).StopContext, d)
defer cancel()

id, err := parse.EventGridDomainTopicID(d.Id())
if err != nil {
return err
}

future, err := client.Delete(ctx, id.ResourceGroup, id.Domain, id.Name)
if err != nil {
if response.WasNotFound(future.Response()) {
return nil
}
return fmt.Errorf("Error deleting EventGrid Domain Topic %q: %+v", id.Name, err)
}

if err = future.WaitForCompletionRef(ctx, client.Client); err != nil {
if response.WasNotFound(future.Response()) {
return nil
}
return fmt.Errorf("Error deleting EventGrid Domain Topic %q: %+v", id.Name, err)
}

return nil
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
package parse

import (
"fmt"

"github.com/terraform-providers/terraform-provider-azurerm/azurerm/helpers/azure"
)

type EventGridDomainTopicId struct {
ResourceGroup string
Name string
Domain string
}

func EventGridDomainTopicID(input string) (*EventGridDomainTopicId, error) {
id, err := azure.ParseAzureResourceID(input)
if err != nil {
return nil, fmt.Errorf("[ERROR] Unable to parse EventGrid Domain Topic ID %q: %+v", input, err)
}

domainTopic := EventGridDomainTopicId{
ResourceGroup: id.ResourceGroup,
}

if domainTopic.Name, err = id.PopSegment("topics"); err != nil {
return nil, err
}

if domainTopic.Domain, err = id.PopSegment("domains"); err != nil {
return nil, err
}

if err := id.ValidateNoEmptySegments(input); err != nil {
return nil, err
}

return &domainTopic, nil
}
1 change: 1 addition & 0 deletions azurerm/internal/services/eventgrid/registration.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ func (r Registration) SupportedDataSources() map[string]*schema.Resource {
func (r Registration) SupportedResources() map[string]*schema.Resource {
return map[string]*schema.Resource{
"azurerm_eventgrid_domain": resourceArmEventGridDomain(),
"azurerm_eventgrid_domain_topic": resourceArmEventGridDomainTopic(),
"azurerm_eventgrid_event_subscription": resourceArmEventGridEventSubscription(),
"azurerm_eventgrid_topic": resourceArmEventGridTopic(),
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,149 @@
package tests

import (
"fmt"
"net/http"
"testing"

"github.com/hashicorp/terraform-plugin-sdk/helper/resource"
"github.com/hashicorp/terraform-plugin-sdk/terraform"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/internal/acceptance"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/internal/clients"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/utils"
)

func TestAccAzureRMEventGridDomainTopic_basic(t *testing.T) {
data := acceptance.BuildTestData(t, "azurerm_eventgrid_domain_topic", "test")

resource.ParallelTest(t, resource.TestCase{
PreCheck: func() { acceptance.PreCheck(t) },
Providers: acceptance.SupportedProviders,
CheckDestroy: testCheckAzureRMEventGridDomainTopicDestroy,
Steps: []resource.TestStep{
{
Config: testAccAzureRMEventGridDomainTopic_basic(data),
Check: resource.ComposeTestCheckFunc(
testCheckAzureRMEventGridDomainTopicExists(data.ResourceName),
),
},
data.ImportStep(),
},
})
}

func TestAccAzureRMEventGridDomainTopic_requiresImport(t *testing.T) {
data := acceptance.BuildTestData(t, "azurerm_eventgrid_domain_topic", "test")

resource.ParallelTest(t, resource.TestCase{
PreCheck: func() { acceptance.PreCheck(t) },
Providers: acceptance.SupportedProviders,
CheckDestroy: testCheckAzureRMEventGridTopicDestroy,
Steps: []resource.TestStep{
{
Config: testAccAzureRMEventGridDomainTopic_basic(data),
Check: resource.ComposeTestCheckFunc(
testCheckAzureRMEventGridDomainTopicExists(data.ResourceName),
),
},
{
Config: testAccAzureRMEventGridDomainTopic_requiresImport(data),
ExpectError: acceptance.RequiresImportError("azurerm_eventgrid_domain_topic"),
},
},
})
}

func testCheckAzureRMEventGridDomainTopicDestroy(s *terraform.State) error {
client := acceptance.AzureProvider.Meta().(*clients.Client).EventGrid.DomainTopicsClient
ctx := acceptance.AzureProvider.Meta().(*clients.Client).StopContext

for _, rs := range s.RootModule().Resources {
if rs.Type != "azurerm_eventgrid_domain_topic" {
continue
}

name := rs.Primary.Attributes["name"]
domainName := rs.Primary.Attributes["domain_name"]
resourceGroup := rs.Primary.Attributes["resource_group_name"]

resp, err := client.Get(ctx, resourceGroup, domainName, name)
if err != nil {
if utils.ResponseWasNotFound(resp.Response) {
return nil
}

return err
}

if resp.StatusCode != http.StatusNotFound {
return fmt.Errorf("EventGrid Domain Topic still exists:\n%#v", resp)
}
}

return nil
}

func testCheckAzureRMEventGridDomainTopicExists(resourceName string) resource.TestCheckFunc {
return func(s *terraform.State) error {
client := acceptance.AzureProvider.Meta().(*clients.Client).EventGrid.DomainTopicsClient
ctx := acceptance.AzureProvider.Meta().(*clients.Client).StopContext

// Ensure we have enough information in state to look up in API
rs, ok := s.RootModule().Resources[resourceName]
if !ok {
return fmt.Errorf("Not found: %s", resourceName)
}

name := rs.Primary.Attributes["name"]
domainName := rs.Primary.Attributes["domain_name"]
resourceGroup, hasResourceGroup := rs.Primary.Attributes["resource_group_name"]
if !hasResourceGroup {
return fmt.Errorf("Bad: no resource group found in state for EventGrid Domain Topic: %s", name)
}

resp, err := client.Get(ctx, resourceGroup, domainName, name)
if err != nil {
if utils.ResponseWasNotFound(resp.Response) {
return fmt.Errorf("Bad: EventGrid Domain Topic %q (resource group: %s) does not exist", name, resourceGroup)
}

return fmt.Errorf("Bad: Get on EventGrid.DomainTopicsClient: %s", err)
}

return nil
}
}

func testAccAzureRMEventGridDomainTopic_basic(data acceptance.TestData) string {
return fmt.Sprintf(`
provider "azurerm" {
features {}
}
resource "azurerm_resource_group" "test" {
name = "acctestRG-%d"
location = "%s"
}
resource "azurerm_eventgrid_domain" "test" {
name = "acctestegdomain-%d"
location = azurerm_resource_group.test.location
resource_group_name = azurerm_resource_group.test.name
}
resource "azurerm_eventgrid_domain_topic" "test" {
name = "acctestegtopic-%d"
domain_name = azurerm_eventgrid_domain.test.name
resource_group_name = azurerm_resource_group.test.name
}
`, data.RandomInteger, data.Locations.Primary, data.RandomInteger, data.RandomInteger)
}

func testAccAzureRMEventGridDomainTopic_requiresImport(data acceptance.TestData) string {
template := testAccAzureRMEventGridDomainTopic_basic(data)
return fmt.Sprintf(`
%s
resource "azurerm_eventgrid_domain_topic" "import" {
name = azurerm_eventgrid_domain_topic.test.name
domain_name = azurerm_eventgrid_domain_topic.test.domain_name
resource_group_name = azurerm_eventgrid_domain_topic.test.resource_group_name
}
`, template)
}
4 changes: 4 additions & 0 deletions website/azurerm.erb
Original file line number Diff line number Diff line change
Expand Up @@ -1793,6 +1793,10 @@
<li>
<a href="/docs/providers/azurerm/r/eventgrid_domain.html">azurerm_eventgrid_domain</a>
</li>

<li>
<a href="/docs/providers/azurerm/r/eventgrid_domain_topic.html">azurerm_eventgrid_domain_topic</a>
</li>

<li>
<a href="/docs/providers/azurerm/r/eventgrid_event_subscription.html">azurerm_eventgrid_event_subscription</a>
Expand Down
Loading

0 comments on commit cc979d4

Please sign in to comment.