use std::sync::Arc;
use async_trait::async_trait;
use crate::TableUpdate::UpgradeFormatVersion;
use crate::spec::FormatVersion;
use crate::table::Table;
use crate::transaction::action::{ActionCommit, TransactionAction};
use crate::{Error, ErrorKind, Result};
pub struct UpgradeFormatVersionAction {
format_version: Option<FormatVersion>,
}
impl UpgradeFormatVersionAction {
pub fn new() -> Self {
UpgradeFormatVersionAction {
format_version: None,
}
}
pub fn set_format_version(mut self, format_version: FormatVersion) -> Self {
self.format_version = Some(format_version);
self
}
}
impl Default for UpgradeFormatVersionAction {
fn default() -> Self {
Self::new()
}
}
#[async_trait]
impl TransactionAction for UpgradeFormatVersionAction {
async fn commit(self: Arc<Self>, _table: &Table) -> Result<ActionCommit> {
let format_version = self.format_version.ok_or_else(|| {
Error::new(
ErrorKind::DataInvalid,
"FormatVersion is not set for UpgradeFormatVersionAction!",
)
})?;
Ok(ActionCommit::new(
vec![UpgradeFormatVersion { format_version }],
vec![],
))
}
}
#[cfg(test)]
mod tests {
use as_any::Downcast;
use crate::spec::FormatVersion;
use crate::transaction::Transaction;
use crate::transaction::action::ApplyTransactionAction;
use crate::transaction::upgrade_format_version::UpgradeFormatVersionAction;
#[test]
fn test_upgrade_format_version() {
let table = crate::transaction::tests::make_v1_table();
let tx = Transaction::new(&table);
let tx = tx
.upgrade_table_version()
.set_format_version(FormatVersion::V2)
.apply(tx)
.unwrap();
assert_eq!(tx.actions.len(), 1);
let action = (*tx.actions[0])
.downcast_ref::<UpgradeFormatVersionAction>()
.unwrap();
assert_eq!(action.format_version, Some(FormatVersion::V2));
}
}