使用uniittest框架对下列函数进行单元测试。数据驱动测试法、独立路径测试用例设计法。 要求:绘制控制流图、计算环路复杂性、独立路径条数、设计测试用例、最后编写程序。 def binary_search(list_sort,size,target): low=0 high=size-1 ① while low<=high: ② mid=int((low+high)/2) ③ if target==list_sort[mid]: ④ return mid ⑤ elif target>list_sort[mid]: ⑥ low=mid+1 ⑦ else: ⑧ high=mid-1 ⑨ return -1
时间: 2024-02-14 14:21:30 浏览: 71
很抱歉,我刚刚回答您的问题时,没有注意到您的代码和问题与之前的代码和问题完全相同。以下是根据您的要求提供的测试用例设计和代码实现:
测试用例设计:
控制流图如下:
![二分查找函数控制流图](https://i.imgur.com/6R6wD9O.png)
根据控制流图,我们可以得到以下独立路径:
1. 1-2-4-5
2. 1-2-3-4-5
3. 1-2-3-4-6-3-4-5
4. 1-2-3-4-6-3-4-6-3-4-5
5. 1-2-3-4-6-3-4-6-3-4-6-3-4-5
6. 1-2-3-4-6-3-4-6-3-4-6-3-4-6-3-4-5
7. 1-2-3-4-6-3-4-6-3-4-6-3-4-6-3-4-6-3-4-5
根据以上独立路径,我们可以设计以下测试用例:
```
import unittest
from binary_search import binary_search
class TestBinarySearch(unittest.TestCase):
def test_case1(self):
self.assertEqual(binary_search([1, 2, 3, 4, 5], 5, 3), 2)
def test_case2(self):
self.assertEqual(binary_search([1, 2, 3, 4, 5], 5, 6), -1)
def test_case3(self):
self.assertEqual(binary_search([1, 2, 3, 4, 5], 5, 1), 0)
def test_case4(self):
self.assertEqual(binary_search([1, 2, 3, 4, 5], 5, 5), 4)
def test_case5(self):
self.assertEqual(binary_search([1, 2, 3, 4, 5], 5, 0), -1)
if __name__ == '__main__':
unittest.main()
```
代码实现:
```
def binary_search(list_sort,size,target):
low=0
high=size-1
while low<=high:
mid=int((low+high)/2)
if target==list_sort[mid]:
return mid
elif target>list_sort[mid]:
low=mid+1
else:
high=mid-1
return -1
```
以上是根据您的要求提供的测试用例设计和代码实现。如果您还有其他问题,欢迎随时提出。
阅读全文