noqa runner
Project description
noqa-runner
AI-powered mobile test execution runner for iOS applications.
Installation
pip install noqa-runner
Quick Start
CLI
# Run on physical device with local IPA build
python -m noqa_runner run \
--noqa-api-token $NOQA_API_TOKEN \
--case-input-json '[
{
"case_instructions": "Open app and login with valid credentials"
}
]' \
--device-id "00008110-001234567890001E" \
--apple-developer-team-id TEAM123456 \
--app-bundle-id com.example.app \
--build-path /path/to/app.ipa
# Run on iOS Simulator with .app build
python -m noqa_runner run \
--noqa-api-token $NOQA_API_TOKEN \
--case-input-json '[
{
"case_instructions": "Open app and login with valid credentials"
}
]' \
--simulator-id "SIMULATOR-UDID" \
--app-bundle-id com.example.app \
--build-path /path/to/MyApp.app
# Run on device with TestFlight installation
python -m noqa_runner run \
--noqa-api-token $NOQA_API_TOKEN \
--case-input-json '[
{
"case_instructions": "Open app and verify features"
}
]' \
--device-id "00008110-001234567890001E" \
--apple-developer-team-id TEAM123456 \
--app-bundle-id com.example.app \
--app-store-id 123456789
Required Options:
--noqa-api-token TEXT noqa API authentication token [required]
--case-input-json TEXT JSON with test cases: [{case_instructions, test_id?, case_name?}] [required]
--app-bundle-id TEXT App bundle ID (auto-extracted from build if not provided) [recommended]
Target Options (choose one):
--device-id TEXT Device UDID for physical device testing
--simulator-id TEXT Simulator UDID for simulator testing
**Device-Only Options:**
--apple-developer-team-id TEXT Apple Developer Team ID for code signing [required for devices] --app-store-id TEXT App Store ID for TestFlight installation (device only)
**Installation Options (choose one):**
--build-path TEXT Path to local IPA build file --app-store-id TEXT App Store ID for TestFlight installation
**Other Options:**
--app-context TEXT Application context information [optional] --agent-api-url TEXT Agent API base URL [optional, default: https://agent.noqa.ai] --log-level TEXT Logging level [optional, default: INFO]
### Python API
```python
from noqa_runner import RunnerSession, RunnerTestInfo
# Create session
session = RunnerSession()
# Run on physical device with local IPA build
results = await session.run(
noqa_api_token="your-token",
tests=[
RunnerTestInfo(
case_instructions="Open app and verify home screen",
)
],
device_id="00008110-001234567890001E",
apple_developer_team_id="TEAM123456",
app_bundle_id="com.example.app",
app_build_path="/path/to/app.ipa",
)
# Run on iOS Simulator with .app build
results = await session.run(
noqa_api_token="your-token",
tests=[
RunnerTestInfo(
case_instructions="Open app and verify home screen",
)
],
simulator_id="SIMULATOR-UDID",
app_bundle_id="com.example.app",
app_build_path="/path/to/MyApp.app",
)
# Run with TestFlight installation
results = session.run(
noqa_api_token="your-token",
tests=[
RunnerTestInfo(
case_instructions="Open app and verify features",
)
],
device_id="00008110-001234567890001E",
apple_developer_team_id="TEAM123456",
app_bundle_id="com.example.app",
app_store_id="123456789",
)
Test Results
The CLI returns test results as JSON with detailed information about each test execution:
[
{
"case_instructions": "Complete onboarding, check that paywall has products",
"status": "passed",
"message": "Test completed",
"test_conditions": [
{
"condition": "Onboarding process was completed successfully",
"is_verified": true,
"evidence": "User progressed through multiple onboarding screens, ending with 'Get started' button",
"step_number": 4,
"confidence": 100
},
...
],
"steps": [...]
}
]
Support
For issues and questions https://noqa.ai/
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file noqa_runner-0.4.0rc1.tar.gz.
File metadata
- Download URL: noqa_runner-0.4.0rc1.tar.gz
- Upload date:
- Size: 35.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9fbae5a37dace9ee481202961eed6b86c7e34d2ce8a9e02dacf262154a978cd7
|
|
| MD5 |
8d406ce4b737d6c42c1ac6091fd31cfe
|
|
| BLAKE2b-256 |
059d48de570b636b4a5013305fbf1830d5e73c8bb630c2ed1fc214e60183b82e
|
File details
Details for the file noqa_runner-0.4.0rc1-py3-none-any.whl.
File metadata
- Download URL: noqa_runner-0.4.0rc1-py3-none-any.whl
- Upload date:
- Size: 54.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
65bc71155d26bc7d1f2f19c93aa9a195a2cc3453663ddd606db3a78ae636d837
|
|
| MD5 |
7ab738a2e2c8f2e2cd24f0e1a3c1a25e
|
|
| BLAKE2b-256 |
09803aa008f7bd2f2ced4b6b5c9ca335d8dd2fd0f04dd653c0f1b59ec63b1a56
|