1.环境变量
很多时候,我们在开发时会有多个部署位置,比如一个用于测试,一个用于生产。通常的流程是先使用测试部署进行开发调试测试,再到生产部署上进行。对于同一个API,仅仅是URL略有不同,如果使用了环境变量,那么我们就不需要需要存储多条API,或者在使用的时候改一下URL。
- 点击 Manage Environments
-
设置测试环境的环境变量
填写环境变量的名称为:test environment
填写key与value值,key的值是对应的自定义环境变量名称,value是该环境变量的值。
-
如下图,则是将接口地址
api.groupy.cn:8080/groupyuser/loginThirdpart?snsid=&snspf=&tokenize=
改成api.groupy.{{value}}:8080/groupyuser/loginThirdpart?snsid=&snspf=&tokenize=
{{value}}则是一个环境变量。
同理,正式环境的环境变量,设置名称为formal environment,将value值设置为vip。
-
{{URL}}/groupyuser/loginThirdpart?snsid=&snspf=&tokenize=
填上完整的接口路径,效果也是一样的。
环境 key value 正式环境 URL api.groupy.vip:8080 测试环境 URL api.groupy.cn:8080
-
保存好设置的环境变量,测试接口时就可以在该处切换所需要的环境变量。
在这个例子里,我设置了两组环境变量,一个叫test environment用于测试环境测试,一个formal environment用于正式环境测试,其中都包含一个名为value的环境变量。这样,如果我想在测试或正式的测试进行切换时,只需要切换环境变量就可以了。
- 点击 Manage Environments,可对你设置的环境变量进行简单的操作,如分享,删除,下载等。
2.全局变量-Tests
在测试接口时,我们通常需要通过一个API获取一个token用于后续API的调用,那么我们每次都把获取的token拷贝到要使用的API里去,如果用全局变量的话,可以极大的简化这一流程。
-
在能获取token值的接口中,输入脚本,以获取token的值。
var jsonData = JSON.parse(responseBody); postman.setGlobalVariable("idolToken", jsonData.data.accessToken);
注意:在API设置的选项卡中有Pre-request Script和Tests两项,它们可以都接受代码片断,并分别在请求发出前和请求发出后执行。获取token值是在发送请求后执行的。
- 这个全局变量idolToken被保存之后,就可以在其他需要使用到这个全局变量的地方调用它了。输入
Token {{
后,系统会自动帮你列出所有的全局变量以及它的值。
-
同样地,用以上的方法,还可以同时或分开设置其他的全局变量。
代码参考:
var Data = JSON.parse(responseBody); if (Data.data.accessToken) { tests["Body has token"] = true; postman.setGlobalVariable("user_id", Data.data.nickname); postman.setGlobalVariable("user_token", Data.data.accessToken); } else { tests["Body has token"] = false; }
- 在manage environments中,点击Globals可以管理这些全局变量,也可以导出分享。
3.全局变量-Pre-request Script
API设置中的Pre-request Script和Tests,可以分别在API调用前和调用后执行脚本。对于调用前脚本,通常可以清除或设置一些环境变量/全局变量来对API调用进行控制。
-
在Pre-request Script写入预设的环境变量和全局变量。这里把get请求参数的snsid和snspf设置为全局变量并为其赋值。发送请求之后,也能返回正确的结果。
注意:测试脚本可以自己写,也可以使用选项卡右边postman所提供的脚本,直接点击使用,输入参数即可。
参考代码:
//预设全局变量 pm.globals.set("idol_snsid", "729952657834573824"); pm.globals.set("idol_snspf", "tw"); //预设环境变量 pm.environment.set("url", "http://api.groupy.vip:8080");
- 如果是已存在的全局变量(在变量管理中能看到的),则你在输入参数时,系统会自动为你补全。
4.单个API测试
在2.全局变量-Tests,我们可以获取和调用结果,方便于我们控制全局变量。但这个有一个更重要的功能,就是写测试脚本,然后对测试结果进行判断。基本的格式如下:
// description 为该测试的描述,value不等于false,这个测试就是PASS tests[description] = value
-
在tests选项卡内写入测试脚本
var Data = JSON.parse(responseBody); tests ["fans id >= 200"] = Data.data.id >= 200; tests ["fans id < 200"] = Data.data.id < 200;
-
点击send执行测试脚本,然后就可以看到测试用例的执行是否通过。
在该例子中,该用户的id是165,因此执行结果中只有一个是通过的。
5.测试一组API
如果你有一组API,都写了测试脚本,不需要一个个的运行,点击左上角的Runner,可以对一组API进行测试。
选择要测试的API组、环境变量组、运行次数、运行延时,点击开始测试,它会按顺序调用所有API并展示测试结果,你还可以将测试结果导出分享。
不同接口的get请求中用到的同一个参数,也能用全局变量去设置。