frostfs-testcases/README.md

129 lines
5.5 KiB
Markdown
Raw Normal View History

2020-11-28 22:16:52 +00:00
## Запуск тесткейсов
### Локальный запуск тесткейсов
2020-11-28 22:16:52 +00:00
1. Устаносить зависимости (только для первого запуска):
- pip3 install robotframework
2020-11-28 22:16:52 +00:00
- pip3 install pexpect
- pip3 install requests
(pip3 заменить на соответсвующий менеджер пакетов python в системе).
При этом должен быть запущен dev-env с тестируемым окружением.
2. Выпольнить `make run`
3. Логи будут доступны в папке artifacts/ после завершения тестов с любым из статусов.
2020-08-13 22:09:00 +00:00
### Запуск произвольного тесткейса
2020-11-28 22:16:52 +00:00
2020-09-06 11:33:20 +00:00
Для запуска произвольного тесткейса нужно выполнить команду:
2020-08-13 22:09:00 +00:00
`robot --timestampoutputs --outputdir artifacts/ robot/testsuites/integration/<testsuite name>.robot `
Для запуска доступны следущие сценарии:
2020-11-29 00:51:38 +00:00
2020-08-13 22:09:00 +00:00
* acl_basic.robot - базовый ACL
2020-11-29 00:53:41 +00:00
* acl_extended.robot - extended ACL
2020-11-29 00:51:38 +00:00
* acl_baearer.robot - Bearer Token ACL
2020-08-13 22:09:00 +00:00
* object_complex.robot - операции над простым объектом
* object_simple.robot - операции над большим объектом
2020-11-29 00:51:38 +00:00
* withdraw.robot - оперция Deposit и Withdraw с счета NeoFS
2020-11-30 10:53:28 +00:00
* netmap_simple.robot - проверка Placement policy
2020-11-29 04:28:01 +00:00
* replication.robot - базовый тесткейс проверки репликации объектов
2020-08-13 22:09:00 +00:00
### Запуск тесткейсов в докере
2020-11-28 22:16:52 +00:00
1. Задать переменные окружения для работы с dev-env:
```
export REG_USR=<registry_user>
export REG_PWD=<registry_pass>
export JF_TOKEN=<JF_token>
```
2. Выполнить `make build`
3. Выполнить `make run_docker`
4. Логи будут доступны в папке artifacts/ после завершения тестов с любым из статусов.
### Запуск тесткейсов в докере с произвольными коммитами
На данный момент доступны произовльные коммиты для NeoFS Node и NeoFS CLI.
Для этого достаточно задать переменные окружения перед запуском `make build`.
```
export BUILD_NEOFS_NODE=<commit or branch>
```
2020-11-28 22:16:52 +00:00
2020-11-30 10:53:28 +00:00
### Запуск smoke-тестов
Есть сьют со smoke-тестами для CDN-гейтов `robot/testsuites/smoke/selectelcdn_smoke.robot`.
Ему требуются отдельные переменные, в отличие от сьютов NeoFS, которые запускаются на
девэнве. Чтобы библиотеки кейвордов их использовали, нужно установить переменную
окружения
```
export ROBOT_PROFILE=selectel_smoke
```
По умолчанию кейворды используют переменные из файла `robot/resources/lib/neofs_int_vars.py`.
```
robot --outputdir artifacts/ robot/testsuites/smoke/selectelcdn_smoke.robot
```
2020-11-28 23:17:36 +00:00
### Генерация документации
Для генерации документации по шагам:
```
python3 -m robot.libdoc robot/resources/lib/neofs.py docs/NeoFS_Library.html
python3 -m robot.libdoc robot/resources/lib/payment_neogo.py docs/Payment_Library.html
```
Для генерации документации по тесткейсам:
```
python3 -m robot.testdoc robot/testsuites/integration/ docs/testcases.html
```
2020-11-28 22:16:52 +00:00
## Создание тесткейсов
### Source code overview
`robot/` - Files related/depended on Robot Framework.
`robot/resources/` - All resources (Robot Framework Keywords, Python Libraries, etc) which could be used for creating test suites.
`robot/resources/lib/` - Common Python Libraries depended on Robot Framework (with Keywords). For example neofs.py, payment.py.
`robot/variables/` - All variables for tests. It is possible to add the auto-loading logic of parameters from the smart-contract in the future. Contain python files.
`robot/testsuites/` - Robot Test Suites and Test Cases.
`robot/testsuites/integration/` - Integration test suites and test cases
`robot/testsuites/fi/` - Fault Injection test suites and test cases
2020-11-29 00:46:53 +00:00
### Code style
2020-11-28 22:16:52 +00:00
Robot Framework keyword should use space as a separator between particular words
The name of the library function in Robot Framework keyword usage and the name of the same function in the Python library must be identical.
The name of GLOBAL VARIABLE must be in UPPER CASE, the underscore ('_')' symbol must be used as a separator between words.
The name of local variable must be in lower case, the underscore symbol must be used as a separator between words.
The names of Python variables, functions and classes must comply with accepted rules, in particular:
Name of variable/function must be in lower case with underscore symbol between words
Name of class must start with a capital letter. It is not allowed to use underscore symbol in name, use capital for each particular word.
For example: NeoFSConf
Name of other variables should not be ended with underscore symbol
On keywords definition, one should specify variable type, e.g. path: str
2020-11-29 00:46:53 +00:00
### Robot style
2020-11-28 22:16:52 +00:00
Следует всегда заполнять секции [Tags] и [Documentation] для Testcase'ов и Documentation для Test Suite'ов.
2020-11-29 00:46:53 +00:00
### Robot-framework User Guide
2020-11-28 22:16:52 +00:00
2020-11-30 10:53:28 +00:00
http://robotframework.org/robotframework/latest/RobotFrameworkUserGuide.html