httprunner學習13-環境變數.env

  • 2019 年 10 月 8 日
  • 筆記

前言

一般來說,在進行實際應用的開發過程中,應用會擁有不同的運行環境,通常會有以下環境:

  • 本地開發環境
  • 測試環境
  • 生產環境

在不同環境中,我們可能會使用不同的資料庫或郵件發送驅動等配置,這時候則需要通過 .env 文件來針對不同的運行環境作不同的設置。

環境變數

在自動化測試中,有時需要藉助環境變數實現某些特定的目的,常見的場景包括:

  • 切換測試環境
  • 切換測試配置
  • 存儲敏感數據(從資訊安全的角度出發)

Windows系統中使用 set 命令設置環境變數和值,接下來設置以下變數

  • host = http://127.0.0.1:8000 設置host值,可以一鍵切換運行的環境
  • user = test 設置登陸帳號和密碼,切換帳號測試
  • psw = 123456 設置登陸帳號和密碼,切換帳號測試

打開cmd,使用 set key=value 格式設置環境變數(linux使用 export 命令)

C:Usersdell>set host=http://127.0.0.1:8000    C:Usersdell>set name=test    C:Usersdell>set password=123456

查看環境變數值使用 set keyname 查看對應的值

C:Usersdell>set host  host=http://127.0.0.1:8000    C:Usersdell>set name  name=test    C:Usersdell>set password  password=123456

在windows系統裡面,命令行引用變數用 %var%

C:Usersdell>echo 帳號:%name%  帳號:test

在python中引用剛才設置的環境變數,先導入os模組,用 os.environ 方法獲取(environ是在os.py中定義的一個dict environ = {})

# 上海悠悠,QQ交流群:750815713  C:Usersdell>python  Python 3.6.0 (v3.6.0:41df79263a11, Dec 23 2016, 08:06:12) [MSC v.1900 64 bit (AMD64)] on win32  Type "help", "copyright", "credits" or "license" for more information.  >>> import os  >>> os.environ.get('host')  'http://127.0.0.1:8000'  >>> os.environ.get('name')  'test'  >>> os.environ.get('password')  '123456'  >>>

所有的在cmd命令行下對環境變數的修改只對當前窗口有效,不是永久性的修改。也就是說當關閉此cmd命令行窗口後,將不再起作用。 永久性修改環境變數的方法可以通過我的電腦-〉屬性-〉高級,來設置系統的環境變數。

.env 文件設置環境變數

在cmd設置的環境變數沒法存儲,所以需要創建用過.env文件來存放環境變數,存儲採用 name=value 的格式: winodws無法直接創建 .env 的文件,會提示文件名不能為空,這裡使用 pycharm 新建用過 .env 文件 (或者你新建用過 1.env 的文件,在cmd窗口重命名 rename 1.env .env

# .env  host=http://127.0.0.1:8000  name=test  password=123456

接下來在debugtalk.py中寫一個ENV函數,用於讀取環境變數,用於在 YAML/JSON 腳本中直接引用環境變數 (在 HttpRunner 2.x版本中內置了函數 environ(簡稱 ENV))

# debugtalk.py  import os  # 上海悠悠,QQ交流群:750815713    def ENV(keyname):      '''      獲取環境keyname對應的值      :return:      '''      value = os.environ.get('keyname', '')      return value

HttpRunner 運行時,會自動將.env文件中的內容載入到運行時(RunTime)的環境變數中,然後在運行時中就可以對環境變數進行讀取了。

腳本案例

引用環境變數使用ENV函數 ${ENV(keyname)

# 上海悠悠,QQ交流群:750815713  - config:      name: logincase      variables: {}      request:           base_url: ${ENV(host)}      # 引用環境變數host值  - test:      name: login case1      request:          url: /api/v1/login/          method: POST          headers:              Content-Type: application/json              User-Agent: python-requests/2.18.4          json:              username: ${ENV(name)}  # 引用環境變數name值              password: ${ENV(password)}        # 引用環境變數password值      extract:          - token: content.token     # 提取token      validate:          - eq: [status_code, 200]          - eq: [headers.Content-Type, application/json]          - eq: [content.msg, login success!]          - eq: [content.code, 0]

運行用例

D:softuntitledprojectdemo>hrun test_env_demo.yml  INFO     Loading environment variables from D:softuntitledprojectdemo.env  login case1  INFO     POST /api/v1/login/  INFO     status_code: 200, response_time(ms): 517.84 ms, response_length: 109 bytes  INFO     start to extract from response object.  INFO     start to validate.  .    ----------------------------------------------------------------------  Ran 1 test in 0.525s    OK  INFO     Start to render Html report ...  INFO     Generated Html report: D:softuntitledprojectdemoreports1569661153.html    D:softuntitledprojectdemo>

如果.env文件和debugtalk不在同一個文件夾下,可以使用 --dot-env-path 參數指定.env的路徑

hrun test_env_demo.yml —dot-env-path /path/to/.env 可以設置—log-level 參數為debug模式,查看更加詳細的運行日誌

>hrun test_env_demo.yml --log-level debug  INFO     Loading environment variables from D:softuntitledprojectdemo.env  DEBUG    Loaded variable: host  DEBUG    Loaded variable: name  DEBUG    Loaded variable: password  login case1  DEBUG    call hook: ${setup_hook_prepare_kwargs($request)}  INFO     POST /api/v1/login/  DEBUG    request kwargs(raw): {'headers': {'content-type': 'application/json', 'user-agent': 'python-requests/2.18.4'}, 'json': {'username': 'test', 'password': '123456'}}  DEBUG    processed request:  > POST http://127.0.0.1:8000/api/v1/login/