diff --git a/crates/benchmarks/src/bin/merge.rs b/crates/benchmarks/src/bin/merge.rs index 5afa3e6f35..d3acb80c0a 100644 --- a/crates/benchmarks/src/bin/merge.rs +++ b/crates/benchmarks/src/bin/merge.rs @@ -355,6 +355,7 @@ struct MergePrefArgs { #[tokio::main] async fn main() { + type MergeOp = fn(DataFrame, DeltaTable) -> Result; match MergePrefArgs::parse().command { Command::Convert(Convert { tpcds_path, @@ -364,11 +365,9 @@ async fn main() { .await .unwrap(); } + Command::Bench(BenchArg { table_path, name }) => { - let (merge_op, params): ( - fn(DataFrame, DeltaTable) -> Result, - MergePerfParams, - ) = match name { + let (merge_op, params): (MergeOp, MergePerfParams) = match name { MergeBench::Upsert(params) => (merge_upsert, params), MergeBench::Delete(params) => (merge_delete, params), MergeBench::Insert(params) => (merge_insert, params), diff --git a/crates/deltalake-core/src/delta_datafusion/mod.rs b/crates/deltalake-core/src/delta_datafusion/mod.rs index d3883eac8b..5890401e67 100644 --- a/crates/deltalake-core/src/delta_datafusion/mod.rs +++ b/crates/deltalake-core/src/delta_datafusion/mod.rs @@ -146,7 +146,7 @@ impl DeltaTableState { let files = self.files(); // Initalize statistics - let mut table_stats = match files.get(0) { + let mut table_stats = match files.first() { Some(file) => match file.get_stats() { Ok(Some(stats)) => { let mut column_statistics = Vec::with_capacity(schema.fields().size()); diff --git a/crates/deltalake-core/src/kernel/arrow/mod.rs b/crates/deltalake-core/src/kernel/arrow/mod.rs index 0c89f6ab48..1fbacec4f3 100644 --- a/crates/deltalake-core/src/kernel/arrow/mod.rs +++ b/crates/deltalake-core/src/kernel/arrow/mod.rs @@ -686,7 +686,7 @@ mod tests { let partition_values_parsed = add_field_map.get("partitionValues_parsed").unwrap(); if let ArrowDataType::Struct(fields) = partition_values_parsed.data_type() { assert_eq!(1, fields.len()); - let field = fields.get(0).unwrap().to_owned(); + let field = fields.first().unwrap().to_owned(); assert_eq!( Arc::new(ArrowField::new("pcol", ArrowDataType::Int32, true)), field @@ -708,7 +708,7 @@ mod tests { "minValues" | "maxValues" | "nullCount" => match v.data_type() { ArrowDataType::Struct(fields) => { assert_eq!(1, fields.len()); - let field = fields.get(0).unwrap().to_owned(); + let field = fields.first().unwrap().to_owned(); let data_type = if k == "nullCount" { ArrowDataType::Int64 } else { diff --git a/crates/deltalake-core/src/lib.rs b/crates/deltalake-core/src/lib.rs index 4f0bd64ef0..d95f8d40e3 100644 --- a/crates/deltalake-core/src/lib.rs +++ b/crates/deltalake-core/src/lib.rs @@ -67,7 +67,6 @@ //! }; //! ``` -#![deny(warnings)] #![deny(missing_docs)] #![allow(rustdoc::invalid_html_tags)] #![allow(clippy::nonminimal_bool)] diff --git a/crates/deltalake-core/tests/checkpoint_writer.rs b/crates/deltalake-core/tests/checkpoint_writer.rs index b1fc28faed..ca6fbccf97 100644 --- a/crates/deltalake-core/tests/checkpoint_writer.rs +++ b/crates/deltalake-core/tests/checkpoint_writer.rs @@ -51,8 +51,8 @@ mod simple_checkpoint { // delta table should load just fine with the checkpoint in place let table_result = deltalake_core::open_table(table_location).await.unwrap(); let table = table_result; - let files = table.get_files(); - assert_eq!(12, files.len()); + let files = table.get_files_iter(); + assert_eq!(12, files.count()); } fn get_last_checkpoint_version(log_path: &Path) -> i64 { @@ -138,7 +138,7 @@ mod delete_expired_delta_log_in_checkpoint { table.update().await.unwrap(); // make table to read the checkpoint assert_eq!( - table.get_files(), + table.get_files_iter().collect::>(), vec![ ObjectStorePath::from(a1.path.as_ref()), ObjectStorePath::from(a2.path.as_ref()) @@ -186,7 +186,7 @@ mod delete_expired_delta_log_in_checkpoint { .unwrap(); table.update().await.unwrap(); // make table to read the checkpoint assert_eq!( - table.get_files(), + table.get_files_iter().collect::>(), vec![ ObjectStorePath::from(a1.path.as_ref()), ObjectStorePath::from(a2.path.as_ref()) @@ -249,7 +249,7 @@ mod checkpoints_with_tombstones { checkpoints::create_checkpoint(&table).await.unwrap(); table.update().await.unwrap(); // make table to read the checkpoint assert_eq!( - table.get_files(), + table.get_files_iter().collect::>(), vec![ ObjectStorePath::from(a1.path.as_ref()), ObjectStorePath::from(a2.path.as_ref()) @@ -258,7 +258,7 @@ mod checkpoints_with_tombstones { let (removes1, opt1) = pseudo_optimize(&mut table, 5 * 59 * 1000).await; assert_eq!( - table.get_files(), + table.get_files_iter().collect::>(), vec![ObjectStorePath::from(opt1.path.as_ref())] ); assert_eq!(table.get_state().all_tombstones(), &removes1); @@ -266,7 +266,7 @@ mod checkpoints_with_tombstones { checkpoints::create_checkpoint(&table).await.unwrap(); table.update().await.unwrap(); // make table to read the checkpoint assert_eq!( - table.get_files(), + table.get_files_iter().collect::>(), vec![ObjectStorePath::from(opt1.path.as_ref())] ); assert_eq!(table.get_state().all_tombstones().len(), 0); // stale removes are deleted from the state @@ -335,8 +335,7 @@ mod checkpoints_with_tombstones { async fn pseudo_optimize(table: &mut DeltaTable, offset_millis: i64) -> (HashSet, Add) { let removes: HashSet = table - .get_files() - .iter() + .get_files_iter() .map(|p| Remove { path: p.to_string(), deletion_timestamp: Some(Utc::now().timestamp_millis() - offset_millis), diff --git a/crates/deltalake-core/tests/command_optimize.rs b/crates/deltalake-core/tests/command_optimize.rs index b91558ce08..468f3f279f 100644 --- a/crates/deltalake-core/tests/command_optimize.rs +++ b/crates/deltalake-core/tests/command_optimize.rs @@ -714,7 +714,7 @@ async fn test_zorder_unpartitioned() -> Result<(), Box> { assert_eq!(metrics.total_considered_files, 2); // Check data - let files = dt.get_files(); + let files = dt.get_files_iter().collect::>(); assert_eq!(files.len(), 1); let actual = read_parquet_file(&files[0], dt.object_store()).await?;