use std::sync::Arc;
use async_trait::async_trait;
use crate::table::Table;
use crate::transaction::action::{ActionCommit, TransactionAction};
use crate::{Error, ErrorKind, Result, TableUpdate};
pub struct UpdateLocationAction {
location: Option<String>,
}
impl UpdateLocationAction {
pub fn new() -> Self {
UpdateLocationAction { location: None }
}
pub fn set_location(mut self, location: String) -> Self {
self.location = Some(location);
self
}
}
impl Default for UpdateLocationAction {
fn default() -> Self {
Self::new()
}
}
#[async_trait]
impl TransactionAction for UpdateLocationAction {
async fn commit(self: Arc<Self>, _table: &Table) -> Result<ActionCommit> {
let updates: Vec<TableUpdate>;
if let Some(location) = self.location.clone() {
updates = vec![TableUpdate::SetLocation { location }];
} else {
return Err(Error::new(
ErrorKind::DataInvalid,
"Location is not set for UpdateLocationAction!",
));
}
Ok(ActionCommit::new(updates, vec![]))
}
}
#[cfg(test)]
mod tests {
use as_any::Downcast;
use crate::transaction::Transaction;
use crate::transaction::action::ApplyTransactionAction;
use crate::transaction::tests::make_v2_table;
use crate::transaction::update_location::UpdateLocationAction;
#[test]
fn test_set_location() {
let table = make_v2_table();
let tx = Transaction::new(&table);
let tx = tx
.update_location()
.set_location(String::from("s3://bucket/prefix/new_table"))
.apply(tx)
.unwrap();
assert_eq!(tx.actions.len(), 1);
let action = (*tx.actions[0])
.downcast_ref::<UpdateLocationAction>()
.unwrap();
assert_eq!(
action.location,
Some(String::from("s3://bucket/prefix/new_table"))
)
}
}