前言
一般來說,在進行實際應用的開發過程中,應用會擁有不同的運行環境,通常會有以下環境:
- 本地開發環境
- 測試環境
- 生產環境
在不同環境中,我們可能會使用不同的數據庫或郵件發送驅動等配置,這時候則需要通過 .env 文件來針對不同的運行環境作不同的設置。
環境變量
在自動化測試中,有時需要借助環境變量實現某些特定的目的,常見的場景包括:
- 切換測試環境
- 切換測試配置
- 存儲敏感數據(從信息安全的角度出發)
Windows系統中使用 set 命令設置環境變量和值,接下來設置以下變量
- host = http://127.0.0.1:8000 設置host值,可以一鍵切換運行的環境
- user = test 設置登陸賬號和密碼,切換賬號測試
- psw = 123456 設置登陸賬號和密碼,切換賬號測試
打開cmd,使用 set key=value
格式設置環境變量(linux使用 export
命令)
C:\Users\dell>set host=http://127.0.0.1:8000
C:\Users\dell>set name=test
C:\Users\dell>set password=123456
查看環境變量值使用 set keyname
查看對應的值
C:\Users\dell>set host
host=http://127.0.0.1:8000
C:\Users\dell>set name
name=test
C:\Users\dell>set password
password=123456
在windows系統里面,命令行引用變量用 %var%
C:\Users\dell>echo 賬號:%name%
賬號:test
在python中引用剛才設置的環境變量,先導入os模塊,用 os.environ
方法獲取(environ是在os.py中定義的一個dict environ = {})
# 上海悠悠,QQ交流群:750815713
C:\Users\dell>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:\soft\untitled\projectdemo>hrun test_env_demo.yml
INFO Loading environment variables from D:\soft\untitled\projectdemo\.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:\soft\untitled\projectdemo\reports\1569661153.html
D:\soft\untitled\projectdemo>
如果.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:\soft\untitled\projectdemo\.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/
在 HttpRunner 2.x版本中內置了函數 environ(簡稱 ENV)