Skip to content

mainmatter/rust-workshop-runner

Repository files navigation

wr

A Rust workshop runner
<div align="center">
    <!-- Crates version -->
    <a href="https://crates.io/crates/cargo-px">
        <img src="https://img.shields.io/crates/v/cargo-px.svg?style=flat-square"
        alt="Crates.io version" />
    </a>
    <!-- Downloads -->
    <a href="https://crates.io/crates/cargo-px">
        <img src="https://img.shields.io/crates/d/cargo-px.svg?style=flat-square"
        alt="Download" />
    </a>
</div>

demo

wr is a CLI to drive test-driven workshops written in Rust. It is designed to be used in conjunction with a workshop repository, which contains a series of exercises to be solved by the workshop participants.

This workshop runner has been developed by Mainmatter to support our hands-on Rust workshops. Check out our landing page if you're looking for Rust consulting or training!

## How to install

Check out the instructions on the release page.

How it works

What I cannot create, I do not understand.

Richard Feynman

A test-driven workshop is structured as a series of exercises. Each exercise is a Rust project with a set of tests that verify the correctness of the solution.

wr will run the tests for the current exercise and, if they pass, allow you to move on to the next exercise while keeping track of what you have solved so far.

You can see it in action in the rust-telemetry-workshop.

Installation

cargo install workshop-runner

Check that it has been installed correctly:

wr --help

Usage

Run

wr

from the top-level folder of a workshop repository to verify the solution for the current exercise and move forward in the workshop.

You can also navigate to a specific exercise and then run wr check from inside its directory to verify its solution, regardless of what the current exercise is.

Continuous checking

You can combine wr with cargo-watch to re-check your solution every time you make a change to the code:

cargo watch -- wr

Folder structure

wr expects the following structure for the workshop repository:

.
├── exercises
│  ├── 00_<collection name>
│  │  ├── 00_<exercise name>
│  │  │  ..
│  │  ├── 0n_<exercise name>
│  │  ..
│  ├── 0n_<collection name>
│  │  ├── 00_<exercise name>
│  │  │  ..
│  │  ├── 0n_<exercise name>

Each xx_<exercise name> folder must be a Rust project with its own Cargo.toml file.

You can choose a different top-level folder name by either passing the --exercises-dir flag when invoking wr or by creating a top-level wr.toml file with the following content:

exercises-dir = "my-top-level-folder"

You can refer to rust-telemetry-workshop as an example.

About

A CLI tool to drive test-driven Rust workshops

Resources

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT

Stars

Watchers

Forks

Packages

No packages published

Languages