Skip to content

Commit 53aa3af

Browse files
committed
chore: add examples
1 parent 936485d commit 53aa3af

File tree

13 files changed

+142
-17
lines changed

13 files changed

+142
-17
lines changed

Cargo.lock

Lines changed: 42 additions & 13 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

Cargo.toml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
[workspace]
22
default-members = ["postgresql_archive", "postgresql_embedded"]
3-
members = ["postgresql_archive", "postgresql_embedded"]
3+
members = ["examples/*", "postgresql_archive", "postgresql_embedded"]
44
resolver = "2"
55

66
[workspace.package]

examples/archive_async/Cargo.toml

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
[package]
2+
edition = "2021"
3+
name = "archive_async"
4+
publish = false
5+
version = "0.1.0"
6+
7+
[dependencies]
8+
postgresql_archive = { path = "../../postgresql_archive" }
9+
tempfile = { workspace = true }
10+
tokio = { workspace = true }

examples/archive_async/src/main.rs

Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
use postgresql_archive::{extract, get_archive, Result, LATEST};
2+
3+
#[tokio::main]
4+
async fn main() -> Result<()> {
5+
let (archive_version, archive, _hash) = get_archive(&LATEST).await?;
6+
let out_dir = tempfile::tempdir()?.into_path();
7+
extract(&archive, &out_dir).await?;
8+
println!(
9+
"PostgreSQL {} extracted to {}",
10+
archive_version,
11+
out_dir.to_string_lossy()
12+
);
13+
Ok(())
14+
}

examples/archive_sync/Cargo.toml

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
[package]
2+
edition = "2021"
3+
name = "archive_sync"
4+
publish = false
5+
version = "0.1.0"
6+
7+
[dependencies]
8+
postgresql_archive = { path = "../../postgresql_archive", features = ["blocking"] }
9+
tempfile = { workspace = true }

examples/archive_sync/src/main.rs

Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
use postgresql_archive::blocking::{extract, get_archive};
2+
use postgresql_archive::{Result, LATEST};
3+
4+
fn main() -> Result<()> {
5+
let (archive_version, archive, _hash) = get_archive(&LATEST)?;
6+
let out_dir = tempfile::tempdir()?.into_path();
7+
extract(&archive, &out_dir)?;
8+
println!(
9+
"PostgreSQL {} extracted to {}",
10+
archive_version,
11+
out_dir.to_string_lossy()
12+
);
13+
Ok(())
14+
}

examples/embedded_async/Cargo.toml

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
[package]
2+
edition = "2021"
3+
name = "embedded_async"
4+
publish = false
5+
version = "0.1.0"
6+
7+
[dependencies]
8+
postgresql_embedded = { path = "../../postgresql_embedded" }
9+
tokio = { workspace = true }
10+
Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
use postgresql_embedded::{PostgreSQL, Result};
2+
3+
#[tokio::main]
4+
async fn main() -> Result<()> {
5+
let mut postgresql = PostgreSQL::default();
6+
postgresql.setup().await?;
7+
postgresql.start().await?;
8+
9+
let database_name = "test";
10+
postgresql.create_database(database_name).await?;
11+
postgresql.database_exists(database_name).await?;
12+
postgresql.drop_database(database_name).await?;
13+
14+
postgresql.stop().await
15+
}

examples/embedded_sync/Cargo.toml

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
[package]
2+
edition = "2021"
3+
name = "embedded_sync"
4+
publish = false
5+
version = "0.1.0"
6+
7+
[dependencies]
8+
postgresql_embedded = { path = "../../postgresql_embedded", features = ["blocking"] }

examples/embedded_sync/src/main.rs

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
use postgresql_embedded::blocking::PostgreSQL;
2+
use postgresql_embedded::Result;
3+
4+
fn main() -> Result<()> {
5+
let mut postgresql = PostgreSQL::default();
6+
postgresql.setup()?;
7+
postgresql.start()?;
8+
9+
let database_name = "test";
10+
postgresql.create_database(database_name)?;
11+
postgresql.database_exists(database_name)?;
12+
postgresql.drop_database(database_name)?;
13+
14+
postgresql.stop()
15+
}

0 commit comments

Comments
 (0)