Skip to content

Commit

Permalink
test: add image test for md_importer (AppFlowy-IO#335)
Browse files Browse the repository at this point in the history
* test: add image test for md_importer

* test: add nested image test
  • Loading branch information
LucasXu0 authored Nov 6, 2024
1 parent 6cb0fcb commit 0925271
Showing 1 changed file with 86 additions and 0 deletions.
86 changes: 86 additions & 0 deletions collab-document/tests/importer/md_importer_customer_test.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
use collab_document::importer::define::{BlockType, URL_FIELD};
use serde_json::json;

use crate::importer::util::{
Expand Down Expand Up @@ -373,3 +374,88 @@ fn test_customer_image_in_first_level() {
"https://example.com/image.png"
);
}

#[test]
fn test_customer_image_in_nested_level_1() {
// notes: there's a empty line between the first nested bulleted item and the image
let markdown = r#"
- 7/18 Consumption Spike issue
- 7/19 Contacted Enphase and they are going to clear spike with case #16518709 - they said the update on the 18th caused the snike
![Untitled](Untitled.png)
"#;

let result = markdown_to_document_data(markdown);

let page_block = get_page_block(&result);
let children_blocks = get_children_blocks(&result, &page_block.id);

// - First bulleted item
let delta = get_delta(&result, &children_blocks[0].id);
assert_eq!(children_blocks.len(), 1);
assert_eq!(children_blocks[0].ty, BlockType::BulletedList.to_string());
assert_eq!(delta, r#"[{"insert":"7/18 Consumption Spike issue"}]"#);

// - First nested bulleted item
let children_blocks_1 = get_children_blocks(&result, &children_blocks[0].id);
let delta = get_delta(&result, &children_blocks_1[0].id);
assert_eq!(children_blocks_1.len(), 1);
assert_eq!(children_blocks_1[0].ty, BlockType::BulletedList.to_string());
assert_eq!(
delta,
r#"[{"insert":"7/19 Contacted Enphase and they are going to clear spike with case #16518709 - they said the update on the 18th caused the snike"}]"#
);

// Image under the first nested bulleted item
let children_blocks_1_1 = get_children_blocks(&result, &children_blocks_1[0].id);
assert_eq!(children_blocks_1_1.len(), 1);
assert_eq!(children_blocks_1_1[0].ty, BlockType::Image.to_string());
assert_eq!(
children_blocks_1_1[0].data.get(URL_FIELD).unwrap(),
"Untitled.png"
);

let blocks = result.blocks;
for value in blocks.iter() {
let block = value.1;
if block.ty == BlockType::Image.to_string() {
assert_eq!(block.data.get(URL_FIELD).unwrap(), "Untitled.png");
}
}
}

#[test]
fn test_indented_image_under_paragraph() {
let markdown = r#"
This is a paragraph 1
![Untitled](Untitled.png)
This is a paragraph 2
"#;

let result = markdown_to_document_data(markdown);
let page_block = get_page_block(&result);
let children_blocks = get_children_blocks(&result, &page_block.id);

// First paragraph
assert_eq!(children_blocks[0].ty, BlockType::Paragraph.to_string());
assert_eq!(
get_delta(&result, &children_blocks[0].id),
r#"[{"insert":"This is a paragraph 1"}]"#
);

// Image
assert_eq!(children_blocks[1].ty, BlockType::Image.to_string());
assert_eq!(
children_blocks[1].data.get(URL_FIELD).unwrap(),
"Untitled.png"
);

// Second paragraph
assert_eq!(children_blocks[2].ty, BlockType::Paragraph.to_string());
assert_eq!(
get_delta(&result, &children_blocks[2].id),
r#"[{"insert":"This is a paragraph 2"}]"#
);
}

0 comments on commit 0925271

Please sign in to comment.