接口测试教程 - PostMan(九)变量设置

接触过任何语言类和一些测试工具的同学应该都知道变量这个概念。

变量是用来存储动态值的静态标识符。变量标识的信息可以更改,但是对变量的操作保持不变。

Postman 中的变量也是如此。我们可以在多个位置重用变量值。如果变量的值发生变化,变量的每个实例都会相应的更改,从而减少了重复修改的需要和出错的可能性。

比如,我们的所有接口都是同一个域名http://nemo.test,但这个域名可能会变,比如我们运行在开发环境的时候,域名会变为 http://nemo.dev ,如果我们不使用变量而是老老实实写的话。当我们写上几十上百个请求的时候,此时如果需要在不同的环境中运行时,将会是一个噩梦,你需要逐一修改每个请求的 Host。

我们还可以通过变量从一个请求中获取数据,在另一个请求中使用它们。这就是依赖的处理,后面的章节会再讲。

简而言之,使用变量有如下好处:

  • 重用数据使代码(请求)保持DRY(don't repeat yourself 不要自我重复);
  • 配置不同的设置以使用不同的环境;
  • 从 Collection 中的响应中提取数据供后续请求使用。

在 Postman 中有以下几种变量:

  • 局部变量 local
  • data 文件中的变量 data
  • 环境变量 environment
  • Collection 中的变量 collection
  • 全局变量 global
  • 内置变量 dynamic

除局部变量以外的其他变量值只能是字符串,如果要存储对象或者其他数据类型的数据,需要先转换为字符串(JSON.stringify()),然后在使用时转换回去(JSON.parse())。

变量优先级

以下的图可以说明变量的优先级,越外层的变量优先级越低。

比如同一个变量名 host,在 environment 和 global 中分别设置了不同的值,那么最终运行请求的时候,实际使用的是 environment 中的值,因为 environment 变量的优先级比 global 更高。

设置变量

我们先了解一下如何设置这些变量,有部分内容已经在前面提到过了,另外内置变量由 Postman 提供不需要设置。

1. 局部变量 local variable

局部变量是在代码(Pre-request,Tests)中设置的。使用 JavaScript 的变量语法即可。

其优先级最高,但是仅在当前的脚本环境中有效,对于上图中的json变量,只在当前请求的 Tests 中的脚本有效。

data 文件中的变量 data

在 Collection 运行中我们讲过可以加载数据驱动的文件(CSV,JSON)中的值。

上图中通过加载的数据文件中读取出的三个变量pathvaluep

环境变量 environment

环境变量可以通过两种方式设置,一种是上一节讲过的在环境设置中进行设置:

上图中设置了一个变量host,其值为http://127.0.0.1

另一种设置环境变量的方法是,在代码(Pre-request,Tests)中设置。

上图中通过代码设置了一个变量 db_host,其值为 192.168.1.222

Collection 中的变量 collection

在 Collection 中可以设置变量,设置的方法是在 Collection 编辑界面的 Variables选项卡中:

上图中设置了一个 Collection 变量 path,其值为 post

也可以看到这里的设置界面很类似环境变量的设置。

全局变量 global

全局变量的设置类似环境变量的设置,也有两种方式。

一种方法,那就是通过代码(Pre-request,Tests)设置。

上图中通过代码设置了一个全局变量 username, 其值为nemo

另一种方法是在环境设置(就是设置环境变量那个地方)界面进行设置:

上图中设置了全局变量PI,其值为 3.14159265358

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,445评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,889评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,047评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,760评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,745评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,638评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,011评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,669评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,923评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,655评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,740评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,406评论 4 320
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,995评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,961评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,023评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,483评论 2 342

推荐阅读更多精彩内容