当前位置: 首页>>代码示例>>C#>>正文


C# RhetosTestContainer.AddLogMonitor方法代码示例

本文整理汇总了C#中RhetosTestContainer.AddLogMonitor方法的典型用法代码示例。如果您正苦于以下问题:C# RhetosTestContainer.AddLogMonitor方法的具体用法?C# RhetosTestContainer.AddLogMonitor怎么用?C# RhetosTestContainer.AddLogMonitor使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在RhetosTestContainer的用法示例。


在下文中一共展示了RhetosTestContainer.AddLogMonitor方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: TestPermissionsCachingOnChange

        public void TestPermissionsCachingOnChange(Action<Common.ExecutionContext> change, bool[] expectedPermissionsAfterChange, string expectedCacheMisses)
        {
            using (var container = new RhetosTestContainer(commitChanges: false))
            {
                var log = new List<string>();
                container.AddLogMonitor(log);
                container.AddFakeUser(User1Name);
                
                var repository = container.Resolve<Common.DomRepository>();
                var context = container.Resolve<Common.ExecutionContext>();
                var authorizationManager = container.Resolve<IAuthorizationManager>();

                AuthorizationDataCache.ClearCache();

                // Get user authorization:

                Assert.AreEqual(TestUtility.Dump(new[] { true, true, false }),
                    TestUtility.Dump(authorizationManager.GetAuthorizations(new[] { Claim1, Claim2, Claim3 })));

                Assert.AreEqual("Claims, Principal, PrincipalPermissions, PrincipalRoles, RolePermissions, RolePermissions, RoleRoles, RoleRoles, Roles",
                    ReportCacheMisses(log, "Initial authorization"), "Initial permission should yield cache misses. See test output log for details.");

                // Modify the permissions. Part of the cache might be invalidated:

                change(context);

                // Get user authorization, with parially invalidated cache:

                Assert.AreEqual(TestUtility.Dump(expectedPermissionsAfterChange),
                    TestUtility.Dump(authorizationManager.GetAuthorizations(new[] { Claim1, Claim2, Claim3 })));

                Assert.AreEqual(expectedCacheMisses, ReportCacheMisses(log, "Authorization after cache invalidation"), "See test output log for details.");
            }
        }
开发者ID:davorpr1,项目名称:Rhetos,代码行数:34,代码来源:AuthorizationCachingTest.cs

示例2: KeepSynchronizedSimple

        public void KeepSynchronizedSimple()
        {
            using (var container = new RhetosTestContainer())
            {
                var log = new List<string>();
                container.AddLogMonitor(log);

                var repository = container.Resolve<Common.DomRepository>();

                var doc1 = new Test9.Document { Name = "doc1" };
                var doc2 = new Test9.Document { Name = "doc2" };
                repository.Test9.Document.Insert(new[] { doc1, doc2 });
                container.Resolve<Common.ExecutionContext>().EntityFrameworkContext.ClearCache();

                Assert.AreEqual(0, SimpleNumParts(repository, "doc1"), "initial");
                container.Resolve<Common.ExecutionContext>().EntityFrameworkContext.ClearCache();

                var st1 = new Test9.Part { HeadID = doc1.ID, Name = "st1" };
                repository.Test9.Part.Insert(new[] { st1 });
                container.Resolve<Common.ExecutionContext>().EntityFrameworkContext.ClearCache();

                Assert.AreEqual(1, SimpleNumParts(repository, "doc1"), "after insert detail");
                container.Resolve<Common.ExecutionContext>().EntityFrameworkContext.ClearCache();

                var st2 = new Test9.Part { HeadID = doc1.ID, Name = "st2" };
                repository.Test9.Part.Insert(new[] { st2 });
                container.Resolve<Common.ExecutionContext>().EntityFrameworkContext.ClearCache();

                Assert.AreEqual(2, SimpleNumParts(repository, "doc1"), "after insert detail 2");
                container.Resolve<Common.ExecutionContext>().EntityFrameworkContext.ClearCache();

                st1.HeadID = doc2.ID;
                log.Clear();
                repository.Test9.Part.Update(new[] { st1 });
                container.Resolve<Common.ExecutionContext>().EntityFrameworkContext.ClearCache();

                Assert.AreEqual("DocumentAggregates i0 u2 d0, DocumentSimpleAggregate i0 u2 d0",
                    ReportRecompute(log)); // Optimized IEnumerable<Guid> filters in ChangesOnChangedItems merges IDs retrieved before and after save, to avoid two calls to the Recompute() function.
                Assert.AreEqual(1, SimpleNumParts(repository, "doc1"), "after update detail");
                container.Resolve<Common.ExecutionContext>().EntityFrameworkContext.ClearCache();

                st1.Name += "x";
                log.Clear();
                repository.Test9.Part.Update(new[] { st1 });
                container.Resolve<Common.ExecutionContext>().EntityFrameworkContext.ClearCache();

                Assert.AreEqual("DocumentAggregates i0 u0 d0, DocumentSimpleAggregate i0 u0 d0",
                    ReportRecompute(log)); // Optimized IEnumerable<Guid> filters in ChangesOnChangedItems merges IDs retrieved before and after save, to avoid two calls to the Recompute() function.
                Assert.AreEqual(1, SimpleNumParts(repository, "doc1"), "after update detail");
                container.Resolve<Common.ExecutionContext>().EntityFrameworkContext.ClearCache();

                repository.Test9.Part.Delete(new[] { st2 });
                container.Resolve<Common.ExecutionContext>().EntityFrameworkContext.ClearCache();

                Assert.AreEqual(0, SimpleNumParts(repository, "doc1"), "after delete detail 2");
                container.Resolve<Common.ExecutionContext>().EntityFrameworkContext.ClearCache();
            }
        }
开发者ID:tjakopovic,项目名称:Rhetos,代码行数:58,代码来源:PersistedDataStructureTest.cs

示例3: TestExecuteDataMigrationScripts

        private List<string> TestExecuteDataMigrationScripts(string[] scriptsDescriptions, string expectedResult, bool skipScriptsWithWrongOrder = false)
        {
            using (var container = new RhetosTestContainer())
            {
                var log = new List<string>();
                container.AddLogMonitor(log);

                var sqlExecuter = container.Resolve<ISqlExecuter>();
                sqlExecuter.ExecuteSql("DELETE FROM Rhetos.DataMigrationScript");

                foreach (string scriptsDescription in scriptsDescriptions)
                {
                    var scriptsProvider = new SimpleScriptsProvider(scriptsDescription);
                    var configuration = new MockConfiguration(new Dictionary<string, object>
                    {
                        { "DataMigration.SkipScriptsWithWrongOrder", skipScriptsWithWrongOrder }
                    });
                    var dataMigration = new DataMigration(sqlExecuter, container.Resolve<ILogProvider>(), scriptsProvider, configuration);
                    dataMigration.ExecuteDataMigrationScripts();
                }

                var report = new List<string>();
                sqlExecuter.ExecuteReader("SELECT Path, Active FROM Rhetos.DataMigrationScript ORDER BY OrderExecuted",
                    reader => report.Add(reader.GetString(0).Replace(".sql", "") + (reader.GetBoolean(1) ? "" : "-")));
                Assert.AreEqual(expectedResult, string.Join(", ", report));

                return log;
            }
        }
开发者ID:Rhetos,项目名称:Rhetos,代码行数:29,代码来源:DataMigrationTest.cs


注:本文中的RhetosTestContainer.AddLogMonitor方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。