Experimental extraction of Socorro signature generation
Project description
This is an experimental extraction of the Socorro signature generation code.
- Code:
- Documentation:
Check the README.rst file
- Changelog:
Check the HISTORY.rst file
- Issue tracker:
- License:
MPLv2
- Status:
Alpha
Installing
socorro-siggen is available on PyPI. You can install it with:
$ pip install siggen
Basic use
You can use socorro-siggen as a command line:
$ signify <JSONFILE> SIGNATURE HERE
Alternatively:
$ cat <JSONFILE> | signify
You can use socorro-siggen as a library:
from siggen import SignatureGenerator
generator = SignatureGenerator()
crash_data = {
...
}
ret = generator.generate(crash_data)
print(ret['signature'])
Crash data schema
This is the schema for the crash data structure:
Crash data:
- crashing_thread: int or None
The index of the crashing thread in threads. This defaults to None
which indicates there was no crashing thread identified in the crash
report.
- threads: list of CStackTrace or None
This is a list of stack traces for c/c++/rust code.
Each stack trace is a dict with keys:
- frames: list of frames
The list of frames in this stack. See below for the frame structure.
- thread_name: string or None
The name of the thread. This isn't used, yet, but might be in the
future for debugging purposes.
- frame_count: int or None
This is the total number of frames. This isn't used.
Each frame is a dict with the following keys:
- function: string
The name of the function. If this is ``None`` or not in the frame,
then signature generation will calculate something using other data in
the frame.
- module: string
The name of the module.
- file: string
The name of the file.
- line: int
The line in the file.
- module_offset: string
The offset in hex in the module for this frame.
- offset: string
The offset in hex for this frame.
Signature parts are computed using frame data in this order:
1. if there's a function (and optionally line)--use that
2. if there's a file and a line--use that
3. if there's an offset and no module/module_offset--use that
4. use module/module_offset
- java_stack_trace: string or None
If the crash is a Java crash, then this will be the Java traceback as a
single string. Signature generation will split this string into lines and
then extract frame information from it to generate the signature.
FIXME(willkg): Write up better description of this.
- oom_allocation_size: int or None
The allocation size that triggered an out-of-memory error. This will
get added to the signature if one of the indicator functions appears
in the stack of the crashing thread.
- abort_message: string or None
The abort message for the crash, if there is one. This is added to the
beginning of the signature.
- hang_type: int or None
A value of 1 here indicates this is a chrome hang and we look at thread 0
for generation.
A value of -1 indicates another kind of hang.
All other values indicate this crash is not a hang at all.
- async_shutdown_timeout: text or None
This is a text field encoded in JSON with "phase" and "conditions" keys.
FIXME(willkg): Document this structure better.
- jit_category: string or None
If there's a JIT classification in the crash, then that will override the
signature.
- ipc_channel_error: string or None
If there is an IPC channel error, it replaces the signature.
- ipc_message_name: string or None
This gets added to the signature if there was an IPC message name in the
crash.
- additional_minidumps: string or None
A crash report can contain multiple minidumps. This is a comma-delimited
list of minidumps other than the main one that the crash had.
Example: "browser,flash1,flash2,content"
- mdsw_status_string: string or None (Socorro specific)
This is the minidump-stackwalk status string. This gets generated when the
Socorro processor runs the minidump through minidump-stackwalk. If you're
not using minidump-stackwalk, you can ignore this.
- moz_crash_reason: string or None
This is the MOZ_CRASH_REASON value. This doesn't affect anything unless
the value is "MOZ_RELEASE_ASSERT(parentBuildID == childBuildID)".
- os: string or None
The name of the operating system. This doesn't affect anything unless the
name is "Windows NT" in which case it will lowercase module names when
iterating through frames to build the signature.
Missing keys in the structure are treated as None, so you can pass in a minimal structure with just the parts you define.
Examples
Example almost minimal, somewhat nonsense crash_data.json:
{
"os": "Linux",
"threads": [
{
"frames": [
{
"frame": 0,
"function": "SomeFunc",
"line": 20,
"file": "somefile.cpp",
"module": "foo.so.5.15.0",
"module_offset": "0x37a92",
"offset": "0x7fc641052a92"
},
{
"frame": 1,
"function": "SomeOtherFunc",
"line": 444,
"file": "someotherfile.cpp",
"module": "bar.so",
"module_offset": "0x39a55",
"offset": "0x7fc641044a55"
}
]
}
]
}
That produces this output:
$ cat crash_data.json | signify
{
"notes": [],
"proto_signature": "SomeFunc | SomeOtherFunc",
"signature": "SomeFunc"
}
Release process
Create branch
Update version and release date in siggen/__init__.py
Update HISTORY.rst
Push the branch, create a PR, review it, merge it
Create a signed tag, push to github:
git tag -s v0.1.0 git push --tags [REMOTE] master
Build:
python setup.py sdist bdist_wheel
Upload to PyPI:
twine upload dist/*
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 siggen-0.1.1.tar.gz.
File metadata
- Download URL: siggen-0.1.1.tar.gz
- Upload date:
- Size: 36.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fab7c46c100b764854d2e9870c19b20463123744f151250cfede6af3d9b4d815
|
|
| MD5 |
962ca887c0590d92473fafdaf771b0ef
|
|
| BLAKE2b-256 |
dbff36e8a24918188ac711226628572c73009839f0f687f645d15b880ce2342d
|
File details
Details for the file siggen-0.1.1-py2-none-any.whl.
File metadata
- Download URL: siggen-0.1.1-py2-none-any.whl
- Upload date:
- Size: 36.2 kB
- Tags: Python 2
- Uploaded using Trusted Publishing? No
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
390b3cca4e9d6dd68f71d670e9003c29c1ccb7e6346703c8ff00f871276d84e0
|
|
| MD5 |
7685a914ab73c99cfd432f5cadd5ef80
|
|
| BLAKE2b-256 |
cb92ceacf71c7e91782cddde8d1f7c878b454d784e39a7a477eb6b6e93abadfb
|