Показаны сообщения с ярлыком Тестирование. Показать все сообщения
Показаны сообщения с ярлыком Тестирование. Показать все сообщения

Тестируем DTE

вторник, 9 июня 2009 г.,

Предположим, что требуется протестировать открытие определенного проекта в Visual Studio. Для этого надо:
1) создать UnitTest проект.
2) добавить в References: Microsoft.VSSDK.TestHostFramework (С:\Program Files\Microsoft Visual Studio 9.0\Common7\IDE\PublicAssemblies\Microsoft.VSSDK.TestHostFramework.dll)
3) у тестового метода определить атрибут HostTypeAttribute:
[TestMethod()]
[HostType("VS IDE")]
public void InvokeTest()
{
    var dte = VsIdeTestHostContext.Dte;
    dte.Events.SolutionEvents.Opened += () =>
    {
    };
    dte.ExecuteCommand("File.OpenProject", @"""C:\Projects\Test.csproj""");
}
В результате во время выполнения теста в отдельной Visual Studio откроется проект Test.csproj, а также будет вызван обработчик события Opened.

Если не указать HostTypeAttribute, то VsIdeTestHostContext.Dte вернет null.
Параметры для HostTypeAttribute определены в реестре: "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\VisualStudio\9.0\EnterpriseTools\QualityTools\HostAdapters\"

Как перехватить трафик ASP.NET Development Server'а

пятница, 24 апреля 2009 г.,

Ситуация: ASP.NET Development Server работает по адресу http://localhost:3840; требуется перехватить все запросы и ответы сервера.

Решение:
1) во всех адресах заменить "localhost" на "ipv4.fiddler". Например, вместо http://localhost:3840/Provider.svc/Now указать http://ipv4.fiddler:3840/Provider.svc/Now
2) запустить Fiddler (см. Install Fiddler2).

Запросы можно увидеть в окне Fiddler'а во вкладке Session Inspector - Raw, а на ответы можно посмотреть в нижней части вкладки, также нажав Raw.

ASP.NET Development Server находится в C:\Program Files\Common Files\microsoft shared\DevServer\9.0\WebDev.WebServer.EXE; параметры передаются через командую строку, например: /port:3840 /path:"С:\Projects\Site" /vpath:"/".
Сам веб-сервер - это класс Microsoft.VisualStudio.WebHost.Server, который помещен в GAC (WebDev.WebHost.dll).
Путь к файлу можно выяснить с помощью Process Monitor'а (см. Sysinternals Process Utilities). Открыть файл в проводнике не получится, но можно его предварительно скопировать с помощью copy в Command Prompt.

Тестируем работу клиента web-сервера

суббота, 18 апреля 2009 г.,

Протестировать работу клиента веб-сервера можно без самого веб-сервера. Достаточно установить Fiddler (см. Install Fiddler2) - это прокси с AutoResponder'ом. Автором Fiddler'а является Eric Lawrence - сотрудник Microsoft.
Предположим, что по адресу http://getvaluetest.ru расположен сайт, который на любой запрос присылает следующий http-ответ:
HTTP/1.1 200 OK
Date: Thu, 16 Apr 2009 08:39:02 GMT
Set-Cookie: name1=5; expires=Tue, 13-Apr-2010, 23:43:04, GMT; path=/; domain=.getvaluetest.ru
Set-Cookie: name2=5; expires=Tue, 13-Apr-2010, 23:43:04, GMT; path=/; domain=.getvaluetest.ru
Content-Length: 6
Content-Type: text/html; charset=windows-1251

привет
Сайта не существует, поэтому надо сохранить http-ответ в текстовый файл, например, c:\temp\200.txt, запустить Fiddler, в правой панели стать на AutoResponder и нажать кнопку Add. В левом поле Rule Editor указать http://GetValueTest.ru, а в правом поле - c:\temp\200.txt, нажать Save.
В приложение надо добавить слудующий код:
HttpResponse hr = new HttpResponse();
// запросить через прокси (Fiddler, который на IP: 127.0.0.1 "слушает" порт 8888)
hr.LoadFrom("http://getvaluetest.ru", new WebProxy(IPAddress.Loopback.ToString(), 8888));
System.Diagnostics.Trace.WriteLine(hr.Trace());
Ниже приводятся класс HttpResponse и его методы расширения:
public class HttpResponse
{
    public NameValueCollection Headers { get; set; }
    public string Contnet { get; set; }
    public Exception Error { get; set; }
}

public static class HttpResponseHelper
{
    public static void LoadFrom(this HttpResponse res, string url, WebProxy proxy)
    {
        HttpWebRequest req = (HttpWebRequest)WebRequest.Create(url);
        req.Proxy = proxy;
        req.Method = WebRequestMethods.Http.Get;
        try
        {
            using (HttpWebResponse wres = (HttpWebResponse)req.GetResponse())
            {
                if (req.HaveResponse)
                {
                    // если в http-ответе не указан charset, то получим: ISO-8859-1
                    var encoding = Encoding.GetEncoding(wres.CharacterSet);
                    using (StreamReader sr = new StreamReader(wres.GetResponseStream(), encoding))
                        res.Contnet = sr.ReadToEnd();

                    // копируем, потому что HttpWebResponse.Headers.GetValues(string)
                    // учитывает запятые в значении "Set-Cookie".
                    res.Headers = new NameValueCollection(wres.Headers);
                }
            }
        }
        catch (Exception exc)
        {
            res.Error = exc;
        }
    }

    public static string Trace(this HttpResponse hr)
    {
        if (hr.Error != null)
            return hr.Error.ToString();

        StringBuilder sb = new StringBuilder();
        foreach (string key in hr.Headers.AllKeys)
        {
            foreach (string value in hr.Headers.GetValues(key))
                sb.Append(key).Append(": ").Append(value).Append(Environment.NewLine);
        }
        sb.Append(Environment.NewLine);
        sb.Append(hr.Contnet);
        return sb.ToString();
    }
}