软件测试:1.Describe An Error

时间:2023-03-08 19:07:20

软件测试:1.Describe An Error

软件测试:1.Describe An Error

    要求:

    1.简要描述你最近完成项目里的一个error;

    2.说明原因,错误影响,及你怎样发现的;

  或许因为刚开学的缘故,近期我并没有完成大的项目,多少有些惭愧。

  不过前几天刷编程题时,遇到一道基础的“最大子列和”问题,印象颇深。在程序排错时,自己仅凭感觉找faults,没有章法,费时费力。

    Failure描述:

  在Online Judge系统(OJ)上提交程序时显示结果“部分正确”,其中8个测试用例里有2个答案错误。

软件测试:1.Describe An Error

  根据自己以往的经验,既然其中有5个测试用例通过了,说明程序整体上没有大的错误,其中的一些特殊边界值的处理可能存在问题。

  然后先设计几组自己认为容易出错的边界值测试用例,在IDE里重新将程序运行起来,手动对自己设计的测试用例组进行测试,找出答案错误的情况。

软件测试:1.Describe An Error

  重新读题,题目要求如上图所示。输入一个整数序列,输出该序列的最大子列和、及该子列的第一个和最后一个整数值。

  特殊情况,在整数序列的所有整数均为负数时,输出的最大子列和为0,最大子列的第一个整数为整数子列的第一个整数,最大子列的最后一个整数为整数子列的最后一个整数。

    Error:

  再读题目要求后,注意到一个问题,输出的最大子列和为“0”时有3种情况:

  1.特殊情况,即所有整数项都为负数时;

  2.所有整数项都为0;

  3.所有整数项由负数和0组成;

  而我在之前编写程序并没有考虑这个问题。程序处理上面的情况3时可能会出现问题,于是设计了测试用例,输入:

  4

  -1 -2 0 -9

  

  期望得到的输出是:

  0 0 0

  而实际的输出是:

  0 -1 -9

  

  至此,终于找到程序出错的原因。在所有测试用例中,如果输入的整数序列的所有整数项由0和负数混合组成时,输出结果就会出错。

    Faults:

  Logic faults,定位到程序代码13行,将子列和为负数,和子列和为0的情况误认为是一种情况。这导致在输入的整数序列的所有整数项由0和负数混合组成时,输出最大子列的第一个和最后一个整数值,本该是输出0子列的整数值,却被当做特殊情况输出了整个序列的第一个和最后一个整数值。

软件测试:1.Describe An Error

    如果不足,欢迎指教,感激不尽

相关文章