//consider renaming to InitializeEnvironment //have it return an environment object. /// <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) { _packages.Clear(); Diagnostics = new BottlingDiagnostics(new LoggingSession()); var record = new BottleLoadingRecord(); Diagnostics.LogExecution(record, () => { var facility = new PackageFacility(); var assemblyLoader = new AssemblyLoader(Diagnostics); var graph = new PackagingRuntimeGraph(Diagnostics, assemblyLoader, _packages); var codeLocation = ProvenanceHelper.GetProvenanceFromStack(); 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 void SetUp() { diagnostics = new BottlingDiagnostics(new LoggingSession()); loader = new StubBottleLoader("a", "b"); _bottle = new StubBottle("a"); diagnostics.LogPackage(_bottle, loader); }
public void SetUp() { diagnostics = new BottlingDiagnostics(new LoggingSession()); _bottle = new StubBottle("a"); assembly = Assembly.GetExecutingAssembly(); theProvenance = "from here"; diagnostics.LogAssembly(_bottle, assembly, theProvenance); }
public void SetUp() { diagnostics = new BottlingDiagnostics(new LoggingSession()); activator1 = new StubActivator(); activator2 = new StubActivator(); activator3 = new StubActivator(); bootstrapper = new StubBootstrapper("Boot1", activator1, activator2, activator3); diagnostics.LogBootstrapperRun(bootstrapper, bootstrapper.Bootstrap(null)); }
public void SetUp() { diagnostics = new BottlingDiagnostics(new LoggingSession()); }