• [翻译]那么您想回放IIS Web服务器日志?


    几个月前,微软的一个组想回放一个大的IIS日志作为一个Visual Studio Web测试。他们开始一个转换将IIS日志转换为一个巨大的编码的Web测试。118M的CS文件这个结果是很荒谬的,并且对设计或运行时并没有很好的执行。

    我使用另一个不同的方法从Web测试读取IIS日志。它依赖于可以方便下载的LogReader 2.2来处理所有的日志分析并保持代码短而简单。

    这里是一个回放一个IIS日志的Webtest示例:

    public class IISLogCodedWebTest : WebTest
    {
        public IISLogCodedWebTest()
        {
            this.PreAuthenticate = true;
        }

        public override IEnumerator<WebTestRequest> GetRequestEnumerator()
        {
            IISLogReader reader = new IISLogReader(@"d:\download\ex060209.log");
            foreach (WebTestRequest request in reader.GetRequests())
            {
                yield return request;
            }
        }
    }

    上面使用的IISLogReader类的代码如下:

    using System;
    using System.Collections.Generic;
    using System.Text;
    using MSUtil;
    using LogQuery = MSUtil.LogQueryClassClass;
    using IISLogInputFormat = MSUtil.COMIISW3CInputContextClassClass;
    using LogRecordSet = MSUtil.ILogRecordset;
    using Microsoft.VisualStudio.TestTools.WebTesting;

    namespace IISLogToWebTest
    {
        public class IISLogReader
        {
            private string _iisLogPath;

            public IISLogReader(string iisLogPath)
            {
                _iisLogPath = iisLogPath;
            }

            public IEnumerable<WebTestRequest> GetRequests()
            {
                LogQuery logQuery = new LogQuery();
                IISLogInputFormat iisInputFormat = new IISLogInputFormat();

                string query = @"SELECT s-ip, s-port, cs-method, cs-uri-stem, cs-uri-query FROM " + _iisLogPath;

                LogRecordSet recordSet = logQuery.Execute(query, iisInputFormat);
                while (!recordSet.atEnd())
                {
                    ILogRecord record = recordSet.getRecord();
                    if (record.getValueEx("cs-method").ToString() == "GET")
                    {
                        string server = record.getValueEx("s-ip").ToString();
                        string path = record.getValueEx("cs-uri-stem").ToString();
                        string querystring = record.getValueEx("cs-uri-query").ToString();

                        StringBuilder urlBuilder = new StringBuilder();
                        urlBuilder.Append("http://");
                        urlBuilder.Append(server);
                        urlBuilder.Append(path);
                        if (!String.IsNullOrEmpty(querystring))
                        {
                            urlBuilder.Append("?");
                            urlBuilder.Append(querystring);
                        }

                        WebTestRequest request = new WebTestRequest(urlBuilder.ToString());
                        yield return request;
                    }

                    recordSet.moveNext();
                }
                recordSet.close();
            }
        }
    }

    请让我知道您是否觉得这个对您有用或是您还有其他任何问题。

                        JoshCh发布于星期一,2006年7月3日上午3点46分

    原文地址:http://blogs.msdn.com/joshch/archive/2006/07/03/65...

    OscarXie.net

    关注质量与体验——电子商务与自动化测试
    http://www.cnblogs.com/oscarxie/

  • 相关阅读:
    CodeForces 681D Gifts by the List (树上DFS)
    UVa 12342 Tax Calculator (水题,纳税)
    CodeForces 681C Heap Operations (模拟题,优先队列)
    CodeForces 682C Alyona and the Tree (树上DFS)
    CodeForces 682B Alyona and Mex (题意水题)
    CodeForces 682A Alyona and Numbers (水题,数学)
    Virtualizing memory type
    页面跳转
    PHP Misc. 函数
    PHP 5 Math 函数
  • 原文地址:https://www.cnblogs.com/oscarxie/p/958045.html
Copyright © 2020-2023  润新知