引入jasmine测试框架
引入jasmine测试框架
1、下载jasmine测试框架
data:image/s3,"s3://crabby-images/306ba/306ba13579f51d9db781a64237f6f61a2f410448" alt=""
data:image/s3,"s3://crabby-images/a9aa9/a9aa9e956662ebe0beee88c4fd7d348263a76ba8" alt=""
2、Spring Boot项目引入jasmine测试框架
data:image/s3,"s3://crabby-images/79314/7931484e7da0d0e9697ea03e4c50400566469d3f" alt=""
data:image/s3,"s3://crabby-images/3962b/3962b14d3570379a5ede97b62c1acdf871620596" alt=""
3、index.html引入jasmine
data:image/s3,"s3://crabby-images/455c9/455c9d45bccf2c68cf00182c3f53d86856324363" alt=""
4、编写jasmine测试代码
index.html代码:
<body>
<a href="#" onclick="get1()">发生get请求</a>
<script type="text/javascript">
function get1(){
$.getJSON("http://localhost:8081/test/get1").then(
function(result){
console.log(result)
}
)
}
// 每一个测试用例的超时时间
jasmine.DEFAULT_TIMEOUT_INTERVAL = 1000;
// 请求的接口的前缀 // http://localhost:8080/test
var base = "http://localhost:8081/test";
//测试模块
describe("晓风轻-ajax跨越完全讲解", function() {
// 测试方法
it("get1请求", function(done) {
// 服务器返回的结果
var result;
$.getJSON(base + "/get1").then(function(jsonObj) {
result = jsonObj;
});
// 由于是异步请求,需要使用setTimeout来校验
setTimeout(function() {
expect(result).toEqual({
"data" : "get1 ok"
});
// 校验完成,通知jasmine框架
done();
}, 100);
});
});
</script>
<h2>test</h2>
</body>
5、验证jasmine测试代码
两个问题:
(1)跨域错误
(2)跨域错误导致结果返回为undifined,所以结果跟Expected值不相等,即undifined != “get1 ok”