build-fs-tree

Test Crates.io Version

Generate a filesystem tree from a macro or a YAML tree.

Description

When I write integration tests, I often find myself needing to create temporary files and directories. Therefore, I created this crate which provides both a library to use in a Rust code and a CLI program that generates a filesystem tree according to a YAML structure.

Usage Examples

The Library

Go to the docs.rs for the full API reference.

FileSystemTree

FileSystemTree::build is faster than MergeableFileSystemTree::build but it does not write over an existing directory and it does not create parent directories when they don't exist.

rust use build_fs_tree::{FileSystemTree, Build, dir, file}; let tree: FileSystemTree<&str, &str> = dir! { "index.html" => file!(r#" <!DOCTYPE html> <link rel="stylesheet" href="styles/style.css" /> <script src="scripts/main.js"></script> "#) "scripts" => dir! { "main.js" => file!(r#"document.write('Hello World')"#) } "styles" => dir! { "style.css" => file!(r#":root { color: red; }"#) } }; tree.build(&"public".into()).unwrap();

MergeableFileSystemTree

Unlike FileSystemTree::build, MergeableFileSystemTree::build can write over an existing directory and create parent directories that were not exist before at the cost of performance.

You can convert a FileSystemTree into a MergeableFileSystemTree via From::from/Into::into or vice versa.

rust use build_fs_tree::{MergeableFileSystemTree, Build, dir, file}; let tree = MergeableFileSystemTree::<&str, &str>::from(dir! { "public" => dir! { "index.html" => file!(r#" <!DOCTYPE html> <link rel="stylesheet" href="styles/style.css" /> <script src="scripts/main.js"></script> "#) "scripts/main.js" => file!(r#"document.write('Hello World')"#) "scripts/style.css" => file!(r#":root { color: red; }"#) } }); tree.build(&".".into()).unwrap();

The Program

The name of the command is build-fs-tree. It has 2 subcommands: create and pollute.

create

This command reads YAML from stdin and creates a new filesystem tree. It is the CLI equivalent of FileSystemTree.

Create two text files in a new directory:

sh echo '{ foo.txt: HELLO, bar.txt: WORLD }' | build-fs-tree create foo-and-bar

Create a text file and its parent directories:

sh echo '{ text-files: { foo.txt: HELLO } }' | build-fs-tree create files

Create a new filesystem tree from a YAML file:

sh build-fs-tree create root < fs-tree.yaml

pollute

This command reads YAML from stdin and either creates a new filesystem tree or add files and directories to an already existing directories. It is the CLI equivalent of MergeableFileSystemTree.

Create two text files in the current directory:

sh echo '{ foo.txt: HELLO, bar.txt: WORLD }' | build-fs-tree pollute .

Create a text file and its parent directories:

sh echo '{ files/text-files/foo.txt: HELLO }' | build-fs-tree pollute .

Pollute the current directory with filesystem tree as described in a YAML file:

sh build-fs-tree pollute . < fs-tree.yaml

Packing Status

Packaging Status

License

MIT © Hoàng Văn Khải.