Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Создать клиентскую библиотеку для сервиса ws3.morpher.ru #1

Open
bzaar opened this issue Apr 8, 2022 · 0 comments

Comments

@bzaar
Copy link
Member

bzaar commented Apr 8, 2022

Имеется HTTP API: https://morpher.ru/ws3/

Для него есть несколько клиентских библиотек на разных языках программирования:

По аналогии с ними нужно сделать Composer-пакет, включающий библиотеку функций на PHP для вызова всех функций HTTP API. Можно взять за основу вот этот код.

Решение оформить в виде пул-реквеста к этому (пока пустому) репозиторию.

Решение должно включать в себя:

  • документацию примерно того же объема, что и JS-пакет: https://www.npmjs.com/package/morpher-ws3-client
  • юнит-тесты, проверяющие реакцию библиотеки на все возможные ответы сервиса WS3 (HTTP Status = 200, 4xx, 500) для каждого эндпойнта. Есть коды ошибок, общие для всех эндпойнтов (https://morpher.ru/ws3/#errors) и специфичные для конкретных эндпойнтов (например, https://morpher.ru/ws3/#qazaq/declension)
  • интеграционные тесты, работающие с «живым» веб-сервисом https://ws3.morpher.ru. Предусмотреть передачу в эти тесты секретного ключа-токена, который будет храниться в настройках CI-среды.

Тесты должны выполняться в CI-среде вроде TravisCI, GitHub Actions или AppVeyor (мне ближе AppVeyor). Файлы конфигурации CI-среды (appveyor.yml и подобные) должны быть внутри репозитория.

Код библиотеки должен быть совместим с PHP 7+.

Юнит-тесты

На каждый тип запроса (эндпойнт) нужны как минимум такие тесты:

  1. проверка правильности составления запроса к WS3
  2. проверка правильности разбора ответа WS3
  3. проверка возбуждения исключений в случае ошибочного ответа WS3 - по тесту на каждый код ошибки 4xx (завести отдельный тип исключения на каждый код ошибки)
  4. проверка возбуждения исключений в случае неожиданного ответа WS3 (500, таймаут, невалидный JSON).
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant