public void Retrieves_Ok() { ExceptionsHelper.Log(new Exception("UnitTest", new SqliteException("UnitTest", 1001)), null); Assert.NotEmpty(ExceptionsHelper.Retrieves()); var ex = new Exceptions() { Period = "1" }; Assert.Equal("1", ex.Period); }
public object Get() { if (!User.IsInRole("Administrators")) { return(false); } // New Users var user = UserHelper.RetrieveNewUsers(); var usersCount = user.Count(); user = user.Take(6); user.AsParallel().ForAll(n => { var ts = DateTime.Now - n.RegisterTime; if (ts.TotalMinutes < 5) { n.Period = "刚刚"; } else if (ts.Days > 0) { n.Period = string.Format("{0}天", ts.Days); } else if (ts.Hours > 0) { n.Period = string.Format("{0}小时", ts.Hours); } else if (ts.Minutes > 0) { n.Period = string.Format("{0}分钟", ts.Minutes); } }); // Tasks var task = TaskServicesManager.ToList().Where(s => s.NextRuntime != null).Select(s => new { s.Name, s.LastRuntime, s.LastRunResult }); var tasksCount = task.Count(); //Message var message = MessageHelper.Retrieves(User.Identity.Name); var messagesCount = message.Count(); message = message.Take(6); message.AsParallel().ForAll(m => m.FromIcon = Url.Content(m.FromIcon)); //Apps var apps = ExceptionsHelper.Retrieves().Where(n => n.Category != "DB"); var appExceptionsCount = apps.Count(); apps = apps.Take(6); apps.AsParallel().ForAll(n => { n.ExceptionType = n.ExceptionType.Split('.').Last(); var ts = DateTime.Now - n.LogTime; if (ts.TotalMinutes < 5) { n.Period = "刚刚"; } else if (ts.Days > 0) { n.Period = string.Format("{0}天", ts.Days); } else if (ts.Hours > 0) { n.Period = string.Format("{0}小时", ts.Hours); } else if (ts.Minutes > 0) { n.Period = string.Format("{0}分钟", ts.Minutes); } }); //Dbs var dbs = ExceptionsHelper.Retrieves().Where(n => n.Category == "DB"); var dbExceptionsCount = dbs.Count(); dbs = dbs.Take(6); dbs.AsParallel().ForAll(n => { var ts = DateTime.Now - n.LogTime; if (ts.TotalMinutes < 5) { n.Period = "刚刚"; } else if (ts.Days > 0) { n.Period = string.Format("{0}天", ts.Days); } else if (ts.Hours > 0) { n.Period = string.Format("{0}小时", ts.Hours); } else if (ts.Minutes > 0) { n.Period = string.Format("{0}分钟", ts.Minutes); } }); return(new { NewUsersCount = usersCount, TasksCount = tasksCount, MessagesCount = messagesCount, AppExceptionsCount = appExceptionsCount, DbExceptionsCount = dbExceptionsCount, Users = user.Select(i => new { i.Period, i.UserName, i.DisplayName, i.Description }), Tasks = task.Take(6), Messages = message, Apps = apps.Select(n => new { n.ExceptionType, n.Message, n.Period }), Dbs = dbs.Select(n => new { n.ErrorPage, n.Message, n.Period }) }); }