LR中的时间戳函数web_save_timestamp_param

以前真没注意过后面看某个群有人说到这个函数一查,还真有,那么处理时间戳就简单很多了,我们经常在各种网站上看到类似于这样的时间戳

1302245899530
51Testing软件测试网"d bLq!uR&am
做时间戳的目的是为了JS缓存和防止CSRF,在LR中可以简单的使用下面这个函数

web_save_timestamp_param

来生成时间戳
 

 web_save_timestamp_param("tStamp", LAST);  

 lr_output_message("%s",lr_eval_string("{tStamp}"));

 

brokerDetail.c(49): web_save_timestamp_param("web_save_timestamp_param") was successful   [MsgId: MMSG-26392]
brokerDetail.c(53): 1433760182344

 

我想生成唯一的一个用户名。想到用web_save_timestamp_param函数。web_save_timestamp_param function saves the current timestamp to LoadRunner parameter. Timestamp is the number of milliseconds since midnight January 1st, 1970 (also known as Unix Epoch).
说这个函数是存储毫秒级的时间戳。而我刚取到的时间戳是1302245899530,这个时间戳我完全看不懂呀!跟时间不搭边呀现在时间是14:58分钟。

后来才发现取到的时间戳是现在时间减去现在的时间 减去 1970年1月1日0点00 的时间 ,然后换算成毫秒。

 

 

 

 

Lr_save_datetime函数的使用

 

    最近几天在录制测试脚本,希望能有一个方法自动保存系统时间,以便能够更好的进行分辨,于是在LR的帮助函数中查找到了lr_save_datetime函数,一试验,感觉非常不错,满足了我的要求,下面就将lr_save_datetime函数的使用方法记载下来,以便后用:

<!--[if !supportEmptyParas]--> <!--[endif]-->

函数原型:

voidlr_save_datetime(const char *format,intoffset,const char *name);

<!--[if !supportEmptyParas]--> <!--[endif]-->

format期望输出的日期格式比如说%Y、%m、%d、%X等等

<!--[if !supportEmptyParas]--> <!--[endif]-->

offset:类似与表示时间的一些关键字常量,主要有DATE_NOW, TIME_NOW, ONE_DAY, ONE_HOUR, ONE_MIN,他们可以单独使用,也可以联合使用,比如DATE_NOW + TIME_NOW

<!--[if !supportEmptyParas]--> <!--[endif]-->

name:期望将时间保存到的那个参数的名称

<!--[if !supportEmptyParas]--> <!--[endif]-->

举例:

lr_save_datetime(“%Y-%m-%d %x”,DATE_NOW+TIME_NOW,“DateTimeParam”);

lr_output_message(lr_eval_string("Now is {DateTimeParam}"));

 

 

 

 

loadrunner函数 lr_save_datetime



今天到51testing的blog里查看文章《Loadrunner获取当前系统时间》的回复,51testing的网友persist提到了一个lr函数实现的方法也可以实现,在这里非常感谢persist;只有

交流和不断的学习,我们的技术水平才能进步哈!!

本人在51testing的blog全部为原创,转载请注明!!

扯的有点远了,还是看这个函数吧!!

 

【lr_save_datetime】

void lr_save_datetime(const char *format, int offset, const char *name);

中文解释:
lr_save_datetime将当前日期和时间,或具有指定偏移的日期和时间保存在参数中。如果达到MAX_DATETIME_LEN个字符,结果字符串将被截断。

参数说明:
1、const char *format
   格式化信息
   同fopen、lr_message等相同;例如:"the first is %s"

2、int offset
   时间的偏移量
     DATE_NOW(现在的日期)
     TIME_NOW(现在的时间)
     ONE_DAY(一天的时间)
     ONE_HOUR(一小时的时间)
     ONE_MIN(一分钟的时间)

   需要注意的是,时间的偏移量可以使用公式,例如:DATE_NOW+ONE_DAY

   这样,我们就可以取得昨天、明天的日期了
     DATE_NOW-ONE_DAY(昨天)
     DATE_NOW+ONE_DAY(明天)

   那么,我们就可以使用如下表示得到前天的日期
     lr_save_datetime("%Y-%B-%d",DATE_NOW-2*(ONE_DAY),"abc");
     lr_save_datetime("%Y-%B-%d",DATE_NOW-2*24*(ONE_HOUR),"abc");
     lr_save_datetime("%Y-%B-%d",DATE_NOW-2*24*60*(ONE_MIN),"abc");

   当然,我们也可以使用如下表示2个小时后的时间
     lr_save_datetime("%H:%M:%S",TIME_NOW+2*(ONE_HOUR),"ab");   
     lr_save_datetime("%H:%M:%S",TIME_NOW+2*60*(ONE_MIN),"ab");
 

3、const char *name
   参数保存的参数名;使用时lr_eval_string("{参数名}")

示例如下:
===========================================
Action()
{
    lr_save_datetime("%y-%b-%d",DATE_NOW-2*24*(ONE_HOUR),"abc");
     //保存前天的日期到参数abc中
    lr_message("the day before yesterday is:%s",lr_eval_string("{abc}"));
     //输出abc的值
    lr_save_datetime("%H:%M:%S",TIME_NOW+2*(ONE_HOUR),"ab");
     //保存2个小时后的时间到参数ab中
    lr_message("the time after two hour is:%s",lr_eval_string("{ab}"));
     //输入ab的值
    return 0;
}


执行结果如下:
the day before yesterday is:07-七月-04
the time after two hour is:15:33:41
===========================================


附:《lr_save_datetime格式参数表》
%a 星期几的简写
%A 星期几的全称
%b 月分的简写
%B 月份的全称
%c 标准的日期的时间串
%C 年份的后两位数字
%d 十进制表示的每月的第几天
%D 月/天/年
%e 在两字符域中,十进制表示的每月的第几天
%F 年-月-日
%g 年份的后两位数字,使用基于周的年
%G 年分,使用基于周的年
%h 简写的月份名
%H 24小时制的小时
%I 12小时制的小时
%j 十进制表示的每年的第几天
%m 十进制表示的月份
%M 十时制表示的分钟数
%n 新行符
%p 本地的AM或PM的等价显示
%r 12小时的时间
%R 显示小时和分钟:hh:mm
%S 十进制的秒数
%t 水平制表符
%T 显示时分秒:hh:mm:ss
%u 每周的第几天,星期一为第一天 (值从0到6,星期一为0)
%U 第年的第几周,把星期日做为第一天(值从0到53)
%V 每年的第几周,使用基于周的年
%w 十进制表示的星期几(值从0到6,星期天为0)
%W 每年的第几周,把星期一做为第一天(值从0到53)
%x 标准的日期串
%X 标准的时间串
%y 不带世纪的十进制年份(值从0到99)
%Y 带世纪部分的十制年份
%z,%Z 时区名称,如果不能得到时区名称则返回空字符。
%% 百分号

 

posted @ 2015-06-08 18:53  Agoly  阅读(6859)  评论(0编辑  收藏  举报