CasperJS实践笔记(4)

casperJS的测试module

 

casper.test.begin执行一串完整的测试动作,不过其中的对象this并非capser而是test!

只不过test对象本身具备casper的attribute,另外还有test module提供的attribute(提供了测试相关的诸多API)。

 

casper对象有很多很多options,下面说说这些options的设置,options允许我们设置一些默认值、userAgent、定制功能、等等。

举例如下:

casper.options.pageSettings = {
        loadImages: true,
        loadPlugins: true,    
        userAgent: ‘Mozilla/5.0 (Linux; U; Android 4.3; en-us; SM-N900T Build/JSS15J) AppleWebKit/534.30 (KHTML, like Gecko) Version/4.0 Mobile Safari/534.30‘
    };

casper.options.verbose = true;
casper.options.logLevel = "debug";

casper.on("page.error", function(_err, _trace){
    this.log(_err, "error");
});

casper.on("remote.message", function(_msg){
    this.log(_msg, "warning");
});

 

比如logLevel用来设置log等级,有4个值:debug,info,warning,error;

比如使用on监听事件"page.error",可用抓取js脚本错误;

关于Http请求的响应也有办法处理,而且还有两个办法,代码如下:

casper.on("http.status.400", function(_resource){
    this.log("Remote http.status.400 occur.", "error");
    this.log(_resource.url, "error");
});


casper.options.httpStatusHandlers = {
    400:    function(self, _resource){
                this.log(casper._Impor_msg_str1, "error");
                this.log("Remote http.status.400 occur.", "error");
                this.log(_resource.url, "error");
                this.log(casper._Impor_msg_str2, "error");
            }
};

 

代码执行过程中,肯定需要output一下信息,才好嘛;有三种方式:casper.echo,casper.log,test.info

其中test.info带一个参数,就是“想说的话”;

而casper.echo可以带2个参数:“想说的话”和“重要级别”(debug,info,warning,error);

casper.log则可以带3个参数:“想说的话”、“重要级别”、“来源”(phantom or casper);

 

好了,感觉自己很慷慨~~~

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。