dagger-rs/crates/dagger-sdk/examples/caching/main.rs

45 lines
1.2 KiB
Rust
Raw Permalink Normal View History

2023-02-17 17:40:46 +01:00
use rand::Rng;
#[tokio::main]
async fn main() -> eyre::Result<()> {
let client = dagger_sdk::connect().await?;
2023-02-17 17:40:46 +01:00
let host_source_dir = client.host().directory_opts(
"./examples/caching/app",
dagger_sdk::HostDirectoryOptsBuilder::default()
2023-04-29 23:36:53 +02:00
.exclude(vec!["node_modules/", "ci/"])
.build()?,
2023-02-17 17:40:46 +01:00
);
let node_cache = client.cache_volume("node").id().await?;
2023-02-17 17:40:46 +01:00
let source = client
.container()
.from("node:16")
.with_mounted_directory("/src", host_source_dir.id().await?)
.with_mounted_cache("/src/node_modules", node_cache);
2023-02-17 17:40:46 +01:00
let runner = source
.with_workdir("/src")
.with_exec(vec!["npm", "install"]);
let test = runner.with_exec(vec!["npm", "test", "--", "--watchAll=false"]);
2023-02-17 17:40:46 +01:00
let build_dir = test
.with_exec(vec!["npm", "run", "build"])
.directory("./build");
2023-02-17 17:40:46 +01:00
let mut rng = rand::thread_rng();
let ref_ = client
.container()
.from("nginx")
.with_directory("/usr/share/nginx/html", build_dir.id().await?)
.publish(format!("ttl.sh/hello-dagger-sdk-{}:1h", rng.gen::<u64>()))
.await?;
2023-02-17 17:40:46 +01:00
println!("published image to: {}", ref_);
Ok(())
}