forked from databendlabs/openraft
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
With `SnapshotPolicy::Never`, Openraft will not build snapshots automatically based on a policy. Instead, the application has full control over when snapshots are built. In this scenario, the application can call the `Raft::trigger_snapshot()` API at the desired times to manually trigger Openraft to build a snapshot. Rename integration tests: - `log_compaction -> snapshot_building` - `snapshto -> snapshot_streaming` - Fix: databendlabs#851
- Loading branch information
1 parent
4ab38e7
commit 269d221
Showing
23 changed files
with
125 additions
and
8 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
File renamed without changes.
82 changes: 82 additions & 0 deletions
82
tests/tests/snapshot_building/t60_snapshot_policy_never.rs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,82 @@ | ||
use std::sync::Arc; | ||
use std::time::Duration; | ||
|
||
use anyhow::Result; | ||
use futures::StreamExt; | ||
use maplit::btreeset; | ||
use openraft::Config; | ||
use openraft::SnapshotPolicy; | ||
|
||
use crate::fixtures::init_default_ut_tracing; | ||
use crate::fixtures::RaftRouter; | ||
|
||
/// Compaction test. | ||
/// | ||
/// What does this test do? | ||
/// | ||
/// - build a stable single node cluster. | ||
/// - send enough requests to the node that log compaction will be triggered. | ||
/// - add new nodes and assert that they receive the snapshot. | ||
#[async_entry::test(worker_threads = 8, init = "init_default_ut_tracing()", tracing_span = "debug")] | ||
async fn snapshot_policy_never() -> Result<()> { | ||
let n_logs: u64 = 6000; | ||
let default_config = Config::default().snapshot_policy; | ||
let default_threshold = if let SnapshotPolicy::LogsSinceLast(n) = default_config { | ||
n | ||
} else { | ||
panic!("snapshot_policy must be never"); | ||
}; | ||
|
||
assert!( | ||
n_logs > default_threshold, | ||
"snapshot_threshold must be greater than default threshold" | ||
); | ||
|
||
// Setup test dependencies. | ||
let config = Arc::new( | ||
Config { | ||
snapshot_policy: SnapshotPolicy::Never, | ||
enable_tick: false, | ||
..Default::default() | ||
} | ||
.validate()?, | ||
); | ||
let mut router = RaftRouter::new(config.clone()); | ||
|
||
tracing::info!("--- initializing cluster"); | ||
let mut log_index = router.new_cluster(btreeset! {0}, btreeset! {}).await?; | ||
|
||
let mut clients = futures::stream::FuturesUnordered::new(); | ||
|
||
let n_clients = 20; | ||
for i in 0..n_clients { | ||
let per_client = n_logs / n_clients; | ||
let r = router.clone(); | ||
clients.push(async move { | ||
let client_id = format!("{}", i); | ||
r.client_request_many(0, &client_id, per_client as usize).await | ||
}); | ||
log_index += per_client; | ||
} | ||
|
||
while clients.next().await.is_some() {} | ||
|
||
tracing::info!(log_index, "--- log_index: {}", log_index); | ||
router | ||
.wait(&0, timeout()) | ||
.log(Some(log_index), format_args!("write log upto {}", log_index)) | ||
.await?; | ||
|
||
let wait_snapshot_res = router | ||
.wait(&0, Some(Duration::from_millis(3_000))) | ||
.metrics(|m| m.snapshot.is_some(), "no snapshot will be built") | ||
.await; | ||
|
||
assert!(wait_snapshot_res.is_err(), "no snapshot should be built"); | ||
|
||
Ok(()) | ||
} | ||
|
||
fn timeout() -> Option<Duration> { | ||
Some(Duration::from_millis(1_000)) | ||
} |
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.