public static void LoadPackages(Action <IPackageFacility> configuration, bool runActivators = true) { _packages.Clear(); Diagnostics = new PackagingDiagnostics(); var record = new PackageLoadingRecord(); Diagnostics.LogExecution(record, () => { var facility = new PackageFacility(); var assemblyLoader = new AssemblyLoader(Diagnostics); var graph = new PackagingRuntimeGraph(Diagnostics, assemblyLoader, _packages); var codeLocation = findCallToLoadPackages(); graph.PushProvenance(codeLocation); configuration(facility); facility.Configure(graph); graph.PopProvenance(); graph.DiscoverAndLoadPackages(() => { _assemblies.Clear(); _assemblies.AddRange(assemblyLoader.Assemblies); }, runActivators); }); record.Finished = DateTime.Now; //_packages.Clear(); }
public void SetUp() { diagnostics = new PackagingDiagnostics(); package = new StubPackage("a"); assembly = Assembly.GetExecutingAssembly(); theProvenance = "from here"; diagnostics.LogAssembly(package, assembly, theProvenance); }
public void SetUp() { diagnostics = new PackagingDiagnostics(); loader = new StubPackageLoader("a", "b"); package = new StubPackage("a"); diagnostics.LogPackage(package, loader); }
public void SetUp() { diagnostics = new PackagingDiagnostics(); activator1 = new StubActivator(); activator2 = new StubActivator(); activator3 = new StubActivator(); bootstrapper = new StubBootstrapper("Boot1", activator1, activator2, activator3); diagnostics.LogBootstrapperRun(bootstrapper, bootstrapper.Bootstrap(null)); }
public HtmlDocument FullLog() { var table = new TableTag(); table.AddHeaderRow(r => { r.Header("Type"); r.Header("Description"); r.Header("Provenance"); r.Header("Timing"); }); PackageRegistry.Diagnostics.EachLog((target, log) => { table.AddBodyRow(row => { row.Cell(PackagingDiagnostics.GetTypeName(target)); row.Cell(target.ToString()); row.Cell(log.Provenance); row.Cell(log.TimeInMilliseconds.ToString()).AddClass("execution-time"); }); if (log.FullTraceText().IsNotEmpty()) { table.AddBodyRow(row => { row.Cell().Attr("colspan", "4").Add("pre").AddClass("log").Text(log.FullTraceText()); if (!log.Success) { row.AddClass("failure"); } }); } }); var document = DiagnosticHtml.BuildDocument(_urls, "Full Package Loading Log", table); return(document); }
/// <summary> /// The entry method into the bottles environment /// </summary> /// <param name="configuration"></param> /// <param name="runActivators"></param> public static void LoadPackages(Action <IPackageFacility> configuration, bool runActivators = true) //consider renaming to InitializeEnvironment //have it return an environment object. { _packages.Clear(); Diagnostics = new PackagingDiagnostics(); var record = new PackageLoadingRecord(); Diagnostics.LogExecution(record, () => { var facility = new PackageFacility(); var assemblyLoader = new AssemblyLoader(Diagnostics); var graph = new PackagingRuntimeGraph(Diagnostics, assemblyLoader, _packages); var codeLocation = findCallToLoadPackages(); graph.InProvenance(codeLocation, g => { //collect user configuration configuration(facility); //applies collected configurations facility.Configure(g); }); graph.DiscoverAndLoadPackages(() => { //clearing assemblies why? - my guess is testing. // this should only really be called once. _assemblies.Clear(); _assemblies.AddRange(assemblyLoader.Assemblies); //the above assemblies are used when we need to resolve bottle assemblies }, runActivators); }); record.Finished = DateTime.Now; }
public static void LoadPackages(Action <IPackageFacility> configuration) { _packages.Clear(); var facility = new PackageFacility(); Diagnostics = new PackagingDiagnostics(); var assemblyLoader = new AssemblyLoader(Diagnostics); var graph = new PackagingRuntimeGraph(Diagnostics, assemblyLoader, _packages); var codeLocation = findCallToLoadPackages(); graph.PushProvenance(codeLocation); configuration(facility); facility.As <IPackagingRuntimeGraphConfigurer>().Configure(graph); graph.PopProvenance(); graph.DiscoverAndLoadPackages(() => { _assemblies.Clear(); _assemblies.AddRange(assemblyLoader.Assemblies); }); }
public PackageDiagnosticsModel Get(PackageDiagnosticsRequestModel request) { // Might want to do some querying via json so let's flatten the logs - maybe map them? var logs = new List <PackageDiagnosticsLogModel>(); // Nothing really gained here by mocking this so let's hit it directly PackageRegistry .Diagnostics .EachLog((target, log) => logs.Add(new PackageDiagnosticsLogModel { Type = PackagingDiagnostics.GetTypeName(target), Description = target.ToString(), Provenance = log.Provenance, Timing = log.TimeInMilliseconds.ToString(), FullTraceText = log.FullTraceText(), Success = log.Success })); return(new PackageDiagnosticsModel { Logs = logs }); }
public void SetUp() { diagnostics = new PackagingDiagnostics(); }