aboutsummaryrefslogtreecommitdiffstats
path: root/tests/xxx_document.rs
diff options
context:
space:
mode:
authorLibravatar Titus Wormer <tituswormer@gmail.com>2022-10-03 17:34:52 +0200
committerLibravatar Titus Wormer <tituswormer@gmail.com>2022-10-03 17:34:52 +0200
commit3a1fd1918f65c0a751a872d66e2d5bb01c64830c (patch)
treea10932d41f02b310b06dab8b344f6c4a35ff3ee6 /tests/xxx_document.rs
parent117cfc10c6d4a0a9346a29353860d1185d1ea224 (diff)
downloadmarkdown-rs-3a1fd1918f65c0a751a872d66e2d5bb01c64830c.tar.gz
markdown-rs-3a1fd1918f65c0a751a872d66e2d5bb01c64830c.tar.bz2
markdown-rs-3a1fd1918f65c0a751a872d66e2d5bb01c64830c.zip
Add support for creating a component, using layout
Diffstat (limited to '')
-rw-r--r--tests/xxx_document.rs229
1 files changed, 229 insertions, 0 deletions
diff --git a/tests/xxx_document.rs b/tests/xxx_document.rs
new file mode 100644
index 0000000..2d89f16
--- /dev/null
+++ b/tests/xxx_document.rs
@@ -0,0 +1,229 @@
+extern crate micromark;
+extern crate swc_common;
+extern crate swc_ecma_ast;
+extern crate swc_ecma_codegen;
+mod test_utils;
+use micromark::{micromark_to_mdast, Constructs, Options};
+use pretty_assertions::assert_eq;
+use swc_common::{sync::Lrc, FilePathMapping, SourceMap};
+use swc_ecma_codegen::{text_writer::JsWriter, Emitter};
+use test_utils::{
+ swc::{parse_esm, parse_expression},
+ to_document::{to_document, Options as DocumentOptions},
+ to_hast::to_hast,
+ to_swc::{to_swc, Program},
+};
+
+// To do: share with `xxx_swc`.
+fn serialize(program: &Program) -> String {
+ let mut buf = vec![];
+ let cm = Lrc::new(SourceMap::new(FilePathMapping::empty()));
+ // let comm = &program.comments as &dyn swc_common::comments::Comments;
+ {
+ let mut emitter = Emitter {
+ cfg: swc_ecma_codegen::Config {
+ ..Default::default()
+ },
+ cm: cm.clone(),
+ // To do: figure out how to pass them.
+ comments: None,
+ wr: JsWriter::new(cm, "\n", &mut buf, None),
+ };
+
+ emitter.emit_module(&program.module).unwrap();
+ }
+
+ String::from_utf8_lossy(&buf).to_string()
+}
+
+fn from_markdown(value: &str) -> Result<String, String> {
+ let mdast = micromark_to_mdast(
+ value,
+ &Options {
+ constructs: Constructs::mdx(),
+ mdx_esm_parse: Some(Box::new(parse_esm)),
+ mdx_expression_parse: Some(Box::new(parse_expression)),
+ ..Options::default()
+ },
+ )?;
+ let hast = to_hast(&mdast);
+ let program = to_document(to_swc(&hast)?, &DocumentOptions::default())?;
+ let value = serialize(&program);
+ Ok(value)
+}
+
+#[test]
+fn document() -> Result<(), String> {
+ assert_eq!(
+ from_markdown("# hi\n\nAlpha *bravo* **charlie**.")?,
+ "function _createMdxContent(props) {
+ return <><h1 >{\"hi\"}</h1>{\"\\n\"}<p >{\"Alpha \"}<em >{\"bravo\"}</em>{\" \"}<strong >{\"charlie\"}</strong>{\".\"}</p></>;
+}
+function MDXContent(props = {}) {
+ return MDXLayout ? <MDXLayout {...props}><_createMdxContent {...props}/></MDXLayout> : _createMdxContent(props);
+}
+export default MDXContent;
+",
+ "should support a small program",
+ );
+
+ assert_eq!(
+ from_markdown("import a from 'b'\n\n# {a}")?,
+ "import a from 'b';
+function _createMdxContent(props) {
+ return <h1 >{a}</h1>;
+}
+function MDXContent(props = {}) {
+ return MDXLayout ? <MDXLayout {...props}><_createMdxContent {...props}/></MDXLayout> : _createMdxContent(props);
+}
+export default MDXContent;
+",
+ "should support an import",
+ );
+
+ assert_eq!(
+ from_markdown("export * from 'a'\n\n# b")?,
+ "export * from 'a';
+function _createMdxContent(props) {
+ return <h1 >{\"b\"}</h1>;
+}
+function MDXContent(props = {}) {
+ return MDXLayout ? <MDXLayout {...props}><_createMdxContent {...props}/></MDXLayout> : _createMdxContent(props);
+}
+export default MDXContent;
+",
+ "should support an export all",
+ );
+
+ assert_eq!(
+ from_markdown("export function a() {}")?,
+ "export function a() {}
+function _createMdxContent(props) {
+ return <></>;
+}
+function MDXContent(props = {}) {
+ return MDXLayout ? <MDXLayout {...props}><_createMdxContent {...props}/></MDXLayout> : _createMdxContent(props);
+}
+export default MDXContent;
+",
+ "should support an export declaration",
+ );
+
+ assert_eq!(
+ from_markdown("export default a")?,
+ "const MDXLayout = a;
+function _createMdxContent(props) {
+ return <></>;
+}
+function MDXContent(props = {}) {
+ return <MDXLayout {...props}><_createMdxContent {...props}/></MDXLayout>;
+}
+export default MDXContent;
+",
+ "should support an export default expression",
+ );
+
+ assert_eq!(
+ from_markdown("export default function () {}")?,
+ "const MDXLayout = function() {};
+function _createMdxContent(props) {
+ return <></>;
+}
+function MDXContent(props = {}) {
+ return <MDXLayout {...props}><_createMdxContent {...props}/></MDXLayout>;
+}
+export default MDXContent;
+",
+ "should support an export default declaration",
+ );
+
+ assert_eq!(
+ from_markdown("export {a, b as default}")?,
+ "export { a };
+const MDXLayout = b;
+function _createMdxContent(props) {
+ return <></>;
+}
+function MDXContent(props = {}) {
+ return <MDXLayout {...props}><_createMdxContent {...props}/></MDXLayout>;
+}
+export default MDXContent;
+",
+ "should support a named export w/o source, w/ a default specifier",
+ );
+
+ assert_eq!(
+ from_markdown("export {a}")?,
+ "export { a };
+function _createMdxContent(props) {
+ return <></>;
+}
+function MDXContent(props = {}) {
+ return MDXLayout ? <MDXLayout {...props}><_createMdxContent {...props}/></MDXLayout> : _createMdxContent(props);
+}
+export default MDXContent;
+",
+ "should support a named export w/o source, w/o a default specifier",
+ );
+
+ assert_eq!(
+ from_markdown("export {}")?,
+ "export { };
+function _createMdxContent(props) {
+ return <></>;
+}
+function MDXContent(props = {}) {
+ return MDXLayout ? <MDXLayout {...props}><_createMdxContent {...props}/></MDXLayout> : _createMdxContent(props);
+}
+export default MDXContent;
+",
+ "should support a named export w/o source, w/o a specifiers",
+ );
+
+ // ...........
+
+ assert_eq!(
+ from_markdown("export {a, b as default} from 'c'")?,
+ "export { a } from 'c';
+import { b as MDXLayout } from 'c';
+function _createMdxContent(props) {
+ return <></>;
+}
+function MDXContent(props = {}) {
+ return <MDXLayout {...props}><_createMdxContent {...props}/></MDXLayout>;
+}
+export default MDXContent;
+",
+ "should support a named export w/ source, w/ a default specifier",
+ );
+
+ assert_eq!(
+ from_markdown("export {a} from 'b'")?,
+ "export { a } from 'b';
+function _createMdxContent(props) {
+ return <></>;
+}
+function MDXContent(props = {}) {
+ return MDXLayout ? <MDXLayout {...props}><_createMdxContent {...props}/></MDXLayout> : _createMdxContent(props);
+}
+export default MDXContent;
+",
+ "should support a named export w/ source, w/o a default specifier",
+ );
+
+ assert_eq!(
+ from_markdown("export {} from 'a'")?,
+ "export { } from 'a';
+function _createMdxContent(props) {
+ return <></>;
+}
+function MDXContent(props = {}) {
+ return MDXLayout ? <MDXLayout {...props}><_createMdxContent {...props}/></MDXLayout> : _createMdxContent(props);
+}
+export default MDXContent;
+",
+ "should support a named export w/ source, w/o a specifiers",
+ );
+
+ Ok(())
+}