どうやら、私たちのチームで開発者によって構築されたアプリケーションをテストするのに苦労しているようです。クラス: Apis、ユーザーからの接続文字列、ID、およびエラー メッセージを読み取ります。値の名前と資格の重みの辞書を返します。間違っていません。
クラス:
public class Apis
{
public Dictionary<String, String> getQualWeight(String sqlConStr, String inBin, Label lblResults)
{
Dictionary<String, String> qualList = new Dictionary<string, string>();
string selectSQL = "select Name,qual_weight from Qualification_type "
+ "where ID in (select Qualification_ID from Qualifications where BIN = @inBin)";
con = getConn(sqlConStr);
SqlCommand cmd = new SqlCommand(selectSQL, con);
cmd.Parameters.AddWithValue("@inBin", inBin);
SqlDataReader reader;
try
{
con.Open();
reader = cmd.ExecuteReader();
while (reader.Read())
{
qualList.Add(reader[0].ToString(), reader[1].ToString());
}
reader.Close();
return qualList;
}
catch (Exception err)
{
lblResults.Text = "error fetching qualification weight " + err.Message;
return null;
}
finally
{
con.Close();
}
}
私のテスト:
[TestMethod()]
public void getQualWeightTest()
{
Api target = new Api();
string sqlConStr = "SERVER=ABC123; Database=DB; UID=id; PWD=passme;encrypt=no;enlist=false";
string inBin = "2012-52-456";
Label lblResults = null;
lblResults.Text = " Failed";
Dictionary<string, string> expected = new Dictionary<string,string>();
expected.Add("Gohn", "50");
Dictionary<string, string> actual;
actual = target.getQualWeight(sqlConStr, inBin, lblResults);
Assert.AreEqual(expected, actual);
}