先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7
深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新大数据全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
如果你需要这些资料,可以添加V获取:vip204888 (备注大数据)
正文
此段代码我们去除了`add`操作,因为`add`操作并不是我们真实的目的,真实目的是我们想要控制程序的执行走的路径,达到全覆盖。
### 验证
#### 验证某一方法是否执行
我们如何验证程序按照我们想要的路径争取执行了呢?可以使用`verify`。`Mockito verify`方法用于检查是否发生了某些行为,我们可以在测试方法代码的末尾使用`Mockito`验证方法,以确保调用了指定的方法。
package com.bootdo.app.service.impl;
import lombok.extern.slf4j.Slf4j;
import org.junit.Test;
import java.util.List;
import static org.mockito.Mockito.*;
@Slf4j
public class AppNoticeServiceTest {
@Test
public void baseOperation() {
List mockedList = mock(List.class);
when(mockedList.get(1)).thenReturn(“one”);
String content =(String) mockedList.get(1);
if(content.equals(“one”)) {
// 程序略
mockedList.add(“two”);
} else {
// 程序略
mockedList.add(“three”);
}
verify(mockedList).add(“two”);
}
}
我们成功验证了`mockedList`执行了`add("two")`方法,证明走了true分支。
#### 验证某一个方法执行次数
mockedList.add(“three times”);
mockedList.add(“three times”);
mockedList.add(“three times”);
verify(mockedList, times(3)).add(“three times”);
#### 验证执行顺序
// A. Single mock whose methods must be invoked in a particular order
List singleMock = mock(List.class);
//using a single mock
singleMock.add(“was added first”);
singleMock.add(“was added second”);
//create an inOrder verifier for a single mock
InOrder inOrder = inOrder(singleMock);
//following will make sure that add is first called with “was added first”, then with “was added second”
inOrder.verify(singleMock).add(“was added first”);
inOrder.verify(singleMock).add(“was added second”);
两个类的执行顺序
// B. Multiple mocks that must be used in a particular order
List firstMock = mock(List.class);
List secondMock = mock(List.class);
//using mocks
firstMock.add(“was called first”);
secondMock.add(“was called second”);
//create inOrder object passing any mocks that need to be verified in order
InOrder inOrder = inOrder(firstMock, secondMock);
//following will make sure that firstMock was called before secondMock
inOrder.verify(firstMock).add(“was called first”);
inOrder.verify(secondMock).add(“was called second”);
#### 验证类的所有模拟方法是否都被验证了
这个方法很难理解,而且网上的资料大多数都是直译官网,非常难以理解。以下我们通过一个例子来理解一下:
public class Test {
public String method1(){return “method1”;}
public String method2(){return “method2”;}
}
public class MockTest {
public static void main(String[] args) {
Test test = mock(Test.class);
test.method1();
verifyNoMoreInteractions(test);
}
}
以上调用了`test.method1()`但是却没有验证该结果,所以会报错。
public class MockTest {
public static void main(String[] args) {
Test test = mock(Test.class);
test.method1();
verify(test).method1();
verifyNoMoreInteractions(test);
}
}
以上的程序虽然仅仅掉了test的method1方法,没有调用test的method2方法,但是却在调用method1之后,进行了验证了执行次数(默认为1),所以verifyNoMoreInteractions就不会报错了
### 参数匹配
如果一个方法需要填写参数,但是输入什么参数并不是很重要,重要的是他的返回值,那么你可以使用参数匹配。
when(mockedList.get(anyInt())).thenReturn(“element”);
你甚至可以模拟空指针和任意类
when(mock.dryRun(isNull())).thenReturn(“state”);
when(mock.dryRun(any(String.class))).thenReturn(“state”);
### 模拟异常
doThrow(new RuntimeException()).when(mockedList).clear();
// 以下程序执行会抛出异常
mockedList.clear();
## 参考资料
[官方文档]( )
## 好文推荐
1. [通俗易懂JVM]( )
2. [为什么Spring中的IOC(控制反转)能够降低耦合性(解耦)?]( )
3. [效率翻倍,这些idea的逆天功能你知道吗?]( )
**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
**需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注大数据)**
![img](https://img-blog.csdnimg.cn/img_convert/bb8d28b324eff12018f6a26853841c2a.png)
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
深入研究,那么很难做到真正的技术提升。**
**需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注大数据)**
[外链图片转存中...(img-dbqmdsjm-1713375214174)]
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**