Skip to main content

SoloX - Real-time collection tool for Android/iOS performance data.

Project description

English | 中文 | FAQ | 使用文档

SoloX

solox preview

🔎Preview

SoloX - Real-time collection tool for Android/iOS performance data.

Quickly locate and analyze performance issues to improve application performance and quality. No need for ROOT/jailbreak, plug and play.

10 161 9 178_50003__platform=Android lan=en (1)

📦Requirements

  • Install Python 3.10 + Download
  • Install adb and configure environment variables (SoloX's adb may not necessarily fit your computer) Download

💡 If Windows users need to test ios, install and start Itunes. Documentation (Not support iOS17)

📥Installation

default

pip install -U solox    (pip install solox==version)

mirrors

pip install -i  https://mirrors.ustc.edu.cn/pypi/web/simple -U solox

💡 If your network is unable to download through [pip install -U solox], please try using mirrors to download, but the download of SoloX may not be the latest version.

🚀Quickstart

default

python -m solox

customize

python -m solox --host=ip --port=port

🏴󠁣󠁩󠁣󠁭󠁿Python API

# solox version : >= 2.8.5
from solox.public.apm import AppPerformanceMonitor
from solox.public.common import Devices

d = Devices()
processList = d.getPid(deviceId='ca6bd5a5', pkgName='com.bilibili.app.in') # for android
print(processList) # ['{pid}:{packagename}',...]

apm = AppPerformanceMonitor(pkgName='com.bilibili.app.in',platform='Android', deviceId='ca6bd5a5', surfaceview=True, 
                            noLog=False, pid=None, record=False, collect_all=False, duration=0)
# apm = AppPerformanceMonitor(pkgName='com.bilibili.app.in', platform='iOS') only supports one device
# surfaceview: False = gfxinfo (Developer - GPU rendering mode - adb shell dumpsys gfxinfo)
# noLog : False (Save test data to log file)

# ************* Collect a performance parameter ************* #
cpu = apm.collectCpu() # %
memory = apm.collectMemory() # MB
memory_detail = apm.collectMemoryDetail() # MB
network = apm.collectNetwork(wifi=True) # KB
fps = apm.collectFps() # HZ
battery = apm.collectBattery() # level:% temperature:°C current:mA voltage:mV power:w
gpu = apm.collectGpu() # %
disk = apm.collectDisk()
thermal = apm.collectThermal()
# ************* Collect all performance parameter ************* #
 
if __name__ == '__main__':
  apm = AppPerformanceMonitor(pkgName='com.bilibili.app.in',platform='Android', deviceId='ca6bd5a5', surfaceview=True, 
                              noLog=False, pid=None, record=False, collect_all=True, duration=0)
  # apm = AppPerformanceMonitor(pkgName='com.bilibili.app.in', platform='iOS',  deviceId='xxxx', noLog=False, record=False, collect_all=True, duration=0)
  #duration: running time (second)
  #record: record android screen
  apm.collectAll(report_path=None) # report_path='/test/report.html'

# in other python file
from solox.public.apm import initPerformanceService  

initPerformanceService.stop() # stop solox

🏴󠁣󠁩󠁣󠁭󠁿Service API

Start the service in the background

# solox version >= 2.1.5

macOS/Linux: nohup python3 -m solox &
Windows: start /min python3 -m solox &

Request performance data from api

Android: http://{ip}:{port}/apm/collect?platform=Android&deviceid=ca6bd5a5&pkgname=com.bilibili.app.in&target=cpu
iOS: http://{ip}:{port}/apm/collect?platform=iOS&pkgname=com.bilibili.app.in&target=cpu

target in ['cpu','memory','memory_detail','network','fps','battery','gpu']

🔥Features

  • No ROOT/Jailbreak: No need of Root for Android devices, Jailbreak for iOS devices. Efficiently solving the test and analysis challenges in Android & iOS performance.

  • Data Integrality: We provide the data about CPU, GPU, Memory, Battery, Network,FPS, Jank, etc., which you may easy to get.

  • Beautiful Report: A beautiful and detailed report analysis, where to store, visualize, edit, manage, and download all the test cases collected with SoloX no matter where you are or when is it.

  • Useful Monitoring Settings: Support setting alarm values, collecting duration, and accessing mobile devices on other PC machines during the monitoring process.

  • PK Model: Supports simultaneous comparative testing of two mobile devices.

    • 🌱2-devices: test the same app on two different phones.
    • 🌱2-apps: test two different apps on two phones with the same configuration.
  • Collect In Python/API: Support Python and API to collect performance data, helping users easily integrate into automated testing processes.

Develop

debug

  • remove [solox] moudel in all python file
example
from solox.view.apis import api  
change to 
from view.apis import api
  • run [python ./solox/debug.py]
cd solox
python debug.py

Browser

Chrome

Terminal

💕Thanks

Project details


Release history Release notifications | RSS feed

This version

2.9.3

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

solox-2.9.3.tar.gz (17.4 MB view details)

Uploaded Source

Built Distribution

solox-2.9.3-py3-none-any.whl (17.5 MB view details)

Uploaded Python 3

File details

Details for the file solox-2.9.3.tar.gz.

File metadata

  • Download URL: solox-2.9.3.tar.gz
  • Upload date:
  • Size: 17.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.19

File hashes

Hashes for solox-2.9.3.tar.gz
Algorithm Hash digest
SHA256 f935e9773b2295b6046b69267a43b3e0d8873170aa5be14d1464d74b80d50074
MD5 f7799a4c24fd718ed764f94c9a5650de
BLAKE2b-256 d30140cc4ab1d3657ad902b89e14946b19cf154ed3645a4c4c91176ec38d7ecf

See more details on using hashes here.

File details

Details for the file solox-2.9.3-py3-none-any.whl.

File metadata

  • Download URL: solox-2.9.3-py3-none-any.whl
  • Upload date:
  • Size: 17.5 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.19

File hashes

Hashes for solox-2.9.3-py3-none-any.whl
Algorithm Hash digest
SHA256 31308734d729ead0006af029a0b34f688f15881cae01e90145d204cd21daedb4
MD5 4898738668b27aeac2448a2cbdda1876
BLAKE2b-256 c94f0f16cf89dafa4d2669b1c44da028cc6852a3d038df68be526ff995517d9a

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page