11 releases

0.2.5 Jan 3, 2025
0.2.4 Dec 30, 2024
0.2.3 Aug 8, 2024
0.2.2 May 16, 2024
0.1.0 Dec 26, 2020

#149 in Concurrency

Download history 3/week @ 2024-09-18 13/week @ 2024-09-25 5/week @ 2024-10-02 1/week @ 2024-12-04 2/week @ 2024-12-11 96/week @ 2024-12-25 156/week @ 2025-01-01

255 downloads per month

MIT license

50KB
859 lines

CircleCI Crates.io Crates.io GitHub last commit Codecov License GitHub issues

⏱️ An asynchronous task scheduling library written in Rust

About

tasklet is a task scheduling library written in Rust. It is built over tokio runtime and utilizes green threads in order to run tasks asynchronously.

Dependencies

library version
cron 0.14.0
chrono 0.4.39
time 0.3.37
log 0.4.22
tokio 1.42.0
futures 0.3.31

How to use this library

In your Cargo.toml add:

[dependencies]
tasklet = "0.2.5"

Example

Find more examples in the examples folder.

use log::info;
use simple_logger::SimpleLogger;
use tasklet::task::TaskStepStatusErr::Error;
use tasklet::task::TaskStepStatusOk::Success;
use tasklet::{TaskBuilder, TaskScheduler};

/// A simple example of a task with two steps,
/// that might work or fail sometimes.
#[tokio::main]
async fn main() {
    // Init the logger.
    SimpleLogger::new().init().unwrap();

    // A variable to be passed in the task.
    let mut exec_count = 0;

    // Task scheduler with 1000ms loop frequency.
    let mut scheduler = TaskScheduler::default(chrono::Local);

    // Create a task with 2 steps and add it to the scheduler.
    // The second step fails every second execution.
    // Append the task to the scheduler.
    scheduler.add_task(
        TaskBuilder::new(chrono::Local)
            .every("1 * * * * * *")
            .description("A simple task")
            .add_step("Step 1", || {
                info!("Hello from step 1");
                Ok(Success) // Let the scheduler know this step was a success.
            })
            .add_step("Step 2", move || {
                if exec_count % 2 == 0 {
                    exec_count += 1;
                    Err(Error(Some("Oh no this task failed".into()))) // Indicate that this step was a fail.
                } else {
                    info!("Hello from step 2");
                    exec_count += 1;
                    Ok(Success) // Indicate that this step was a success.
                }
            })
            .build(),
    );

    // Execute the scheduler.
    scheduler.run().await;
}

Author

Stavros Grigoriou (stav121)

Dependencies

~6–12MB
~131K SLoC