2019-10-25 14:16:46 +03:00
|
|
|
//! Each assist definition has a special comment, which specifies docs and
|
|
|
|
//! example.
|
|
|
|
//!
|
|
|
|
//! We collect all the example and write the as tests in this module.
|
|
|
|
|
|
|
|
mod generated;
|
|
|
|
|
2020-02-06 18:10:25 +01:00
|
|
|
use ra_db::FileRange;
|
2019-10-26 19:58:18 +03:00
|
|
|
use test_utils::{assert_eq_text, extract_range_or_offset};
|
2019-10-25 14:16:46 +03:00
|
|
|
|
2020-02-06 18:46:11 +01:00
|
|
|
use crate::resolved_assists;
|
|
|
|
|
2019-10-25 14:16:46 +03:00
|
|
|
fn check(assist_id: &str, before: &str, after: &str) {
|
2019-10-26 19:58:18 +03:00
|
|
|
let (selection, before) = extract_range_or_offset(before);
|
2020-02-06 18:10:25 +01:00
|
|
|
let (db, file_id) = crate::helpers::with_single_file(&before);
|
2019-10-26 19:58:18 +03:00
|
|
|
let frange = FileRange { file_id, range: selection.into() };
|
2019-10-25 14:16:46 +03:00
|
|
|
|
2020-02-06 18:46:11 +01:00
|
|
|
let assist = resolved_assists(&db, frange)
|
2019-10-25 23:38:15 +03:00
|
|
|
.into_iter()
|
2020-01-12 00:40:36 +02:00
|
|
|
.find(|assist| assist.label.id.0 == assist_id)
|
2019-10-27 16:56:53 +03:00
|
|
|
.unwrap_or_else(|| {
|
|
|
|
panic!(
|
|
|
|
"\n\nAssist is not applicable: {}\nAvailable assists: {}",
|
|
|
|
assist_id,
|
2020-02-06 18:46:11 +01:00
|
|
|
resolved_assists(&db, frange)
|
2019-10-27 16:56:53 +03:00
|
|
|
.into_iter()
|
2020-01-12 00:40:36 +02:00
|
|
|
.map(|assist| assist.label.id.0)
|
2019-10-27 16:56:53 +03:00
|
|
|
.collect::<Vec<_>>()
|
|
|
|
.join(", ")
|
|
|
|
)
|
|
|
|
});
|
2019-10-25 14:16:46 +03:00
|
|
|
|
2020-02-09 15:32:53 +01:00
|
|
|
let actual = assist.action.edit.apply(&before);
|
2019-10-25 14:16:46 +03:00
|
|
|
assert_eq_text!(after, &actual);
|
|
|
|
}
|