|
1 | | -using System.Diagnostics; |
| 1 | +using System; |
| 2 | +using System.Diagnostics; |
| 3 | +using System.Linq; |
2 | 4 | using System.Threading.Tasks; |
3 | 5 | using NUnit.Framework; |
4 | 6 | using Rebus.Diagnostics.Incoming; |
@@ -41,6 +43,40 @@ public async Task CreatesNewSubActivityIfThereIsAnActiveActivity() |
41 | 43 | Assert.That(hadActivity); |
42 | 44 | } |
43 | 45 |
|
| 46 | + [Test] |
| 47 | + public async Task MarksActivityAsFailedIfHandlerThrows() |
| 48 | + { |
| 49 | + using var activity = new Activity("MyActivity"); |
| 50 | + |
| 51 | + Activity? innerActivity = null; |
| 52 | + var innerInvoker = new TestInvoker(() => |
| 53 | + { |
| 54 | + innerActivity = Activity.Current; |
| 55 | + throw new Exception("Look im failing"); |
| 56 | + }); |
| 57 | + |
| 58 | + var wrapper = new HandlerInvokerWrapper(innerInvoker, "MyMessage"); |
| 59 | + |
| 60 | + activity.Start(); |
| 61 | + |
| 62 | + Assume.That(activity, Is.SameAs(Activity.Current)); |
| 63 | + |
| 64 | + Assert.That(async () => |
| 65 | + { |
| 66 | + await wrapper.Invoke(); |
| 67 | + }, Throws.Exception); |
| 68 | + |
| 69 | + |
| 70 | + Assert.That(innerActivity, Is.Not.Null); |
| 71 | + |
| 72 | + Assert.That(innerActivity!.Status, Is.EqualTo(ActivityStatusCode.Error)); |
| 73 | + Assert.That(innerActivity!.StatusDescription, Is.EqualTo("Look im failing")); |
| 74 | + Assert.That(innerActivity.Events, Has.Exactly(1).Items); |
| 75 | + var ev = innerActivity.Events.Single(); |
| 76 | + Assert.That(ev.Tags.FirstOrDefault(t => t.Key == "exception.type").Value, Is.EqualTo("System.Exception")); |
| 77 | + Assert.That(ev.Tags.FirstOrDefault(t => t.Key == "exception.message").Value, Is.EqualTo("Look im failing")); |
| 78 | + } |
| 79 | + |
44 | 80 | [Test] |
45 | 81 | public async Task CreatesNoNewActivityIfThereIsntAlreadyAnActiveActivity() |
46 | 82 | { |
|
0 commit comments