【pytest】Hook 方法之 pytest_addoption :註冊命令行參數

Hook 方法之 pytest_addoption :

pytest_addoption 可以讓用戶註冊一個自定義的命令行參數,方便用戶將數據傳遞給 pytest;

這個 Hook 方法一般和 內置 fixture pytestconfig 配合使用,pytest_addoption 註冊命令行參數,pytestconfig 通過配置對象讀取參數的值;

 pytest_addoption 註冊、pytestconfig 獲取命令行參數 :

# conftest.py
 
import pytest
 
# 註冊自定義參數 cmdopt 到配置對象
def pytest_addoption(parser):
    parser.addoption("--cmdopt", action="store",
                     default="None",
                     help="將自定義命令行參數 ’--cmdopt' 添加到 pytest 配置中")
 
# 從配置對象獲取 cmdopt 的值
@pytest.fixture(scope='session')
def cmdopt(pytestconfig):
    return pytestconfig.getoption('--cmdopt')
 
# 然後任何 fixture 或測試用例都可以調用 cmdopt 來獲得設備信息

parser.addoption() 參數說明:

  1. name:自定義命令行參數的名字,可以是:"foo", "-foo" 或 "--foo";
  2. action:在命令行中遇到此參數時要採取的基本操作類型;
  3. nargs:應該使用的命令行參數的數量;
  4. const:某些操作和nargs選擇所需的常量值;
  5. default:如果參數不在命令行中,則生成的默認值。
  6. type:命令行參數應該轉換爲的類型;
  7. choices:參數允許值的容器;
  8. required:命令行選項是否可以省略(僅可選);
  9. help:對參數作用的簡要說明;
  10. metavar:用法消息中參數的名稱;
  11. dest:要添加到 parse_args() 返回的對象中的屬性的名稱;

挑幾個比較常用的來演示:

1. name:這個不用多說,自定義的參數的名字;

2. action 、default 和 const、help

action="store":默認,只存儲參數的值,可以存儲任何類型的值,此時 default 也可以是任何類型的值,而且命令行參數多次使用也只能生效一個,最後一個值覆蓋之前的值;

# 註冊自定義參數 cmdopt 到配置對象
def pytest_addoption(parser):
    parser.addoption("--cmdopt", action="store",
                     default="這個是默認值...",
                     help="將命令行參數 ’--cmdopt' 添加到 pytest 配置中")

# 從配置對象中讀取自定義參數的值
@pytest.fixture(scope="session")
def cmdopt(request):
    return request.config.getoption("--cmdopt")

# 將自定義參數的值打印出來
@pytest.fixture(autouse=True)
def fix_1(cmdopt):
    print('\n --cmdopt的值:',cmdopt)

if __name__ == '__main__':
    # 使用參數
    pytest.main(['-s', '--cmdopt=98k'])
# 控制檯打印參數值:
============================= test session starts =============================
test_Z.py::TestDemoA::test_A_001 
 --cmdopt的值: 98k
PASS
============================== 1 passed in 0.02s ==============================

action="append":存儲一個列表,用 append 模式 將可以同時多次使用自定義參數,並且 default  默認值必須是一個列表,pytest 會把 default  默認參數的值和多個自定義參數的值放在一個列表中:

# 註冊自定義參數 cmdopt 到配置對象
def pytest_addoption(parser):
    parser.addoption("--cmdopt", action="append",
                     default=['這是默認參數'],
                     help="將命令行參數 ’--cmdopt' 添加到 pytest 配置中")

if __name__ == '__main__':
    # 使用參數
    pytest.main(['-s', '--cmdopt=98k', '--cmdopt=毛瑟小手槍'])
# 控制檯打印參數值:
============================= test session starts =============================
test_Z.py::TestDemoA::test_A_001 
 --cmdopt的值: ['這是默認參數', '98k', '毛瑟小手槍']
PASS
============================== 1 passed in 0.02s ==============================

action="store_const":使用 const 爲命令行參數指定一個常量值,必須和 const 參數同時使用,使用這個模式後命令行參數不能賦值:

def pytest_addoption(parser):
    parser.addoption("--cmdopt", action="store_const",
                     default='這是默認參數',
                     const='這個是爲命令行參數指定的常量值...',
                     help="將命令行參數 ’--cmdopt' 添加到 pytest 配置中")

if __name__ == '__main__':
    pytest.main(['-s','--cmdopt'])
# 控制檯打印參數值:
============================= test session starts =============================
test_Z.py::TestDemoA::test_A_001 
 --cmdopt的值: 這個是爲命令行參數指定的常量值...
PASS
============================== 1 passed in 0.02s ==============================

action="append_const":存儲一個列表,使用 const 爲命令行參數指定一個常量值,並將 default 默認值和 const  常量值添加到列表中,這個模式可以同時多次使用自定義參數,但是還是不能賦值,只能使用常量;

def pytest_addoption(parser):
    parser.addoption("--cmdopt", action="append_const",
                     default=['這是默認參數'],
                     const='這個是爲命令行參數指定的常量值...',
                     help="將命令行參數 ’--cmdopt' 添加到 pytest 配置中")

if __name__ == '__main__':
    pytest.main(['-s','--cmdopt', '--cmdopt'])
# 控制檯打印參數值:
============================= test session starts =============================
test_Z.py::TestDemoA::test_A_001 
 --cmdopt的值: ['這是默認參數', '這個是爲命令行參數指定的常量值...', '這個是爲命令行參數指定的常量值...']
PASS
============================== 1 passed in 0.02s ==============================

3. type:type 的類型可以是 python 的基礎類型,比如:int,str,float,list 等類型,如果不指定類型的話,pytest會把接受到的參數值都默認爲 str 類型,所以我們有時需要指定參數的類型:

注意:在使用 type 指定類型時,也需要把 default 的類型修改爲同樣的類型!

def pytest_addoption(parser):
    parser.addoption("--cmdopt", action="store",
                     default=100,
                     type=int,
                     help="將命令行參數 ’--cmdopt' 添加到 pytest 配置中")

if __name__ == '__main__':
    pytest.main(['-s', f'--cmdopt=888'])
# 控制檯打印參數值:
============================= test session starts =============================
--cmdopt的值: 888
--cmdopt的類型: <class 'int'>
PASS
============================== 1 passed in 0.02s ==============================

4. choices:choices 可以指定幾個值,自定義參數必須在這幾個值中選擇一個,否則會報錯:

def pytest_addoption(parser):
    parser.addoption("--cmdopt", action="store",
                     default='100',
                     choices= ['python', 'java', 'c++'],
                     help="將命令行參數 ’--cmdopt' 添加到 pytest 配置中")

if __name__ == '__main__':
    pytest.main(['-s', f'--cmdopt=888'])
# 控制檯打印結果:

ERROR: usage: conftest.py [options] [file_or_dir] [file_or_dir] [...]
conftest.py: error: argument --cmdopt: invalid choice: '888' (choose from 'python', 'java', 'c++')

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章