本文整理汇总了C#中Statistics.AddTime方法的典型用法代码示例。如果您正苦于以下问题:C# Statistics.AddTime方法的具体用法?C# Statistics.AddTime怎么用?C# Statistics.AddTime使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Statistics
的用法示例。
在下文中一共展示了Statistics.AddTime方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: run
public void run(object targetObject, string targetObjectName)
{
logger.log("Testing " + targetObjectName);
logger.log("----------------------------");
Statistics statistics = new Statistics();
Type targetType = targetObject.GetType();
MethodInfo[] methods = targetType.GetMethods();
MethodInfo initializer = getMethodOrNull(targetType, "initialize", typeof(string));
MethodInfo releaser = getMethodOrNull(targetType, "release", typeof(string));
foreach (MethodInfo method in methods)
{
if (method.Name.StartsWith(TEST_METHOD_PREFIX))
{
statistics.TotalCount++;
string fullname = "'" + targetObjectName + "->" + method.Name + "'";
try
{
logger.log("Executing test " + fullname);
if (null != initializer)
{
try
{
initializer.Invoke(targetObject, new object[] { method.Name });
}
catch (Exception e)
{
logger.log("WARNING: Initialization before " + fullname + " test executing was failed. Test can't be run. Error message: " + e.Message);
statistics.SkippedCount++;
logger.log(string.Empty);
continue;
}
}
long startTime = DateTime.Now.Ticks;
try
{
targetType.InvokeMember(method.Name, BindingFlags.InvokeMethod, null, targetObject, null);
}
catch (TargetInvocationException e)
{
throw e.InnerException;
}
long spentTime = (DateTime.Now.Ticks - startTime) / 10000;
statistics.AddTime(spentTime);
statistics.PassedCount++;
if (null != releaser)
{
try
{
releaser.Invoke(targetObject, new object[] { method.Name });
}
catch (Exception e1)
{
logger.log("--- WARNING: Releasing of test data was failed. Error message: " + e1.Message);
}
}
logger.log("Test was passed " + fullname + ". Time: " + spentTime + " ms");
}
catch (SkippedException se)
{
if (null != releaser)
{
try
{
releaser.Invoke(targetObject, new object[] { method.Name });
}
catch (Exception e1)
{
logger.log("--- WARNING: Releasing of test data was failed. Error message: " + e1.Message);
}
}
logger.log("Test was skipped " + fullname + ". Reason: " + se.Message);
statistics.SkippedCount++;
}
catch (Exception e)
{
if (null != releaser)
{
try
{
releaser.Invoke(targetObject, new object[] { method.Name });
}
catch (Exception e1)
{
logger.log("--- WARNING: Releasing of test data was failed. Error message: " + e1.Message);
}
}
logger.log("Test was failed " + fullname + ". Message: " + e.Message);
statistics.FailedCount++;
}
logger.log(string.Empty);
}
}
logger.log("----------------------------");
logger.log("Passed: " + statistics.PassedCount);
logger.log("Failed: " + statistics.FailedCount);
logger.log("Skipped: " + statistics.SkippedCount);
logger.log("Executed: " + statistics.TotalCount);
logger.log("----------------------------");
logger.log("Spent time: " + statistics.TotalSpentTime + " ms");
logger.log();
//.........这里部分代码省略.........