CodeceptJS opinionated setup with BDD tests for multiple platforms:
- TypeScript
- BDD (Gherkin)
- Dockerfile and Docker Compose
- CI (GitHub Actions)
- Static code analysis: formatting and linting
- Separate configuration and tests launch for:
- Web (via
Playwright
) - Mobile (via
WebDriver
+Appium
):- BrowserStack device farm for remote
Appium
server
- BrowserStack device farm for remote
- Backend
- Infrastructure
- Web (via
- Clone repository with
git
andcd
into cloned repo - Install development / system dependencies (read below)
- Set environment variables (read below)
- Launch:
- Containerized:
docker-compose --profile build up
- Non-containerized:
- Switch to required
NodeJS
version:nvm install
(if not installed)nvm use
- Install packages:
npm install
- Run tests:
npm run test
(or other commands - read below)
- Switch to required
- Containerized:
System dependency | Required version | Description |
---|---|---|
Docker Compose | 2.x |
Container orchestration |
Docker Engine | 20.x |
Container technology |
Node.js | 20.11.1 |
JS runtime |
nvm | 2.x |
Node Version Manager |
Autotests can be launched locally or remotely via Appium
-
Android requires installation of the following dependencies:
System dependency Required version Description Java 8.x
Java runtime, JDK
(openjdk
can be used)Android SDK Build Tools 24.x
Android SDK
(recommended to be installed byAndroid Studio
)Additional info (Android): driver setup, preparing app, running tests
-
iOS is not defined at the moment: (TODO)
Additional info (iOS): driver setup, preparing app, running tests
Does not require any additional system dependencies:
-
BrowserStack:
-
Other remote options: (TODO)
Launch via Playwright
which is shipped with patched browser engines:
- Chromium (Chrome)
- Gecko (Firefox)
- WebKit (Safari)
Browser engines are being installed automatically. If needed, manual installation can be triggered
by playwright:install-browsers
command.
Some functionality requires system dependencies (typically, for WebKit support). They can be
installed by playwright:install-deps
command (works only for Debian/Ubuntu).
More info
Not implemented at the moment: (TODO)
ENV variable | Required? | Default state | Example value | Description |
---|---|---|---|---|
CI |
- | false |
true |
Defines whether running in CI or not |
HEADLESS |
- | false |
true |
Headless launch for CodeceptJS (always headless when CI=true ) |
PAUSE_ON_FAIL |
- | false |
true |
Pause CodeceptJS tests execution on fail (never pauses when CI=true ) |
ENV variable | Required? | Default state | Example value | Description |
---|---|---|---|---|
TESTS_API_GRAPHQL_BASE_URL |
- | http://localhost:3000/graphql |
https://test.example/graphql |
Base url for GraphQL API |
TESTS_API_REST_BASE_URL |
- | http://localhost:3000/api |
https://test.example/api |
Base url for REST API |
ENV variable | Required? | Default state | Example value | Description |
---|---|---|---|---|
TESTS_MOBILE_COMMON_LAUNCH_TYPE |
+ | - | local or remote |
Determines autotests launch type |
TESTS_MOBILE_COMMON_USER_USERNAME |
+ | - | [email protected] |
Username |
TESTS_MOBILE_COMMON_USER_PASSWORD |
+ | - | randomsequenceofsymbols |
Password |
ENV variable | Required? | Default state | Example value | Description |
---|---|---|---|---|
TESTS_MOBILE_LOCAL_HOST |
- | localhost |
docker-container-name |
Appium Host |
TESTS_MOBILE_LOCAL_PORT |
- | 4723 |
1337 |
Appium Port |
TESTS_MOBILE_LOCAL_APP_PATH |
+ | - | app-example-1.0.0.apk |
Path to app file (including filename) |
TESTS_MOBILE_LOCAL_PLATFORM |
+ | - | Android or iOS |
Platform (OS) |
TESTS_MOBILE_LOCAL_DEVICE |
+ | - | Samsung Galaxy S10 |
Device |
TESTS_MOBILE_LOCAL_CAPABILITIES |
- | Check config | - | Read here |
ENV variable | Required? | Default state | Example value | Description |
---|---|---|---|---|
TESTS_MOBILE_BROWSERSTACK_USERNAME |
+ | - | user_randomsequenceofsymbols |
BrowserStack API username |
TESTS_MOBILE_BROWSERSTACK_ACCESS_KEY |
+ | - | randomsequenceofsymbols |
BrowserStack API access key |
TESTS_MOBILE_BROWSERSTACK_HOST |
- | hub-cloud.browserstack.com |
hub.test.example |
BrowserStack Host |
TESTS_MOBILE_BROWSERSTACK_PORT |
- | 4444 |
1337 |
BrowserStack Port |
TESTS_MOBILE_BROWSERSTACK_APP_URL |
+ | - | bs://randomsequenceofsymbols |
BrowserStack URL for uploaded app |
TESTS_MOBILE_BROWSERSTACK_PLATFORM |
+ | - | Android or iOS |
BrowserStack platform (OS) |
TESTS_MOBILE_BROWSERSTACK_DEVICE |
+ | - | Samsung Galaxy S10 |
BrowserStack device |
TESTS_MOBILE_BROWSERSTACK_CAPABILITIES |
- | Check config | - | Read here |
ENV variable | Required? | Default state | Example value | Description |
---|---|---|---|---|
TESTS_WEB_COMMON_BROWSER |
- | chromium |
chromium or webkit or firefox |
Browser for autotests launch |
ENV variable | Required? | Default state | Example value | Description |
---|---|---|---|---|
TESTS_WEB_ADMIN_BASE_URL |
- | http://localhost:3000 |
https://admin.test.example |
Base URL for admin portal |
TESTS_WEB_ADMIN_USERNAME |
+ | - | [email protected] |
Username |
TESTS_WEB_ADMIN_PASSWORD |
+ | - | randomsequenceofsymbols |
Password |
ENV variable | Required? | Default state | Example value | Description |
---|---|---|---|---|
TESTS_WEB_USER_BASE_URL |
- | http://localhost:3000 |
https://test.example |
Base URL for user portal |
TESTS_WEB_USER_USERNAME |
+ | - | [email protected] |
Username |
TESTS_WEB_USER_PASSWORD |
+ | - | randomsequenceofsymbols |
Password |
Command | Description |
---|---|
codecept:run |
Run CodeceptJS test runner for all groups of tests |
codecept:run:[api][infra][mobile][web]:[admin][user] |
Run CodeceptJS test runner for specific group of tests |
codecept:types |
Run CodeceptJS types generation for all groups of tests |
codecept:types:[api][infra][mobile][web] |
Run CodeceptJS types generation for specific group of tests |
codecept:ui:[api][infra][mobile][web] |
Run CodeceptJS UI test runner for specific group of tests |
Note: builds are not used at the moment
Command | Description |
---|---|
dist:build |
TS build |
dist:check |
Check TS build (--noEmit ) |
dist:clean |
Clean build folder (dist/ ) |
Command | Description |
---|---|
format |
Check files formatting with Trunk (by default, only modified files) |
lint |
Lint files with Trunk (by default, only modified files) |
Command | Description |
---|---|
package:update |
Update dependencies with ncu |
Command | Description |
---|---|
playground:main |
Run main playground file |
Command | Description |
---|---|
playwright:codegen |
Run Playwright in code generation graphical mode |
playwright:install-browsers |
Install browsers for Playwright |
playwright:install-deps |
Install system dependencies (Debian/Ubuntu) for Playwright browsers |
Command | Description |
---|---|
test |
Run rm -rf reports/ and codecept:types and codecept:run |
test:[api][infra][mobile][web]:[admin][user] |
Run rm -rf reports/[...]/ and codecept:types:[...] and codecept:run:[...] |
Software | Description |
---|---|
Android Studio | IDE for Android which also manages Android SDK, emulated devices, etc. |
Appium Desktop | Appium Server in desktop GUIs for Mac, Windows, and Linux |
Appium Inspector | A GUI inspector for mobile apps and more, powered by a (separately installed) Appium Server |
- Check local
Appium
environment withAppium Doctor
(verifying the installation) - Launch local
Appium
server:- Docker Compose -
docker-compose up
(note: works only for Android) - Standalone (GUI) -
Appium Desktop
(download here)
- Docker Compose -
- Launch a device emulator:
- Android:
- Docker Compose -
docker-compose up
(note: works only for Android) - Using
Android Studio
- Docker Compose -
- iOS:
- TODO
- Android:
- Set ENV variable
TESTS_MOBILE_COMMON_LAUNCH_TYPE
tolocal
- Launch autotests:
npm run test:mobile
- Check local
Appium
environment withAppium Doctor
(verifying the installation) - Launch local
Appium
server:- Docker Compose -
docker-compose up
(note: works only for Android) - Standalone (GUI) -
Appium Desktop
(download here)
- Docker Compose -
- Launch a device emulator:
- Android:
- Docker Compose -
docker-compose up
(note: works only for Android) - Using
Android Studio
- Docker Compose -
- iOS:
- TODO
- Android:
- Launch
Appium Inspector
(download here) - Set "Remote Path" in
Appium Inspector
as/wd/hub
- Set
desired capabilities
inAppium Inspector
. Example:{ "platformName": "Android", "appium:platformVersion": "12", "appium:deviceName": "Samsung Galaxy S10", "appium:automationName": "UiAutomator2", "appium:app": "app-example-1.0.0.apk", "appium:appPackage": "com.package.android.example" }
- Press "Start Session" in
Appium Inspector
- Launch
Appium Inspector
(download here) - Select
Cloud Provider
and set credentials - Set
desired capabilities
inAppium Inspector
. Example:{ "platformName": "Android", "appium:platformVersion": "12", "appium:deviceName": "Samsung Galaxy S10", "appium:automationName": "UiAutomator2", "appium:app": "bs://xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx", "appium:appPackage": "com.package.android.example" }
- Press "Start Session" in
Appium Inspector
Use pause()
function in tests (read here)
- Write tests for some example project
- Add code coverage reporting
- Add visual regression testing
- Add performance testing
- Add schema validation for API tests (
swagger-typescript-api
oropenapi-client-axios
) - Add parallel tests execution (
run-workers
,run-multiple
) - Make common configuration and merge platform-specific sub-configs