/// <summary>
 /// Creates new logger.
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.Azure.Management.ApiManagement.ILoggerOperations.
 /// </param>
 /// <param name='resourceGroupName'>
 /// Required. The name of the resource group.
 /// </param>
 /// <param name='serviceName'>
 /// Required. The name of the Api Management service.
 /// </param>
 /// <param name='loggerid'>
 /// Required. Identifier of the logger.
 /// </param>
 /// <param name='parameters'>
 /// Required. Create parameters.
 /// </param>
 /// <returns>
 /// A standard service response including an HTTP status code and
 /// request ID.
 /// </returns>
 public static Task <AzureOperationResponse> CreateAsync(this ILoggerOperations operations, string resourceGroupName, string serviceName, string loggerid, LoggerCreateParameters parameters)
 {
     return(operations.CreateAsync(resourceGroupName, serviceName, loggerid, parameters, CancellationToken.None));
 }
Ejemplo n.º 2
0
        public void LoggersCreateListUpdateDelete()
        {
            TestUtilities.StartTest("SmapiFunctionalTests", "LoggersCreateListUpdateDelete");

            try
            {
                // create new group with default parameters
                string newloggerId              = TestUtilities.GenerateName("newlogger");
                string loggerDescription        = TestUtilities.GenerateName("newloggerDescription");
                string eventHubName             = ApiManagementHelper.EventHubName;
                string eventHubConnectionString = ApiManagementHelper.EventHubConnectionSendPolicyConnectionString;

                var credentials = new Dictionary <string, string>();
                credentials.Add("name", eventHubName);
                credentials.Add("connectionString", eventHubConnectionString);

                var loggerCreateParameters = new LoggerCreateParameters(LoggerTypeContract.AzureEventHub, credentials);
                loggerCreateParameters.Description = loggerDescription;

                var createResponse = ApiManagementClient.Loggers.Create(
                    ResourceGroupName,
                    ApiManagementServiceName,
                    newloggerId,
                    loggerCreateParameters);

                Assert.NotNull(createResponse);
                Assert.Equal(HttpStatusCode.Created, createResponse.StatusCode);

                // get to check it was created
                var getResponse = ApiManagementClient.Loggers.Get(ResourceGroupName, ApiManagementServiceName, newloggerId);

                Assert.NotNull(getResponse);
                Assert.NotNull(getResponse.Value);
                Assert.Equal(newloggerId, getResponse.Value.Id);
                Assert.NotNull(getResponse.Value.Description);
                Assert.NotNull(getResponse.Value.Credentials);
                Assert.Equal(2, getResponse.Value.Credentials.Keys.Count);
                Assert.Equal(LoggerTypeContract.AzureEventHub, getResponse.Value.Type);

                var listLoggers = ApiManagementClient.Loggers.List(ResourceGroupName, ApiManagementServiceName, null);

                Assert.NotNull(listLoggers);
                Assert.NotNull(listLoggers.Result);
                Assert.NotNull(listLoggers.Result.Values);

                // there should be one user
                Assert.True(listLoggers.Result.TotalCount >= 1);
                Assert.True(listLoggers.Result.Values.Count >= 1);

                // patch logger
                string patchedDescription = TestUtilities.GenerateName("patchedDescription");
                var    patchResponse      = ApiManagementClient.Loggers.Update(
                    ResourceGroupName,
                    ApiManagementServiceName,
                    newloggerId,
                    new LoggerUpdateParameters(LoggerTypeContract.AzureEventHub)
                {
                    Description = patchedDescription
                },
                    getResponse.ETag);

                Assert.NotNull(patchResponse);

                // get to check it was patched
                getResponse = ApiManagementClient.Loggers.Get(ResourceGroupName, ApiManagementServiceName, newloggerId);

                Assert.NotNull(getResponse);
                Assert.NotNull(getResponse.Value);
                Assert.Equal(newloggerId, getResponse.Value.Id);
                Assert.Equal(patchedDescription, getResponse.Value.Description);
                Assert.NotNull(getResponse.Value.Credentials);
                Assert.Equal(LoggerTypeContract.AzureEventHub, getResponse.Value.Type);

                // delete the logger
                var deleteResponse = ApiManagementClient.Loggers.Delete(
                    ResourceGroupName,
                    ApiManagementServiceName,
                    newloggerId,
                    getResponse.ETag);

                Assert.NotNull(deleteResponse);
                Assert.Equal(HttpStatusCode.NoContent, deleteResponse.StatusCode);

                // get the deleted logger to make sure it was deleted
                try
                {
                    ApiManagementClient.Loggers.Get(ResourceGroupName, ApiManagementServiceName, newloggerId);
                    throw new Exception("This code should not have been executed.");
                }
                catch (CloudException ex)
                {
                    Assert.Equal(HttpStatusCode.NotFound, ex.Response.StatusCode);
                }
            }
            finally
            {
                TestUtilities.EndTest();
            }
        }
 /// <summary>
 /// Creates new logger.
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.Azure.Management.ApiManagement.ILoggerOperations.
 /// </param>
 /// <param name='resourceGroupName'>
 /// Required. The name of the resource group.
 /// </param>
 /// <param name='serviceName'>
 /// Required. The name of the Api Management service.
 /// </param>
 /// <param name='loggerid'>
 /// Required. Identifier of the logger.
 /// </param>
 /// <param name='parameters'>
 /// Required. Create parameters.
 /// </param>
 /// <returns>
 /// A standard service response including an HTTP status code and
 /// request ID.
 /// </returns>
 public static AzureOperationResponse Create(this ILoggerOperations operations, string resourceGroupName, string serviceName, string loggerid, LoggerCreateParameters parameters)
 {
     return(Task.Factory.StartNew((object s) =>
     {
         return ((ILoggerOperations)s).CreateAsync(resourceGroupName, serviceName, loggerid, parameters);
     }
                                  , operations, CancellationToken.None, TaskCreationOptions.None, TaskScheduler.Default).Unwrap().GetAwaiter().GetResult());
 }