quickwit_actors/kill_switch.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
// Copyright (C) 2021 Quickwit, Inc.
//
// Quickwit is offered under the AGPL v3.0 and as commercial software.
// For commercial licensing, contact us at hello@quickwit.io.
//
// AGPL:
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
use std::sync::atomic::{AtomicBool, Ordering};
use std::sync::Arc;
use tracing::debug;
#[derive(Clone)]
pub struct KillSwitch {
alive: Arc<AtomicBool>,
}
impl Default for KillSwitch {
fn default() -> Self {
KillSwitch {
alive: Arc::new(AtomicBool::new(true)),
}
}
}
impl KillSwitch {
pub fn kill(&self) {
debug!("kill-switch-activated");
self.alive.store(false, Ordering::Relaxed);
}
pub fn is_alive(&self) -> bool {
self.alive.load(Ordering::Relaxed)
}
pub fn is_dead(&self) -> bool {
!self.is_alive()
}
}
#[cfg(test)]
mod tests {
use super::KillSwitch;
#[test]
fn test_kill_switch() {
let kill_switch = KillSwitch::default();
assert!(kill_switch.is_alive());
assert!(!kill_switch.is_dead());
kill_switch.kill();
assert!(!kill_switch.is_alive());
assert!(kill_switch.is_dead());
kill_switch.kill();
assert!(!kill_switch.is_alive());
assert!(kill_switch.is_dead());
}
}