From 87882c3aa5fcbbe11c20cb762d7d9cee3a98e948 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Damian=20B=C3=BCchel?= Date: Tue, 19 May 2020 15:17:12 +0200 Subject: [PATCH] Fixed issue with missing entry assembly in unit tests. --- .../ConfigurationRepositoryTests.cs | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/SafeExamBrowser.Configuration.UnitTests/ConfigurationRepositoryTests.cs b/SafeExamBrowser.Configuration.UnitTests/ConfigurationRepositoryTests.cs index 96283c33..777a1515 100644 --- a/SafeExamBrowser.Configuration.UnitTests/ConfigurationRepositoryTests.cs +++ b/SafeExamBrowser.Configuration.UnitTests/ConfigurationRepositoryTests.cs @@ -54,6 +54,8 @@ namespace SafeExamBrowser.Configuration.UnitTests fileSaver.Setup(f => f.CanSave(It.IsAny())).Returns(u => u.IsFile); networkLoader.Setup(n => n.CanLoad(It.IsAny())).Returns(u => u.Scheme.Equals("http") || u.Scheme.Equals("seb")); + SetEntryAssembly(); + sut = new ConfigurationRepository(certificateStore.Object, hashAlgorithm.Object, logger.Object); sut.InitializeAppConfig(); } @@ -327,5 +329,22 @@ namespace SafeExamBrowser.Configuration.UnitTests sut.Register(xmlParser.Object); sut.Register(xmlSerializer.Object); } + + /// + /// Hack required for unit tests to be able to retrieve the while executing. + /// + public void SetEntryAssembly() + { + var assembly = Assembly.GetCallingAssembly(); + var manager = new AppDomainManager(); + var entryAssemblyfield = manager.GetType().GetField("m_entryAssembly", BindingFlags.Instance | BindingFlags.NonPublic); + + entryAssemblyfield.SetValue(manager, assembly); + + var domain = AppDomain.CurrentDomain; + var domainManagerField = domain.GetType().GetField("_domainManager", BindingFlags.Instance | BindingFlags.NonPublic); + + domainManagerField.SetValue(domain, manager); + } } }