github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/network/armnetwork/v6@v6.2.0/fake/peerexpressroutecircuitconnections_server.go (about)

     1  //go:build go1.18
     2  // +build go1.18
     3  
     4  // Copyright (c) Microsoft Corporation. All rights reserved.
     5  // Licensed under the MIT License. See License.txt in the project root for license information.
     6  // Code generated by Microsoft (R) AutoRest Code Generator. DO NOT EDIT.
     7  // Changes may cause incorrect behavior and will be lost if the code is regenerated.
     8  
     9  package fake
    10  
    11  import (
    12  	"context"
    13  	"errors"
    14  	"fmt"
    15  	azfake "github.com/Azure/azure-sdk-for-go/sdk/azcore/fake"
    16  	"github.com/Azure/azure-sdk-for-go/sdk/azcore/fake/server"
    17  	"github.com/Azure/azure-sdk-for-go/sdk/azcore/runtime"
    18  	"github.com/Azure/azure-sdk-for-go/sdk/azcore/to"
    19  	"github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/network/armnetwork/v6"
    20  	"net/http"
    21  	"net/url"
    22  	"regexp"
    23  )
    24  
    25  // PeerExpressRouteCircuitConnectionsServer is a fake server for instances of the armnetwork.PeerExpressRouteCircuitConnectionsClient type.
    26  type PeerExpressRouteCircuitConnectionsServer struct {
    27  	// Get is the fake for method PeerExpressRouteCircuitConnectionsClient.Get
    28  	// HTTP status codes to indicate success: http.StatusOK
    29  	Get func(ctx context.Context, resourceGroupName string, circuitName string, peeringName string, connectionName string, options *armnetwork.PeerExpressRouteCircuitConnectionsClientGetOptions) (resp azfake.Responder[armnetwork.PeerExpressRouteCircuitConnectionsClientGetResponse], errResp azfake.ErrorResponder)
    30  
    31  	// NewListPager is the fake for method PeerExpressRouteCircuitConnectionsClient.NewListPager
    32  	// HTTP status codes to indicate success: http.StatusOK
    33  	NewListPager func(resourceGroupName string, circuitName string, peeringName string, options *armnetwork.PeerExpressRouteCircuitConnectionsClientListOptions) (resp azfake.PagerResponder[armnetwork.PeerExpressRouteCircuitConnectionsClientListResponse])
    34  }
    35  
    36  // NewPeerExpressRouteCircuitConnectionsServerTransport creates a new instance of PeerExpressRouteCircuitConnectionsServerTransport with the provided implementation.
    37  // The returned PeerExpressRouteCircuitConnectionsServerTransport instance is connected to an instance of armnetwork.PeerExpressRouteCircuitConnectionsClient via the
    38  // azcore.ClientOptions.Transporter field in the client's constructor parameters.
    39  func NewPeerExpressRouteCircuitConnectionsServerTransport(srv *PeerExpressRouteCircuitConnectionsServer) *PeerExpressRouteCircuitConnectionsServerTransport {
    40  	return &PeerExpressRouteCircuitConnectionsServerTransport{
    41  		srv:          srv,
    42  		newListPager: newTracker[azfake.PagerResponder[armnetwork.PeerExpressRouteCircuitConnectionsClientListResponse]](),
    43  	}
    44  }
    45  
    46  // PeerExpressRouteCircuitConnectionsServerTransport connects instances of armnetwork.PeerExpressRouteCircuitConnectionsClient to instances of PeerExpressRouteCircuitConnectionsServer.
    47  // Don't use this type directly, use NewPeerExpressRouteCircuitConnectionsServerTransport instead.
    48  type PeerExpressRouteCircuitConnectionsServerTransport struct {
    49  	srv          *PeerExpressRouteCircuitConnectionsServer
    50  	newListPager *tracker[azfake.PagerResponder[armnetwork.PeerExpressRouteCircuitConnectionsClientListResponse]]
    51  }
    52  
    53  // Do implements the policy.Transporter interface for PeerExpressRouteCircuitConnectionsServerTransport.
    54  func (p *PeerExpressRouteCircuitConnectionsServerTransport) Do(req *http.Request) (*http.Response, error) {
    55  	rawMethod := req.Context().Value(runtime.CtxAPINameKey{})
    56  	method, ok := rawMethod.(string)
    57  	if !ok {
    58  		return nil, nonRetriableError{errors.New("unable to dispatch request, missing value for CtxAPINameKey")}
    59  	}
    60  
    61  	var resp *http.Response
    62  	var err error
    63  
    64  	switch method {
    65  	case "PeerExpressRouteCircuitConnectionsClient.Get":
    66  		resp, err = p.dispatchGet(req)
    67  	case "PeerExpressRouteCircuitConnectionsClient.NewListPager":
    68  		resp, err = p.dispatchNewListPager(req)
    69  	default:
    70  		err = fmt.Errorf("unhandled API %s", method)
    71  	}
    72  
    73  	if err != nil {
    74  		return nil, err
    75  	}
    76  
    77  	return resp, nil
    78  }
    79  
    80  func (p *PeerExpressRouteCircuitConnectionsServerTransport) dispatchGet(req *http.Request) (*http.Response, error) {
    81  	if p.srv.Get == nil {
    82  		return nil, &nonRetriableError{errors.New("fake for method Get not implemented")}
    83  	}
    84  	const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.Network/expressRouteCircuits/(?P<circuitName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/peerings/(?P<peeringName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/peerConnections/(?P<connectionName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)`
    85  	regex := regexp.MustCompile(regexStr)
    86  	matches := regex.FindStringSubmatch(req.URL.EscapedPath())
    87  	if matches == nil || len(matches) < 5 {
    88  		return nil, fmt.Errorf("failed to parse path %s", req.URL.Path)
    89  	}
    90  	resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")])
    91  	if err != nil {
    92  		return nil, err
    93  	}
    94  	circuitNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("circuitName")])
    95  	if err != nil {
    96  		return nil, err
    97  	}
    98  	peeringNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("peeringName")])
    99  	if err != nil {
   100  		return nil, err
   101  	}
   102  	connectionNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("connectionName")])
   103  	if err != nil {
   104  		return nil, err
   105  	}
   106  	respr, errRespr := p.srv.Get(req.Context(), resourceGroupNameParam, circuitNameParam, peeringNameParam, connectionNameParam, nil)
   107  	if respErr := server.GetError(errRespr, req); respErr != nil {
   108  		return nil, respErr
   109  	}
   110  	respContent := server.GetResponseContent(respr)
   111  	if !contains([]int{http.StatusOK}, respContent.HTTPStatus) {
   112  		return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK", respContent.HTTPStatus)}
   113  	}
   114  	resp, err := server.MarshalResponseAsJSON(respContent, server.GetResponse(respr).PeerExpressRouteCircuitConnection, req)
   115  	if err != nil {
   116  		return nil, err
   117  	}
   118  	return resp, nil
   119  }
   120  
   121  func (p *PeerExpressRouteCircuitConnectionsServerTransport) dispatchNewListPager(req *http.Request) (*http.Response, error) {
   122  	if p.srv.NewListPager == nil {
   123  		return nil, &nonRetriableError{errors.New("fake for method NewListPager not implemented")}
   124  	}
   125  	newListPager := p.newListPager.get(req)
   126  	if newListPager == nil {
   127  		const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.Network/expressRouteCircuits/(?P<circuitName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/peerings/(?P<peeringName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/peerConnections`
   128  		regex := regexp.MustCompile(regexStr)
   129  		matches := regex.FindStringSubmatch(req.URL.EscapedPath())
   130  		if matches == nil || len(matches) < 4 {
   131  			return nil, fmt.Errorf("failed to parse path %s", req.URL.Path)
   132  		}
   133  		resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")])
   134  		if err != nil {
   135  			return nil, err
   136  		}
   137  		circuitNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("circuitName")])
   138  		if err != nil {
   139  			return nil, err
   140  		}
   141  		peeringNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("peeringName")])
   142  		if err != nil {
   143  			return nil, err
   144  		}
   145  		resp := p.srv.NewListPager(resourceGroupNameParam, circuitNameParam, peeringNameParam, nil)
   146  		newListPager = &resp
   147  		p.newListPager.add(req, newListPager)
   148  		server.PagerResponderInjectNextLinks(newListPager, req, func(page *armnetwork.PeerExpressRouteCircuitConnectionsClientListResponse, createLink func() string) {
   149  			page.NextLink = to.Ptr(createLink())
   150  		})
   151  	}
   152  	resp, err := server.PagerResponderNext(newListPager, req)
   153  	if err != nil {
   154  		return nil, err
   155  	}
   156  	if !contains([]int{http.StatusOK}, resp.StatusCode) {
   157  		p.newListPager.remove(req)
   158  		return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK", resp.StatusCode)}
   159  	}
   160  	if !server.PagerResponderMore(newListPager) {
   161  		p.newListPager.remove(req)
   162  	}
   163  	return resp, nil
   164  }