/// <summary> /// Start System Usage Monitor with Diagnostic and Telemetry Recorder if Telemetry is enabled /// Otherwise Start System Usage Monitor with only Diagnostic Recorder /// </summary> private DiagnosticsHandlerHelper() { DiagnosticsHandlerHelper.isDiagnosticsMonitoringEnabled = false; // If the CPU monitor fails for some reason don't block the application try { DiagnosticsHandlerHelper.isTelemetryMonitoringEnabled = ClientTelemetryOptions.IsClientTelemetryEnabled(); List <SystemUsageRecorder> recorders = new List <SystemUsageRecorder>() { this.diagnosticSystemUsageRecorder, }; if (DiagnosticsHandlerHelper.isTelemetryMonitoringEnabled) { recorders.Add(this.telemetrySystemUsageRecorder); } this.systemUsageMonitor = SystemUsageMonitor.CreateAndStart(recorders); DiagnosticsHandlerHelper.isDiagnosticsMonitoringEnabled = true; } catch (Exception ex) { DefaultTrace.TraceError(ex.Message); DiagnosticsHandlerHelper.isDiagnosticsMonitoringEnabled = false; DiagnosticsHandlerHelper.isTelemetryMonitoringEnabled = false; } }
public void TestInitialize() { this.actualInfo = new List <ClientTelemetryProperties>(); Environment.SetEnvironmentVariable(ClientTelemetryOptions.EnvPropsClientTelemetrySchedulingInSeconds, "1"); Environment.SetEnvironmentVariable(ClientTelemetryOptions.EnvPropsClientTelemetryEndpoint, telemetryEndpointUrl); HttpClientHandlerHelper httpHandler = new HttpClientHandlerHelper { RequestCallBack = (request, cancellation) => { if (request.RequestUri.AbsoluteUri.Equals(ClientTelemetryOptions.GetClientTelemetryEndpoint().AbsoluteUri)) { HttpResponseMessage result = new HttpResponseMessage(HttpStatusCode.OK); string jsonObject = request.Content.ReadAsStringAsync().GetAwaiter().GetResult(); lock (this.actualInfo) { this.actualInfo.Add(JsonConvert.DeserializeObject <ClientTelemetryProperties>(jsonObject)); } return(Task.FromResult(result)); } else if (request.RequestUri.AbsoluteUri.Equals(ClientTelemetryOptions.GetVmMetadataUrl().AbsoluteUri)) { HttpResponseMessage result = new HttpResponseMessage(HttpStatusCode.OK); object jsonObject = JsonConvert.DeserializeObject("{\"compute\":{\"azEnvironment\":\"AzurePublicCloud\",\"customData\":\"\",\"isHostCompatibilityLayerVm\":\"false\",\"licenseType\":\"\",\"location\":\"eastus\",\"name\":\"sourabh-testing\",\"offer\":\"UbuntuServer\",\"osProfile\":{\"adminUsername\":\"azureuser\",\"computerName\":\"sourabh-testing\"},\"osType\":\"Linux\",\"placementGroupId\":\"\",\"plan\":{\"name\":\"\",\"product\":\"\",\"publisher\":\"\"},\"platformFaultDomain\":\"0\",\"platformUpdateDomain\":\"0\",\"provider\":\"Microsoft.Compute\",\"publicKeys\":[{\"keyData\":\"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC5uCeOAm3ehmhI+2PbMoMl17Eo\r\nqfHKCycSaBJsv9qxlmBOuFheSJc1XknJleXUSsuTO016/d1PyWpevnqOZNRksWoa\r\nJvQ23sDTxcK+X2OP3QlCUeX4cMjPXqlL8z1UYzU4Bx3fFvf8fs67G3N72sxWBw5P\r\nZyuXyhBm0NCe/2NYMKgEDT4ma8XszO0ikbhoPKbMbgHAQk/ktWQHNcqYOPQKEWqp\r\nEK1R0rjS2nmtovfScP/ZGXcvOpJ1/NDBo4dh1K+OxOGM/4PSH/F448J5Zy4eAyEk\r\nscys+IpeIOTOlRUy/703SNIX0LEWlnYqbyL9c1ypcYLQqF76fKkDfzzFI/OWVlGw\r\nhj/S9uP8iMsR+fhGIbn6MAa7O4DWPWLuedSp7KDYyjY09gqNJsfuaAJN4LiC6bPy\r\nhknm0PVLK3ux7EUOt+cZrHCdIFWbdOtxiPNIl1tkv9kV5aE5Aj2gJm4MeB9uXYhS\r\nOuksboBc0wyUGrl9+XZJ1+NlZOf7IjVi86CieK8= generated-by-azure\r\n\",\"path\":\"/home/azureuser/.ssh/authorized_keys\"}],\"publisher\":\"Canonical\",\"resourceGroupName\":\"sourabh-telemetry-sdk\",\"resourceId\":\"/subscriptions/8fba6d4f-7c37-4d13-9063-fd58ad2b86e2/resourceGroups/sourabh-telemetry-sdk/providers/Microsoft.Compute/virtualMachines/sourabh-testing\",\"securityProfile\":{\"secureBootEnabled\":\"false\",\"virtualTpmEnabled\":\"false\"},\"sku\":\"18.04-LTS\",\"storageProfile\":{\"dataDisks\":[],\"imageReference\":{\"id\":\"\",\"offer\":\"UbuntuServer\",\"publisher\":\"Canonical\",\"sku\":\"18.04-LTS\",\"version\":\"latest\"},\"osDisk\":{\"caching\":\"ReadWrite\",\"createOption\":\"FromImage\",\"diffDiskSettings\":{\"option\":\"\"},\"diskSizeGB\":\"30\",\"encryptionSettings\":{\"enabled\":\"false\"},\"image\":{\"uri\":\"\"},\"managedDisk\":{\"id\":\"/subscriptions/8fba6d4f-7c37-4d13-9063-fd58ad2b86e2/resourceGroups/sourabh-telemetry-sdk/providers/Microsoft.Compute/disks/sourabh-testing_OsDisk_1_9a54abfc5ba149c6a106bd9e5b558c2a\",\"storageAccountType\":\"Premium_LRS\"},\"name\":\"sourabh-testing_OsDisk_1_9a54abfc5ba149c6a106bd9e5b558c2a\",\"osType\":\"Linux\",\"vhd\":{\"uri\":\"\"},\"writeAcceleratorEnabled\":\"false\"}},\"subscriptionId\":\"8fba6d4f-7c37-4d13-9063-fd58ad2b86e2\",\"tags\":\"azsecpack:nonprod;platformsettings.host_environment.service.platform_optedin_for_rootcerts:true\",\"tagsList\":[{\"name\":\"azsecpack\",\"value\":\"nonprod\"},{\"name\":\"platformsettings.host_environment.service.platform_optedin_for_rootcerts\",\"value\":\"true\"}],\"version\":\"18.04.202103250\",\"vmId\":\"d0cb93eb-214b-4c2b-bd3d-cc93e90d9efd\",\"vmScaleSetName\":\"\",\"vmSize\":\"Standard_D2s_v3\",\"zone\":\"1\"},\"network\":{\"interface\":[{\"ipv4\":{\"ipAddress\":[{\"privateIpAddress\":\"10.0.7.5\",\"publicIpAddress\":\"\"}],\"subnet\":[{\"address\":\"10.0.7.0\",\"prefix\":\"24\"}]},\"ipv6\":{\"ipAddress\":[]},\"macAddress\":\"000D3A8F8BA0\"}]}}"); string payload = JsonConvert.SerializeObject(jsonObject); result.Content = new StringContent(payload, Encoding.UTF8, "application/json"); return(Task.FromResult(result)); } return(null); } }; List <string> preferredRegionList = new List <string> { "region1", "region2" }; this.cosmosClientBuilder = TestCommon.GetDefaultConfiguration() .WithApplicationPreferredRegions(preferredRegionList) .WithTelemetryEnabled() .WithHttpClientFactory(() => new HttpClient(httpHandler)); }
/// <summary> /// Initializes a new instance of the <see cref="ConnectionPolicy"/> class to connect to the Azure Cosmos DB service. /// </summary> public ConnectionPolicy() { this.connectionProtocol = Protocol.Https; this.RequestTimeout = TimeSpan.FromSeconds(ConnectionPolicy.defaultRequestTimeout); this.MediaRequestTimeout = TimeSpan.FromSeconds(ConnectionPolicy.defaultMediaRequestTimeout); this.ConnectionMode = ConnectionMode.Gateway; this.MaxConcurrentFanoutRequests = defaultMaxConcurrentFanoutRequests; this.MediaReadMode = MediaReadMode.Buffered; this.UserAgentContainer = new UserAgentContainer(clientId: 0); this.preferredLocations = new ObservableCollection <string>(); this.EnableEndpointDiscovery = true; this.MaxConnectionLimit = defaultMaxConcurrentConnectionLimit; this.RetryOptions = new RetryOptions(); this.EnableReadRequestsFallback = null; this.EnableClientTelemetry = ClientTelemetryOptions.IsClientTelemetryEnabled(); }
public void TestInitialize() { this.actualInfo = new List <ClientTelemetryProperties>(); HttpClientHandlerHelper httpHandler = new HttpClientHandlerHelper { RequestCallBack = (request, cancellation) => { if (request.RequestUri.AbsoluteUri.Equals(ClientTelemetryOptions.GetClientTelemetryEndpoint().AbsoluteUri)) { HttpResponseMessage result = new HttpResponseMessage(HttpStatusCode.OK); string jsonObject = request.Content.ReadAsStringAsync().GetAwaiter().GetResult(); lock (this.actualInfo) { this.actualInfo.Add(JsonConvert.DeserializeObject <ClientTelemetryProperties>(jsonObject)); } return(Task.FromResult(result)); } else if (request.RequestUri.AbsoluteUri.Equals(ClientTelemetryOptions.GetVmMetadataUrl().AbsoluteUri)) { HttpResponseMessage result = new HttpResponseMessage(HttpStatusCode.OK); string payload = JsonConvert.SerializeObject(ClientTelemetryTests.jsonObject); result.Content = new StringContent(payload, Encoding.UTF8, "application/json"); return(Task.FromResult(result)); } return(null); } }; this.preferredRegionList = new List <string> { "region1", "region2" }; this.cosmosClientBuilder = TestCommon.GetDefaultConfiguration() .WithApplicationPreferredRegions(this.preferredRegionList) .WithHttpClientFactory(() => new HttpClient(httpHandler)); }
public async Task ParseAzureVMMetadataTest() { HttpResponseMessage result = new HttpResponseMessage(HttpStatusCode.OK); // Add a substatus code that is not part of the enum. // This ensures that if the backend adds a enum the status code is not lost. object jsonObject = JsonConvert.DeserializeObject("{\"compute\":{\"azEnvironment\":\"AzurePublicCloud\",\"customData\":\"\",\"isHostCompatibilityLayerVm\":\"false\",\"licenseType\":\"\",\"location\":\"eastus\",\"name\":\"sourabh-testing\",\"offer\":\"UbuntuServer\",\"osProfile\":{\"adminUsername\":\"azureuser\",\"computerName\":\"sourabh-testing\"},\"osType\":\"Linux\",\"placementGroupId\":\"\",\"plan\":{\"name\":\"\",\"product\":\"\",\"publisher\":\"\"},\"platformFaultDomain\":\"0\",\"platformUpdateDomain\":\"0\",\"provider\":\"Microsoft.Compute\",\"publicKeys\":[{\"keyData\":\"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC5uCeOAm3ehmhI+2PbMoMl17Eo\r\nqfHKCycSaBJsv9qxlmBOuFheSJc1XknJleXUSsuTO016/d1PyWpevnqOZNRksWoa\r\nJvQ23sDTxcK+X2OP3QlCUeX4cMjPXqlL8z1UYzU4Bx3fFvf8fs67G3N72sxWBw5P\r\nZyuXyhBm0NCe/2NYMKgEDT4ma8XszO0ikbhoPKbMbgHAQk/ktWQHNcqYOPQKEWqp\r\nEK1R0rjS2nmtovfScP/ZGXcvOpJ1/NDBo4dh1K+OxOGM/4PSH/F448J5Zy4eAyEk\r\nscys+IpeIOTOlRUy/703SNIX0LEWlnYqbyL9c1ypcYLQqF76fKkDfzzFI/OWVlGw\r\nhj/S9uP8iMsR+fhGIbn6MAa7O4DWPWLuedSp7KDYyjY09gqNJsfuaAJN4LiC6bPy\r\nhknm0PVLK3ux7EUOt+cZrHCdIFWbdOtxiPNIl1tkv9kV5aE5Aj2gJm4MeB9uXYhS\r\nOuksboBc0wyUGrl9+XZJ1+NlZOf7IjVi86CieK8= generated-by-azure\r\n\",\"path\":\"/home/azureuser/.ssh/authorized_keys\"}],\"publisher\":\"Canonical\",\"resourceGroupName\":\"sourabh-telemetry-sdk\",\"resourceId\":\"/subscriptions/8fba6d4f-7c37-4d13-9063-fd58ad2b86e2/resourceGroups/sourabh-telemetry-sdk/providers/Microsoft.Compute/virtualMachines/sourabh-testing\",\"securityProfile\":{\"secureBootEnabled\":\"false\",\"virtualTpmEnabled\":\"false\"},\"sku\":\"18.04-LTS\",\"storageProfile\":{\"dataDisks\":[],\"imageReference\":{\"id\":\"\",\"offer\":\"UbuntuServer\",\"publisher\":\"Canonical\",\"sku\":\"18.04-LTS\",\"version\":\"latest\"},\"osDisk\":{\"caching\":\"ReadWrite\",\"createOption\":\"FromImage\",\"diffDiskSettings\":{\"option\":\"\"},\"diskSizeGB\":\"30\",\"encryptionSettings\":{\"enabled\":\"false\"},\"image\":{\"uri\":\"\"},\"managedDisk\":{\"id\":\"/subscriptions/8fba6d4f-7c37-4d13-9063-fd58ad2b86e2/resourceGroups/sourabh-telemetry-sdk/providers/Microsoft.Compute/disks/sourabh-testing_OsDisk_1_9a54abfc5ba149c6a106bd9e5b558c2a\",\"storageAccountType\":\"Premium_LRS\"},\"name\":\"sourabh-testing_OsDisk_1_9a54abfc5ba149c6a106bd9e5b558c2a\",\"osType\":\"Linux\",\"vhd\":{\"uri\":\"\"},\"writeAcceleratorEnabled\":\"false\"}},\"subscriptionId\":\"8fba6d4f-7c37-4d13-9063-fd58ad2b86e2\",\"tags\":\"azsecpack:nonprod;platformsettings.host_environment.service.platform_optedin_for_rootcerts:true\",\"tagsList\":[{\"name\":\"azsecpack\",\"value\":\"nonprod\"},{\"name\":\"platformsettings.host_environment.service.platform_optedin_for_rootcerts\",\"value\":\"true\"}],\"version\":\"18.04.202103250\",\"vmId\":\"d0cb93eb-214b-4c2b-bd3d-cc93e90d9efd\",\"vmScaleSetName\":\"\",\"vmSize\":\"Standard_D2s_v3\",\"zone\":\"1\"},\"network\":{\"interface\":[{\"ipv4\":{\"ipAddress\":[{\"privateIpAddress\":\"10.0.7.5\",\"publicIpAddress\":\"\"}],\"subnet\":[{\"address\":\"10.0.7.0\",\"prefix\":\"24\"}]},\"ipv6\":{\"ipAddress\":[]},\"macAddress\":\"000D3A8F8BA0\"}]}}"); string payload = JsonConvert.SerializeObject(jsonObject); result.Content = new StringContent(payload, Encoding.UTF8, "application/json"); AzureVMMetadata metadata = await ClientTelemetryOptions.ProcessResponseAsync(result); Assert.AreEqual("eastus", metadata.Compute.Location); Assert.AreEqual("18.04-LTS", metadata.Compute.SKU); Assert.AreEqual("AzurePublicCloud", metadata.Compute.AzEnvironment); Assert.AreEqual("Linux", metadata.Compute.OSType); Assert.AreEqual("Standard_D2s_v3", metadata.Compute.VMSize); }
public async Task CreateItemWithSubStatusCodeTest(ConnectionMode mode) { HttpClientHandlerHelper httpHandler = new HttpClientHandlerHelper(); HttpClient httpClient = new HttpClient(httpHandler); httpHandler.RequestCallBack = (request, cancellation) => { if (request.RequestUri.AbsoluteUri.Equals(ClientTelemetryOptions.GetClientTelemetryEndpoint().AbsoluteUri)) { HttpResponseMessage result = new HttpResponseMessage(HttpStatusCode.OK); string jsonObject = request.Content.ReadAsStringAsync().GetAwaiter().GetResult(); lock (this.actualInfo) { this.actualInfo.Add(JsonConvert.DeserializeObject <ClientTelemetryProperties>(jsonObject)); } return(Task.FromResult(result)); } else if (request.RequestUri.AbsoluteUri.Equals(ClientTelemetryOptions.GetVmMetadataUrl().AbsoluteUri)) { HttpResponseMessage result = new HttpResponseMessage(HttpStatusCode.OK); string payload = JsonConvert.SerializeObject(ClientTelemetryTests.jsonObject); result.Content = new StringContent(payload, Encoding.UTF8, "application/json"); return(Task.FromResult(result)); } else if (request.Method == HttpMethod.Get && request.RequestUri.AbsolutePath == "//addresses/") { HttpResponseMessage result = new HttpResponseMessage(HttpStatusCode.Forbidden); // Add a substatus code that is not part of the enum. // This ensures that if the backend adds a enum the status code is not lost. result.Headers.Add(WFConstants.BackendHeaders.SubStatus, 999999.ToString(CultureInfo.InvariantCulture)); string payload = JsonConvert.SerializeObject(new Error() { Message = "test message" }); result.Content = new StringContent(payload, Encoding.UTF8, "application/json"); return(Task.FromResult(result)); } return(null); }; // Replacing originally initialized cosmos Builder with this one with new handler this.cosmosClientBuilder = this.cosmosClientBuilder .WithHttpClientFactory(() => new HttpClient(httpHandler)); Container container = await this.CreateClientAndContainer(mode); try { ToDoActivity testItem = ToDoActivity.CreateRandomToDoActivity("MyTestPkValue"); ItemResponse <ToDoActivity> createResponse = await container.CreateItemAsync <ToDoActivity>(testItem); Assert.Fail("Request should throw exception."); } catch (CosmosException ce) when(ce.StatusCode == HttpStatusCode.Forbidden) { Assert.AreEqual(999999, ce.SubStatusCode); } IDictionary <string, long> expectedRecordCountInOperation = new Dictionary <string, long> { { Documents.OperationType.Create.ToString(), 1 } }; await this.WaitAndAssert(expectedOperationCount : 2, expectedOperationRecordCountMap : expectedRecordCountInOperation, expectedSubstatuscode : "999999"); }