private async Task <ChartSet> FastTimeouts(string key) { _testConfigProvider.Set("mjolnir.breaker." + key + ".minimumOperations", 5); _testConfigProvider.Set("mjolnir.breaker." + key + ".thresholdPercentage", 50); _testConfigProvider.Set("mjolnir.breaker." + key + ".trippedDurationMillis", 5000); _testConfigProvider.Set("mjolnir.metrics." + key + ".windowMillis", 10000); // Cranked up the threads here. We're going to sleeping on the server just a bit longer than // the timeout, so there's potential for server threads to grow while we throw more requests // at them. using (var server = new HttpServer(100)) { var url = string.Format("http://*****:*****@"c:\hudl\logs\mjolnir-metrics-{0}-{1}.txt", key, DateTime.Now.ToString("yyyy-MM-dd-HH-mm-ss")), _testStats.Metrics.Select(m => m.ToCsvLine())); return(new ChartSet { Name = "Fast Timeouts", Description = "30s @ 5/sec.<br/>Command: Inherited<br/>Timeout: 100<br/>Server: Delayed (200ms) 200<br/>Breaker: 50% / 10sec, min 5 ops, 5s tripped", Charts = GatherChartData(_testStats.Metrics, key, key + ".HttpClient"), }); }
private async Task <ChartSet> FastFailures(string key) { _testConfigProvider.Set("mjolnir.breaker." + key + ".minimumOperations", 5); _testConfigProvider.Set("mjolnir.breaker." + key + ".thresholdPercentage", 50); _testConfigProvider.Set("mjolnir.breaker." + key + ".trippedDurationMillis", 5000); _testConfigProvider.Set("mjolnir.metrics." + key + ".windowMillis", 10000); using (var server = new HttpServer(1)) { var url = string.Format("http://*****:*****@"c:\hudl\logs\mjolnir-metrics-{0}-{1}.txt", key, DateTime.Now.ToString("yyyy-MM-dd-HH-mm-ss")), _testStats.Metrics.Select(m => m.ToCsvLine())); return(new ChartSet { Name = "Fast Failures", Description = "30s @ 5/sec.<br/>Command: Inherited<br/>Timeout: 30000<br/>Server: Immediate 500<br/>Breaker: 50% / 10sec, min 5 ops, 5s tripped", Charts = GatherChartData(_testStats.Metrics, key, key + ".HttpClient"), }); }