本实验主要关注的是软件工程中的白盒测试技术,特别是针对NextDay问题的测试。这个问题是要求给定一个日期(年、月、日),计算出这个日期的后一天。测试的范围限定在1000年至3000年间,月份为1月至12月,日期为1日至31日。

我们需要理解白盒测试的概念。白盒测试,也称为结构测试或逻辑驱动测试,是一种软件测试方法,它基于对程序内部结构和工作原理的了解来设计测试用例。在这种测试中,测试人员会关注程序的内部逻辑和控制流,确保所有可能的执行路径都被覆盖到。

实验中提到了基本路径测试法,这是白盒测试的一种策略。基本路径测试法确保程序的每个逻辑路径至少被执行一次。在这个NextDay问题中,控制流图(CFG)被用来表示程序的逻辑结构,通过计算环形复杂度(Cyclomatic Complexity)来确定基本路径的数量。环形复杂度可以通过三种方法计算:

1.封闭区域的数量加上1。

2.边的数量减去节点数量再加上2。

3.判定节点的数量加上1。

实验中提到的环形复杂度V(G)为6,这意味着存在6条不同的独立路径,每条路径都应作为一个独立的测试用例。这6条路径分别在实验报告中列出。

接下来,实验提供了7个测试用例,用于验证NextDay函数的功能。这些测试用例包括了边界条件和非法输入,例如2月30日、2月29日在非闰年的情况,以及超出月份和年份范围的日期。这些测试用例的目的是确保程序在各种情况下都能正确处理。

源代码部分展示了如何实现NextDay功能。代码中定义了一个数组monArray来存储每个月的天数,考虑到闰年的特殊情况,会在需要时将2月的天数加1。然后,程序会读取用户输入的日期,并进行一系列的条件检查,如年份、月份和日期是否在范围内,以及是否是闰年。如果输入有效,程序会更新日期,如果输入无效,则打印错误信息。