Security Shepherd ClusterFuzz instructions
[TOC]
This page has instructions for Security Shepherds in how best to use ClusterFuzz to reproduce and label bugs.
Basics
https://clusterfuzz.com/upload-testcase allows you to upload files to reproduce crashes on various platforms and will identify revision ranges when the regression was introduced.
Prefer using the "Quick upload" flow for simple cases. If you choose to use "Upload" instead, you will have to pick which job to run.
Note that ClusterFuzz only supports running untrusted inputs on Linux. The UI will warn you of that.
If a test case requires multiple files, they can be uploaded together in a zip
or tar archive: the main file needs to contain the words run, fuzz- index.
or crash..
Please do specify the crbug number when uploading the test case. This allows ClusterFuzz to keep the crbug updated with progress.
Useful jobs
You should chose the right job type depending on the format of file you want to test:
- repro.html linux_asan_chrome_mp or windows_asan_chrome
- repro.js linux_asan_d8
- repro.pdf libfuzzer_chrome_asan / pdfium_xfa_fuzzer
- repro.js for V8 sandbox bypass / violation: linux_asan_d8_sandbox_testing / linux_asan_chrome_v8_sandbox_testing
MojoJS
MojoJS is a means for a renderer process to use Mojo IPCs directly from JavaScript. Although it's not enabled in normal production Chrome builds, it's a great way to simulate how a compromised renderer can attack other processes over IPC.
Because Mojo IPCs change with each version of Chrome, the test case needs to
use exactly the right MojoJS bindings. MojoJS bugs typically specify to use
python ./copy_mojo_bindings.py to put such bindings in place, but that does not
work for ClusterFuzz where it will need to bisect across many versions of Chrome
with many versions of Mojo.
Therefore, do this instead:
- In the PoC, replace all paths where it's loading MojoJS scripts to be prefixed
with
file:///geninstead. For example:
<script src="file:///gen/mojo/public/js/mojo_bindings_lite.js">
This works because most of the ClusterFuzz Chrome binaries are now built with enable_ipc_fuzzer=true.
- If you believe the bug will reproduce on Linux, use the linux_asan_chrome_mojo job type.
- If you believe the bug will only reproduce on Android, ClusterFuzz can't help right now.
- Otherwise, use any job type but specify extra command-line flags
--enable-blink-features=MojoJS. In this case, ClusterFuzz might declare that a browser process crash is Critical severity, whereas because of the precondition of a compromised renderer you may wish to adjust it down to High.
Example bug where these instructions have worked.
Gestures
Some testcases require UI gestures to reproduce them. ClusterFuzz has a "gestures" field where you may be able to specify such UI interactions. The language is platform-specific. On Linux, it's commands for xdotool in a Python-like list. For instance,
[ "type,'qx1sqOqB0ZbEFYn'","key,F3","key,F12" ]
As mouse coordinates are subject to change, it probably only makes sense to try gestures if the UI actions can be achieved purely using keystrokes. The relevant ClusterFuzz code is in gesture_handler.py to figure out the languages for other platforms.
HTTP(S) headers
If you need to reproduce a test case that involves specific HTTP headers, do this:
- Make a copy of page_load_in_process_fuzzer_seed_corpus/network.textproto
- Edit as necessary to give the headers you need
- Go to the ClusterFuzz upload page
- Select
libfuzzer_chrome_asanfor the job - Select
page_load_in_process_fuzzerfor the fuzzer - Upload
network.textprotoas the test case.