Python client library for the TestingBot REST API.
Project description
testingbotclient
Python client for the TestingBot REST API
Install
pip install testingbotclient
TestingBot
TestingBot allows you to run Selenium tests in the cloud. With access to over +2600 different browser/device combinations, you can run your browser and mobile tests in parallel on the TestingBot Grid.
Getting Started
import testingbotclient
tb = testingbotclient.TestingBotClient('key', 'secret')
Credentials can also be supplied via the TESTINGBOT_KEY / TESTINGBOT_SECRET
(or TB_KEY / TB_SECRET) environment variables, or a ~/.testingbot file
containing key:secret — in which case you can construct the client with no
arguments:
tb = testingbotclient.TestingBotClient()
An optional request timeout (seconds, default 60) can be set; raise it for
large Storage uploads. Transient failures (429 / 5xx) are retried automatically
on idempotent requests — tune or disable with max_retries (default 3):
tb = testingbotclient.TestingBotClient('key', 'secret', timeout=120, max_retries=5)
The client pools connections via a requests.Session; use it as a context
manager to close that session deterministically:
with testingbotclient.TestingBotClient('key', 'secret') as tb:
tb.tests.get_tests()
Every API method raises testingbotclient.TestingBotException on a non-2xx
response. The exception carries the failing .response (with credentials
stripped from it):
try:
tb.tests.get_test('does-not-exist')
except testingbotclient.TestingBotException as e:
print(e.response.status_code)
Use paginate to iterate over every item of a paginated list endpoint without
managing offsets yourself:
for build in testingbotclient.paginate(tb.build.get_builds):
print(build)
API reference: https://testingbot.com/support/api
Tests — tb.tests
# List tests (filters are all optional)
tb.tests.get_tests(offset=0, limit=10, since=None, browser_id=None,
group=None, build=None, skip_fields=None)
tb.tests.get_test_ids()
tb.tests.get_test(sessionId, skip_fields=None)
# Update a test's metadata after running it
tb.tests.update_test(sessionId, name=None, passed=None,
status_message=None, build=None)
tb.tests.stop_test(sessionId)
tb.tests.delete_test(sessionId)
# Create a record for a manual / external test result
tb.tests.create_test(name, success=None, status_message=None,
extra=None, build=None)
Builds — tb.build
tb.build.get_builds(offset=0, limit=10)
tb.build.get_tests_for_build(buildId)
tb.build.delete_build(buildId)
Storage — tb.storage
Upload app binaries (.apk / .ipa) and reference them later via the returned
tb://<appkey> URL.
tb.storage.upload_local_file(localFilePath)
tb.storage.upload_remote_file(remoteUrl)
# Replace the binary behind an existing app_url (the app_url stays the same)
tb.storage.replace_local_file(app_url, localFilePath)
tb.storage.replace_remote_file(app_url, remoteUrl)
tb.storage.get_stored_file(app_url)
tb.storage.get_stored_files(offset=0, limit=10)
tb.storage.remove_file(app_url)
Browsers & devices — tb.information
tb.information.get_browsers(type=None) # type: 'webdriver' | 'rc'
tb.information.get_devices(platform=None) # platform: 'android' | 'ios' | 'real_android' | 'real_ios'
tb.information.get_available_devices()
tb.information.get_device(deviceId)
Screenshots — tb.screenshots
Capture a URL across multiple browsers.
batch = tb.screenshots.take_screenshots(
url, resolution, browsers, # browsers: list of browser_id values
wait_time=0, full_page=None, callback_url=None)
tb.screenshots.get_screenshots(offset=0, limit=10)
tb.screenshots.get_screenshot(screenshotId, exclude_ids=None)
Codeless tests — tb.lab
Create, schedule, and run no-code (recorded) tests. trigger / trigger_all
return a job_id you poll with tb.jobs.
tb.lab.get_tests(offset=0, limit=10)
tb.lab.get_test(testId)
# Create from a target URL, or import a Selenium IDE .side export
tb.lab.create_test(name=None, url=None, cron=None, screenshot=None, video=None,
idletimeout=None, screenresolution=None, ai_prompt=None, file=None)
tb.lab.update_test(testId, name=None, url=None, cron=None, enabled=None)
tb.lab.delete_test(testId)
tb.lab.trigger(testId, url=None)
tb.lab.trigger_all(url=None)
tb.lab.get_steps(testId, offset=0, limit=10)
tb.lab.set_steps(testId, steps) # list of {order, cmd, locator, value}
tb.lab.schedule(testId, type, day=None, hour=None, cron_format=None) # type: once|daily|weekly|custom
tb.lab.stop(testId, browser_id=None)
tb.lab.add_alert(testId, kind, level, content) # kind: EMAIL|API|SMS, level: IMMEDIATELY|DAILY
tb.lab.update_alert(testId, kind=None, level=None, content=None)
tb.lab.add_report(testId, email, cron=None)
tb.lab.update_report(testId, email=None, cron=None)
tb.lab.get_browsers(testId)
tb.lab.set_browsers(testId, browser_ids) # list or comma-separated string
Codeless suites — tb.labsuites
Group Codeless tests so they can be triggered and reported on together.
tb.labsuites.get_suites(offset=0, limit=10)
tb.labsuites.get_suite(suiteId)
tb.labsuites.create_suite(name, cron=None, screenshot=None, video=None,
idletimeout=None, screenresolution=None)
tb.labsuites.delete_suite(suiteId)
tb.labsuites.trigger(suiteId) # returns a job_id
tb.labsuites.get_tests(suiteId, offset=0, limit=10)
tb.labsuites.add_tests(suiteId, test_ids) # list or comma-separated string
tb.labsuites.remove_test(suiteId, testId)
tb.labsuites.get_browsers(suiteId)
tb.labsuites.set_browsers(suiteId, browser_ids)
Jobs — tb.jobs
Poll asynchronous jobs returned by Codeless triggers.
job = tb.lab.trigger(123)
tb.jobs.get_job(job['job_id'])
tb.jobs.wait_for_job(job['job_id'], timeout=600, interval=5) # blocks until FINISHED
Tunnels — tb.tunnel
tb.tunnel.get_tunnels()
tb.tunnel.delete_tunnel(tunnelId)
Team management — tb.team
tb.team.get_concurrency()
tb.team.get_users(offset=0, limit=10)
tb.team.get_user(userId)
tb.team.create_user(email, password, first_name=None, last_name=None,
concurrency=None, concurrency_physical=None)
tb.team.update_user(userId, first_name=None, last_name=None, email=None,
password=None, credits=None, device_credits=None,
concurrency=None, concurrency_physical=None)
tb.team.get_client_key(userId)
tb.team.reset_keys(userId)
Configuration — tb.configuration
tb.configuration.get_ip_ranges() # TestingBot IPs for firewall whitelisting
User — tb.user
tb.user.get_user_information()
tb.user.update_user_information(userInformation)
Sharing
Calculate the authentication hash needed to share a test. https://testingbot.com/support/other/sharing
tb.get_share_link(sessionId)
Test
Unit tests are mocked and need no credentials:
python -m unittest tests.test_unit
The live integration tests hit the real API and require TB_KEY and TB_SECRET:
python -m unittest tests.test_client
More documentation
Check out the TestingBot REST API for more information.
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 testingbotclient-0.2.0.tar.gz.
File metadata
- Download URL: testingbotclient-0.2.0.tar.gz
- Upload date:
- Size: 17.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bd96cf7303e737f92fc6087a9b33ca219168f34da89c4bcd341dba633c15c59e
|
|
| MD5 |
c11047afa3ebc230dc30034427eb7ed1
|
|
| BLAKE2b-256 |
e639a35518ee468aaabf2781398c0aef478816bdd4c18ab40576a4bacf045533
|
Provenance
The following attestation bundles were made for testingbotclient-0.2.0.tar.gz:
Publisher:
build.yml on testingbot/testingbotclient
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
testingbotclient-0.2.0.tar.gz -
Subject digest:
bd96cf7303e737f92fc6087a9b33ca219168f34da89c4bcd341dba633c15c59e - Sigstore transparency entry: 1704816462
- Sigstore integration time:
-
Permalink:
testingbot/testingbotclient@64708c4668899b5d0c23e638328f5b16d08258eb -
Branch / Tag:
refs/tags/0.2.0 - Owner: https://github.com/testingbot
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
build.yml@64708c4668899b5d0c23e638328f5b16d08258eb -
Trigger Event:
release
-
Statement type:
File details
Details for the file testingbotclient-0.2.0-py3-none-any.whl.
File metadata
- Download URL: testingbotclient-0.2.0-py3-none-any.whl
- Upload date:
- Size: 11.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
94cf070120f688ee38924dcd99e33a036695da6ba1de3a95570171bba29c4317
|
|
| MD5 |
355a5867f4ef14f506d293f85ac85c16
|
|
| BLAKE2b-256 |
6e619eb8cc0180b76a1552a02db9e2a97d31c0238b43cf03541d6882dc6e975f
|
Provenance
The following attestation bundles were made for testingbotclient-0.2.0-py3-none-any.whl:
Publisher:
build.yml on testingbot/testingbotclient
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
testingbotclient-0.2.0-py3-none-any.whl -
Subject digest:
94cf070120f688ee38924dcd99e33a036695da6ba1de3a95570171bba29c4317 - Sigstore transparency entry: 1704816476
- Sigstore integration time:
-
Permalink:
testingbot/testingbotclient@64708c4668899b5d0c23e638328f5b16d08258eb -
Branch / Tag:
refs/tags/0.2.0 - Owner: https://github.com/testingbot
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
build.yml@64708c4668899b5d0c23e638328f5b16d08258eb -
Trigger Event:
release
-
Statement type: