public async Task EmitBatchAsync_throws_when_null_events() { // Arrange var db = Guid.NewGuid().ToString(); var settingsMoq = new Mock <ISejilSettings>(); settingsMoq.SetupGet(p => p.SqliteDbPath).Returns(db); settingsMoq.SetupGet(p => p.PageSize).Returns(100); settingsMoq.SetupGet(p => p.Url).Returns("/sejil"); var repository = new SejilRepository(new SejilSqlProvider(settingsMoq.Object), settingsMoq.Object); var sink = new SejilSinkMock(settingsMoq.Object); // Act & assert var ex = await Assert.ThrowsAsync <ArgumentNullException>(async() => await sink.CallEmitBatchAsync(null)); Assert.Equal("events", ex.ParamName); }
public async Task EmitBatchAsync_ignores_events_with_sejil_url_in_RequestPath_or_Path_properties(string propertyName) { // Arrange var db = Guid.NewGuid().ToString(); var settingsMoq = new Mock <ISejilSettings>(); settingsMoq.SetupGet(p => p.SqliteDbPath).Returns(db); settingsMoq.SetupGet(p => p.PageSize).Returns(100); settingsMoq.SetupGet(p => p.Url).Returns("/sejil"); var repository = new SejilRepository(new SejilSqlProvider(settingsMoq.Object), settingsMoq.Object); var sink = new SejilSinkMock(settingsMoq.Object); var tokens = new List <MessageTemplateToken> { new PropertyToken(propertyName, "{" + propertyName + "}"), }; var properties = new List <LogEventProperty> { new LogEventProperty(propertyName, new ScalarValue("/sejil/events")), }; var messageTemplate = new MessageTemplate(tokens); var events = new List <LogEvent> { new LogEvent(DateTime.Now, LogEventLevel.Information, null, messageTemplate, properties), }; // Act await sink.CallEmitBatchAsync(events); // Assert var logEvents = await repository.GetEventsPageAsync(1, null, null); Assert.Equal(0, logEvents.Count()); }
public async Task EmitBatchAsync_inserts_events_to_database() { // Arrange var db = Guid.NewGuid().ToString(); var settingsMoq = new Mock <ISejilSettings>(); settingsMoq.SetupGet(p => p.SqliteDbPath).Returns(db); settingsMoq.SetupGet(p => p.PageSize).Returns(100); var repository = new SejilRepository(new SejilSqlProvider(settingsMoq.Object), settingsMoq.Object); var sink = new SejilSinkMock(settingsMoq.Object); // Hello, {name}. Your # is {number} var tokens = new List <MessageTemplateToken> { new TextToken("Hello, ", 0), new PropertyToken("name", "{name}"), new TextToken(". Your # is ", 13), new PropertyToken("number", "{number}"), }; var properties = new List <LogEventProperty> { new LogEventProperty("name", new ScalarValue("world")), new LogEventProperty("number", new ScalarValue(null)) }; var messageTemplate = new MessageTemplate(tokens); var timestamp1 = new DateTime(2017, 8, 3, 11, 44, 15, 542, DateTimeKind.Local); var timestamp2 = new DateTime(2017, 9, 3, 11, 44, 15, 542, DateTimeKind.Local); var events = new List <LogEvent> { new LogEvent(timestamp1, LogEventLevel.Information, null, messageTemplate, properties), new LogEvent(timestamp2, LogEventLevel.Debug, new Exception("error"), messageTemplate, properties), }; // Act await sink.CallEmitBatchAsync(events); // Assert var logEvents = await repository.GetEventsPageAsync(1, null, null); Assert.Equal(2, logEvents.Count()); var logEvent1 = logEvents.FirstOrDefault(p => p.Level == "Information"); Assert.Equal("Hello, \"world\". Your # is null", logEvent1.Message); Assert.Equal("Hello, {name}. Your # is {number}", logEvent1.MessageTemplate); Assert.Equal("Information", logEvent1.Level); Assert.Equal(timestamp1, logEvent1.Timestamp); Assert.Null(logEvent1.Exception); Assert.Equal(2, logEvent1.Properties.Count()); Assert.Equal(logEvent1.Id, logEvent1.Properties.ElementAt(0).LogId); Assert.Equal("name", logEvent1.Properties.ElementAt(0).Name); Assert.Equal("world", logEvent1.Properties.ElementAt(0).Value); Assert.Equal(logEvent1.Id, logEvent1.Properties.ElementAt(1).LogId); Assert.Equal("number", logEvent1.Properties.ElementAt(1).Name); Assert.Equal("null", logEvent1.Properties.ElementAt(1).Value); var logEvent2 = logEvents.FirstOrDefault(p => p.Level == "Debug"); Assert.Equal("Hello, \"world\". Your # is null", logEvent2.Message); Assert.Equal("Hello, {name}. Your # is {number}", logEvent2.MessageTemplate); Assert.Equal("Debug", logEvent2.Level); Assert.Equal(timestamp2, logEvent2.Timestamp); Assert.Equal("System.Exception: error", logEvent2.Exception); Assert.Equal(2, logEvent2.Properties.Count()); Assert.Equal(logEvent2.Id, logEvent2.Properties.ElementAt(0).LogId); Assert.Equal("name", logEvent2.Properties.ElementAt(0).Name); Assert.Equal("world", logEvent2.Properties.ElementAt(0).Value); Assert.Equal(logEvent2.Id, logEvent2.Properties.ElementAt(1).LogId); Assert.Equal("number", logEvent2.Properties.ElementAt(1).Name); Assert.Equal("null", logEvent2.Properties.ElementAt(1).Value); }