1pub mod editor_lsp_test_context;
2pub mod editor_test_context;
3
4use crate::{
5 display_map::{DisplayMap, DisplaySnapshot, ToDisplayPoint},
6 DisplayPoint, Editor, EditorMode, MultiBuffer,
7};
8
9use gpui::{ModelHandle, ViewContext};
10
11use util::test::{marked_text_offsets, marked_text_ranges};
12
13#[cfg(test)]
14#[ctor::ctor]
15fn init_logger() {
16 if std::env::var("RUST_LOG").is_ok() {
17 env_logger::init();
18 }
19}
20
21// Returns a snapshot from text containing '|' character markers with the markers removed, and DisplayPoints for each one.
22pub fn marked_display_snapshot(
23 text: &str,
24 cx: &mut gpui::AppContext,
25) -> (DisplaySnapshot, Vec<DisplayPoint>) {
26 let (unmarked_text, markers) = marked_text_offsets(text);
27
28 let family_id = cx
29 .font_cache()
30 .load_family(&["Helvetica"], &Default::default())
31 .unwrap();
32 let font_id = cx
33 .font_cache()
34 .select_font(family_id, &Default::default())
35 .unwrap();
36 let font_size = 14.0;
37
38 let buffer = MultiBuffer::build_simple(&unmarked_text, cx);
39 let display_map =
40 cx.add_model(|cx| DisplayMap::new(buffer, font_id, font_size, None, 1, 1, cx));
41 let snapshot = display_map.update(cx, |map, cx| map.snapshot(cx));
42 let markers = markers
43 .into_iter()
44 .map(|offset| offset.to_display_point(&snapshot))
45 .collect();
46
47 (snapshot, markers)
48}
49
50pub fn select_ranges(editor: &mut Editor, marked_text: &str, cx: &mut ViewContext<Editor>) {
51 let (unmarked_text, text_ranges) = marked_text_ranges(marked_text, true);
52 assert_eq!(editor.text(cx), unmarked_text);
53 editor.change_selections(None, cx, |s| s.select_ranges(text_ranges));
54}
55
56pub fn assert_text_with_selections(
57 editor: &mut Editor,
58 marked_text: &str,
59 cx: &mut ViewContext<Editor>,
60) {
61 let (unmarked_text, text_ranges) = marked_text_ranges(marked_text, true);
62 assert_eq!(editor.text(cx), unmarked_text);
63 assert_eq!(editor.selections.ranges(cx), text_ranges);
64}
65
66pub(crate) fn build_editor(
67 buffer: ModelHandle<MultiBuffer>,
68 cx: &mut ViewContext<Editor>,
69) -> Editor {
70 Editor::new(EditorMode::Full, buffer, None, None, cx)
71}