如何为测试目的引发OracleException

时间:2016-05-23 09:07:23

标签: c# oracle exception-handling oracleexception

我有一个执行一些SQL命令的函数,我创建了一个记录器,我在文件中写入了执行的命令和受影响的行数,但我还需要记下命令可能已经引发了OracleException,所以我已经完成了这段代码:

public string ExecuteCommand(List<string> comandos)
        {
            var excepção = string.Empty;
            var executar = new OracleCommand
            {

                Connection = Updater.OraConnection,
                CommandType = CommandType.Text
            };

            try
            {
                Logg("Inicio da execução de comandos");
                foreach (var variable in comandos)
                {
                    excepção = variable;
                    executar.CommandText = variable;
                    throw new OracleException(0, "comando", "stuff", "adasds");
                  var Afectados =  executar.ExecuteNonQuery();
                    Logg(variable);
                    Logg("Linhas afectadas: " + Afectados);

                }

            }
            catch (OracleException)
            {
                Logg("Erros:");
                Logg(excepção);
                return excepção;

            }

            return excepção;


        }

我试图在任何地方进行搜索,但是我无法找到任何合适的甚至是有针对性的答案,所以我很遗憾因为我无法提出oracleException,因为我这样做:throw new OracleException(0, "comando", "stuff", "adasds");

  

它只是说由于其保护级别,无法在此访问构造函数。   任何帮助都是aprecciated

2 个答案:

答案 0 :(得分:0)

public class OracleException : Exception
{

}

该类需要将其范围设置为public或internal。无法将构造函数作为私有类进行访问。

答案 1 :(得分:0)

如果您只是想模拟抛出的异常而不关心询问对象那么。

private OracleResilienceManager CreateSut()
{
    return new OracleResilienceManager(_resilienceSettings);
}

throw System.Runtime.Serialization.CreateSafeUninitializedProtectedType<OracleException>();

在我的情况下,我正在测试重试策略,并希望在抛出此异常时测试重试逻辑。不需要访问对象本身。