我有一个方法TestScenarios()
应该遍历场景数据库,并且对于数据库中的每个项目,导航到指定的 url,截取屏幕截图并更改一些值。
我遇到问题的线路是webBrowser1.Navigate(Url);
线路。当我单步执行该函数时,Url
其值为http://google.com
,但 Web 控件从未显示。
相反,它只是说“导航已被取消”,这让我相信某些东西正在中断Navigate()
功能的完成。
此外,如果我webBrowser1.Navigate("http://google.com");
在 while 循环之外添加一条线,它会显示 Web 控件,这意味着这些webBrowser
控件似乎运行正常。
基本上我只需要一些指导帮助。代码如下。
public void TestScenarios()
{
using (SqlConnection conn = new SqlConnection(connectionString))
{
conn.Open();
using (SqlCommand cmd = new SqlCommand("SELECT * FROM Scenarios WHERE MarkedForDeletion!='1'", conn))
{
SqlDataReader reader = cmd.ExecuteReader();
if (reader.HasRows)
{
while (reader.Read())
{
// Store scenario information
int Id = (int) reader["ScenarioID"];
string Data = reader["ScenarioData"].ToString();
string Url = reader["ScenarioURL"].ToString();
// Navigate to webBrowser
webBrowser1.Navigate(Url);
// Do test
int HasSucceeded = 0;
if (Url == "http://bing.com")
{
HasSucceeded = 1;
}
// Take Screenshot
Bitmap bitmap = new Bitmap(Screen.PrimaryScreen.Bounds.Width, Screen.PrimaryScreen.Bounds.Height);
Graphics g = Graphics.FromImage(bitmap);
g.CopyFromScreen(0, 0, 0, 0, Screen.PrimaryScreen.Bounds.Size);
ImageConverter converter = new ImageConverter();
Byte[] screenshot = (byte[])converter.ConvertTo(bitmap, typeof(byte[]));
// Insert results
InsertResults(Id, HasSucceeded, screenshot);
// Delete scenario
// DeleteScenario(Id);
// Mark scenario for deletion
MarkScenario(Id);
}
}
reader.Close();
}
}
}