aboutsummaryrefslogtreecommitdiff
path: root/crates/syntax/fuzz
diff options
context:
space:
mode:
Diffstat (limited to 'crates/syntax/fuzz')
-rw-r--r--crates/syntax/fuzz/.gitignore4
-rw-r--r--crates/syntax/fuzz/Cargo.toml27
-rw-r--r--crates/syntax/fuzz/fuzz_targets/parser.rs11
-rw-r--r--crates/syntax/fuzz/fuzz_targets/reparse.rs11
4 files changed, 53 insertions, 0 deletions
diff --git a/crates/syntax/fuzz/.gitignore b/crates/syntax/fuzz/.gitignore
new file mode 100644
index 000000000..f734abd49
--- /dev/null
+++ b/crates/syntax/fuzz/.gitignore
@@ -0,0 +1,4 @@
1Cargo.lock
2target
3corpus
4artifacts
diff --git a/crates/syntax/fuzz/Cargo.toml b/crates/syntax/fuzz/Cargo.toml
new file mode 100644
index 000000000..32c40d1b9
--- /dev/null
+++ b/crates/syntax/fuzz/Cargo.toml
@@ -0,0 +1,27 @@
1
2[package]
3name = "syntax-fuzz"
4version = "0.0.1"
5authors = ["rust-analyzer developers"]
6publish = false
7edition = "2018"
8
9[package.metadata]
10cargo-fuzz = true
11
12[dependencies]
13syntax = { path = ".." }
14text_edit = { path = "../../text_edit" }
15libfuzzer-sys = { git = "https://github.com/rust-fuzz/libfuzzer-sys.git" }
16
17# Prevent this from interfering with workspaces
18[workspace]
19members = ["."]
20
21[[bin]]
22name = "parser"
23path = "fuzz_targets/parser.rs"
24
25[[bin]]
26name = "reparse"
27path = "fuzz_targets/reparse.rs"
diff --git a/crates/syntax/fuzz/fuzz_targets/parser.rs b/crates/syntax/fuzz/fuzz_targets/parser.rs
new file mode 100644
index 000000000..386768343
--- /dev/null
+++ b/crates/syntax/fuzz/fuzz_targets/parser.rs
@@ -0,0 +1,11 @@
1//! FIXME: write short doc here
2
3#![no_main]
4use libfuzzer_sys::fuzz_target;
5use syntax::fuzz::check_parser;
6
7fuzz_target!(|data: &[u8]| {
8 if let Ok(text) = std::str::from_utf8(data) {
9 check_parser(text)
10 }
11});
diff --git a/crates/syntax/fuzz/fuzz_targets/reparse.rs b/crates/syntax/fuzz/fuzz_targets/reparse.rs
new file mode 100644
index 000000000..5ac99fdaf
--- /dev/null
+++ b/crates/syntax/fuzz/fuzz_targets/reparse.rs
@@ -0,0 +1,11 @@
1//! FIXME: write short doc here
2
3#![no_main]
4use libfuzzer_sys::fuzz_target;
5use syntax::fuzz::CheckReparse;
6
7fuzz_target!(|data: &[u8]| {
8 if let Some(check) = CheckReparse::from_data(data) {
9 check.run();
10 }
11});