У меня есть веб-сайт ASP.NET MVC, который использует проверку подлинности Windows для управления доступом. Я хотел бы иметь тест селена specflow, который проверяет правильность конфигурации, пытаясь посетить сайт в качестве неавторизованного пользователя.
Поскольку мы используем учетные записи домена для управления доступом, экран входа в систему с именем пользователя и паролем отсутствует. Учетные данные текущего пользователя автоматически передаются на сайт браузером.
Поэтому для моего теста Selenium мне нужно иметь возможность запускать Internet Explorer от имени конкретного пользователя.
Я нашел ряд статей о олицетворении Windows, и я могу переключиться на своего тестового пользователя во время выполнения теста (используя код из http://support.microsoft.com/kb/306158). Однако, если я затем создам InternetExplorerDriver, он запустит Internet Explorer с моими учетными данными, а не с учетными данными тестового пользователя (хотя этот вопрос и ответ предполагают, что он должен работать https://sqa.stackexchange.com/questions/2277/using-selenium-webdriver-with-windows-authentication).
Я также могу явно запустить процесс Internet Explorer в качестве своего тестового пользователя, но я не вижу способа связать InternetExplorerDriver с уже запущенным процессом Internet Explorer, так что это может оказаться тупиком.
Мой код, в основном взятый со страницы MSDN выше, приведен ниже. В отладчике я вижу, что WindowsIdentity.GetCurrent().Name имеет значение «testUser» на всех этапах теста.
namespace MyProject.Specs
{
using NUnit.Framework;
using OpenQA.Selenium;
using OpenQA.Selenium.IE;
using System;
using System.Runtime.InteropServices;
using System.Security.Principal;
using TechTalk.SpecFlow;
[Binding]
public class AuthorisationSteps
{
public const int LOGON32_LOGON_INTERACTIVE = 2;
public const int LOGON32_PROVIDER_DEFAULT = 0;
private static WindowsImpersonationContext impersonationContext;
private static IWebDriver driver;
[BeforeScenario]
public static void impersonateUser()
{
if (!impersonateValidUser("testUser", "testDomain", "password"))
{
throw new Exception();
}
driver = new InternetExplorerDriver();
}
[AfterScenario]
public static void cleanupUser()
{
undoImpersonation();
driver.Quit();
}
[Given(@"I am an unauthorised user")]
public void GivenIAmAnUnauthorisedUser()
{
var temp = WindowsIdentity.GetCurrent().Name;
}
[When(@"I go to the home page")]
public void WhenIGoToTheHomePage()
{
var temp = WindowsIdentity.GetCurrent().Name;
driver.Navigate().GoToUrl(BaseUrl);
}
[Then(@"I should see an error page")]
public void ThenIShouldSeeAnErrorPage()
{
var temp = WindowsIdentity.GetCurrent().Name;
Assert.That(driver.Title.Contains("Error"));
}
[DllImport("advapi32.dll")]
public static extern int LogonUserA(String lpszUserName,
String lpszDomain,
String lpszPassword,
int dwLogonType,
int dwLogonProvider,
ref IntPtr phToken);
[DllImport("advapi32.dll", CharSet = CharSet.Auto, SetLastError = true)]
public static extern int DuplicateToken(IntPtr hToken,
int impersonationLevel,
ref IntPtr hNewToken);
[DllImport("advapi32.dll", CharSet = CharSet.Auto, SetLastError = true)]
public static extern bool RevertToSelf();
[DllImport("kernel32.dll", CharSet = CharSet.Auto)]
public static extern bool CloseHandle(IntPtr handle);
private static bool impersonateValidUser(String userName, String domain, String password)
{
WindowsIdentity tempWindowsIdentity;
var token = IntPtr.Zero;
var tokenDuplicate = IntPtr.Zero;
if (RevertToSelf())
{
if (LogonUserA(userName, domain, password, LOGON32_LOGON_INTERACTIVE,
LOGON32_PROVIDER_DEFAULT, ref token) != 0)
{
if (DuplicateToken(token, 2, ref tokenDuplicate) != 0)
{
tempWindowsIdentity = new WindowsIdentity(tokenDuplicate);
impersonationContext = tempWindowsIdentity.Impersonate();
if (impersonationContext != null)
{
CloseHandle(token);
CloseHandle(tokenDuplicate);
return true;
}
}
}
}
if (token != IntPtr.Zero)
{
CloseHandle(token);
}
if (tokenDuplicate != IntPtr.Zero)
{
CloseHandle(tokenDuplicate);
}
return false;
}
private static void undoImpersonation()
{
impersonationContext.Undo();
}
}
}
driver
передimpersonateValidUser(..)
- person ddavison   schedule 20.01.2015runas /user:USER@DOMIAN path\to\mstest.exe ...
- person Greg Burghardt   schedule 28.01.2015