This is an automated email from the ASF dual-hosted git repository.

github-bot pushed a commit to branch gh-pages
in repository https://gitbox.apache.org/repos/asf/iceberg-rust.git


The following commit(s) were added to refs/heads/gh-pages by this push:
     new 640c9dda3 deploy: 5dc57643aebbe1be3ac36e29581fa7462bfdd2cd
640c9dda3 is described below

commit 640c9dda3826bcb2f508bf71acb7599038b0de7e
Author: liurenjie1024 <[email protected]>
AuthorDate: Thu Dec 25 00:48:41 2025 +0000

    deploy: 5dc57643aebbe1be3ac36e29581fa7462bfdd2cd
---
 api/iceberg_sqllogictest/all.html                  |   2 +-
 api/iceberg_sqllogictest/schedule/index.html       |   2 +-
 api/iceberg_sqllogictest/schedule/sidebar-items.js |   2 +-
 .../schedule/struct.Schedule.html                  |   4 +-
 ...struct.Step.html => struct.ScheduleConfig.html} |  11 +-
 api/iceberg_sqllogictest/schedule/struct.Step.html |   4 +-
 api/search-index.js                                |   4 +-
 .../iceberg_sqllogictest-desc-0-.js                |   2 +-
 .../iceberg_sqllogictest/engine/datafusion.rs.html | 262 +++++++-------
 api/src/iceberg_sqllogictest/engine/mod.rs.html    | 194 ++++++----
 api/src/iceberg_sqllogictest/schedule.rs.html      | 400 ++++++++++++---------
 api/trait.impl/core/clone/trait.Clone.js           |   4 +-
 api/trait.impl/core/fmt/trait.Debug.js             |   4 +-
 api/trait.impl/core/marker/trait.Freeze.js         |   4 +-
 api/trait.impl/core/marker/trait.Send.js           |   4 +-
 api/trait.impl/core/marker/trait.Sync.js           |   4 +-
 api/trait.impl/core/marker/trait.Unpin.js          |   4 +-
 api/trait.impl/core/marker/trait.UnsafeUnpin.js    |   4 +-
 .../core/panic/unwind_safe/trait.RefUnwindSafe.js  |   4 +-
 .../core/panic/unwind_safe/trait.UnwindSafe.js     |   4 +-
 api/trait.impl/serde_core/de/trait.Deserialize.js  |   4 +-
 21 files changed, 517 insertions(+), 410 deletions(-)

diff --git a/api/iceberg_sqllogictest/all.html 
b/api/iceberg_sqllogictest/all.html
index b79249007..0ab5702fb 100644
--- a/api/iceberg_sqllogictest/all.html
+++ b/api/iceberg_sqllogictest/all.html
@@ -1 +1 @@
-<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta 
name="viewport" content="width=device-width, initial-scale=1.0"><meta 
name="generator" content="rustdoc"><meta name="description" content="List of 
all items in this crate"><title>List of all items in this 
crate</title><script>if(window.location.protocol!=="file:")document.head.insertAdjacentHTML("beforeend","SourceSerif4-Regular-6b053e98.ttf.woff2,FiraSans-Italic-81dc35de.woff2,FiraSans-Regular-0fe48ade.woff2,FiraSans-Mediu
 [...]
\ No newline at end of file
+<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta 
name="viewport" content="width=device-width, initial-scale=1.0"><meta 
name="generator" content="rustdoc"><meta name="description" content="List of 
all items in this crate"><title>List of all items in this 
crate</title><script>if(window.location.protocol!=="file:")document.head.insertAdjacentHTML("beforeend","SourceSerif4-Regular-6b053e98.ttf.woff2,FiraSans-Italic-81dc35de.woff2,FiraSans-Regular-0fe48ade.woff2,FiraSans-Mediu
 [...]
\ No newline at end of file
diff --git a/api/iceberg_sqllogictest/schedule/index.html 
b/api/iceberg_sqllogictest/schedule/index.html
index b1eef89f2..f824259f0 100644
--- a/api/iceberg_sqllogictest/schedule/index.html
+++ b/api/iceberg_sqllogictest/schedule/index.html
@@ -1 +1 @@
-<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta 
name="viewport" content="width=device-width, initial-scale=1.0"><meta 
name="generator" content="rustdoc"><meta name="description" content="API 
documentation for the Rust `schedule` mod in crate 
`iceberg_sqllogictest`."><title>iceberg_sqllogictest::schedule - 
Rust</title><script>if(window.location.protocol!=="file:")document.head.insertAdjacentHTML("beforeend","SourceSerif4-Regular-6b053e98.ttf.woff2,FiraSans-Italic-81dc35de
 [...]
\ No newline at end of file
+<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta 
name="viewport" content="width=device-width, initial-scale=1.0"><meta 
name="generator" content="rustdoc"><meta name="description" content="API 
documentation for the Rust `schedule` mod in crate 
`iceberg_sqllogictest`."><title>iceberg_sqllogictest::schedule - 
Rust</title><script>if(window.location.protocol!=="file:")document.head.insertAdjacentHTML("beforeend","SourceSerif4-Regular-6b053e98.ttf.woff2,FiraSans-Italic-81dc35de
 [...]
\ No newline at end of file
diff --git a/api/iceberg_sqllogictest/schedule/sidebar-items.js 
b/api/iceberg_sqllogictest/schedule/sidebar-items.js
index 05d983033..833889f0f 100644
--- a/api/iceberg_sqllogictest/schedule/sidebar-items.js
+++ b/api/iceberg_sqllogictest/schedule/sidebar-items.js
@@ -1 +1 @@
-window.SIDEBAR_ITEMS = {"struct":["Schedule","Step"]};
\ No newline at end of file
+window.SIDEBAR_ITEMS = {"struct":["Schedule","ScheduleConfig","Step"]};
\ No newline at end of file
diff --git a/api/iceberg_sqllogictest/schedule/struct.Schedule.html 
b/api/iceberg_sqllogictest/schedule/struct.Schedule.html
index 6c5febe90..4890e6f19 100644
--- a/api/iceberg_sqllogictest/schedule/struct.Schedule.html
+++ b/api/iceberg_sqllogictest/schedule/struct.Schedule.html
@@ -1,8 +1,8 @@
-<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta 
name="viewport" content="width=device-width, initial-scale=1.0"><meta 
name="generator" content="rustdoc"><meta name="description" content="API 
documentation for the Rust `Schedule` struct in crate 
`iceberg_sqllogictest`."><title>Schedule in iceberg_sqllogictest::schedule - 
Rust</title><script>if(window.location.protocol!=="file:")document.head.insertAdjacentHTML("beforeend","SourceSerif4-Regular-6b053e98.ttf.woff2,FiraSans-
 [...]
+<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta 
name="viewport" content="width=device-width, initial-scale=1.0"><meta 
name="generator" content="rustdoc"><meta name="description" content="API 
documentation for the Rust `Schedule` struct in crate 
`iceberg_sqllogictest`."><title>Schedule in iceberg_sqllogictest::schedule - 
Rust</title><script>if(window.location.protocol!=="file:")document.head.insertAdjacentHTML("beforeend","SourceSerif4-Regular-6b053e98.ttf.woff2,FiraSans-
 [...]
     engines: <a class="struct" 
href="https://doc.rust-lang.org/nightly/std/collections/hash/map/struct.HashMap.html";
 title="struct std::collections::hash::map::HashMap">HashMap</a>&lt;<a 
class="struct" 
href="https://doc.rust-lang.org/nightly/alloc/string/struct.String.html"; 
title="struct alloc::string::String">String</a>, <a class="struct" 
href="https://doc.rust-lang.org/nightly/alloc/boxed/struct.Box.html"; 
title="struct alloc::boxed::Box">Box</a>&lt;dyn EngineRunner&gt;&gt;,
     steps: <a class="struct" 
href="https://doc.rust-lang.org/nightly/alloc/vec/struct.Vec.html"; 
title="struct alloc::vec::Vec">Vec</a>&lt;<a class="struct" 
href="struct.Step.html" title="struct 
iceberg_sqllogictest::schedule::Step">Step</a>&gt;,
     schedule_file: <a class="struct" 
href="https://doc.rust-lang.org/nightly/alloc/string/struct.String.html"; 
title="struct alloc::string::String">String</a>,
-) -&gt; Self</h4></section><section id="method.from_file" class="method"><a 
class="src rightside" 
href="../../src/iceberg_sqllogictest/schedule.rs.html#59-71">Source</a><h4 
class="code-header">pub async fn <a href="#method.from_file" 
class="fn">from_file</a>&lt;P: <a class="trait" 
href="https://doc.rust-lang.org/nightly/core/convert/trait.AsRef.html"; 
title="trait core::convert::AsRef">AsRef</a>&lt;<a class="struct" 
href="https://doc.rust-lang.org/nightly/std/path/struct.Path.html"; title= [...]
+) -&gt; Self</h4></section><section id="method.from_file" class="method"><a 
class="src rightside" 
href="../../src/iceberg_sqllogictest/schedule.rs.html#67-77">Source</a><h4 
class="code-header">pub async fn <a href="#method.from_file" 
class="fn">from_file</a>&lt;P: <a class="trait" 
href="https://doc.rust-lang.org/nightly/core/convert/trait.AsRef.html"; 
title="trait core::convert::AsRef">AsRef</a>&lt;<a class="struct" 
href="https://doc.rust-lang.org/nightly/std/path/struct.Path.html"; title= [...]
     T: 'static + ?<a class="trait" 
href="https://doc.rust-lang.org/nightly/core/marker/trait.Sized.html"; 
title="trait core::marker::Sized">Sized</a>,</div></h3></section></summary><div 
class="impl-items"><details class="toggle method-toggle" open><summary><section 
id="method.type_id" class="method trait-impl"><a class="src rightside" 
href="https://doc.rust-lang.org/nightly/src/core/any.rs.html#139";>Source</a><a 
href="#method.type_id" class="anchor">§</a><h4 class="code-header">fn <a href 
[...]
     T: <a class="trait" 
href="https://doc.rust-lang.org/nightly/core/any/trait.Any.html"; title="trait 
core::any::Any">Any</a>,</div></h3></section></summary><div 
class="impl-items"><section id="method.as_any" class="method trait-impl"><a 
href="#method.as_any" class="anchor">§</a><h4 class="code-header">fn <a 
class="fn">as_any</a>(&amp;self) -&gt; &amp;(dyn <a class="trait" 
href="https://doc.rust-lang.org/nightly/core/any/trait.Any.html"; title="trait 
core::any::Any">Any</a> + 'static)</h4 [...]
     T: ?<a class="trait" 
href="https://doc.rust-lang.org/nightly/core/marker/trait.Sized.html"; 
title="trait core::marker::Sized">Sized</a>,</div></h3></section></summary><div 
class="impl-items"><details class="toggle method-toggle" open><summary><section 
id="method.borrow" class="method trait-impl"><a class="src rightside" 
href="https://doc.rust-lang.org/nightly/src/core/borrow.rs.html#211";>Source</a><a
 href="#method.borrow" class="anchor">§</a><h4 class="code-header">fn <a 
href="https:/ [...]
diff --git a/api/iceberg_sqllogictest/schedule/struct.Step.html 
b/api/iceberg_sqllogictest/schedule/struct.ScheduleConfig.html
similarity index 77%
copy from api/iceberg_sqllogictest/schedule/struct.Step.html
copy to api/iceberg_sqllogictest/schedule/struct.ScheduleConfig.html
index c4978667c..351297db0 100644
--- a/api/iceberg_sqllogictest/schedule/struct.Step.html
+++ b/api/iceberg_sqllogictest/schedule/struct.ScheduleConfig.html
@@ -1,6 +1,11 @@
-<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta 
name="viewport" content="width=device-width, initial-scale=1.0"><meta 
name="generator" content="rustdoc"><meta name="description" content="API 
documentation for the Rust `Step` struct in crate 
`iceberg_sqllogictest`."><title>Step in iceberg_sqllogictest::schedule - 
Rust</title><script>if(window.location.protocol!=="file:")document.head.insertAdjacentHTML("beforeend","SourceSerif4-Regular-6b053e98.ttf.woff2,FiraSans-Italic-8
 [...]
-    __D: <a class="trait" 
href="https://docs.rs/serde_core/1.0.228/serde_core/de/trait.Deserializer.html"; 
title="trait 
serde_core::de::Deserializer">Deserializer</a>&lt;'de&gt;,</div></h4></section></summary><div
 class='docblock'>Deserialize this value from the given Serde deserializer. <a 
href="https://docs.rs/serde_core/1.0.228/serde_core/de/trait.Deserialize.html#tymethod.deserialize";>Read
 more</a></div></details></div></details><details class="toggle 
implementors-toggle" open><summar [...]
-    __S: <a class="trait" 
href="https://docs.rs/serde_core/1.0.228/serde_core/ser/trait.Serializer.html"; 
title="trait 
serde_core::ser::Serializer">Serializer</a>,</div></h4></section></summary><div 
class='docblock'>Serialize this value into the given Serde serializer. <a 
href="https://docs.rs/serde_core/1.0.228/serde_core/ser/trait.Serialize.html#tymethod.serialize";>Read
 more</a></div></details></div></details></div><h2 
id="synthetic-implementations" class="section-header">Auto Trait Imp [...]
+<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta 
name="viewport" content="width=device-width, initial-scale=1.0"><meta 
name="generator" content="rustdoc"><meta name="description" content="Raw 
configuration parsed from the schedule TOML file"><title>ScheduleConfig in 
iceberg_sqllogictest::schedule - 
Rust</title><script>if(window.location.protocol!=="file:")document.head.insertAdjacentHTML("beforeend","SourceSerif4-Regular-6b053e98.ttf.woff2,FiraSans-Italic-81dc35de.woff2,F
 [...]
+    pub engines: <a class="struct" 
href="https://doc.rust-lang.org/nightly/std/collections/hash/map/struct.HashMap.html";
 title="struct std::collections::hash::map::HashMap">HashMap</a>&lt;<a 
class="struct" 
href="https://doc.rust-lang.org/nightly/alloc/string/struct.String.html"; 
title="struct alloc::string::String">String</a>, EngineConfig&gt;,
+    pub steps: <a class="struct" 
href="https://doc.rust-lang.org/nightly/alloc/vec/struct.Vec.html"; 
title="struct alloc::vec::Vec">Vec</a>&lt;<a class="struct" 
href="struct.Step.html" title="struct 
iceberg_sqllogictest::schedule::Step">Step</a>&gt;,
+}</code></pre><details class="toggle top-doc" open><summary 
class="hideme"><span>Expand description</span></summary><div 
class="docblock"><p>Raw configuration parsed from the schedule TOML file</p>
+</div></details><h2 id="fields" class="fields section-header">Fields<a 
href="#fields" class="anchor">§</a></h2><span id="structfield.engines" 
class="structfield section-header"><a href="#structfield.engines" class="anchor 
field">§</a><code>engines: <a class="struct" 
href="https://doc.rust-lang.org/nightly/std/collections/hash/map/struct.HashMap.html";
 title="struct std::collections::hash::map::HashMap">HashMap</a>&lt;<a 
class="struct" href="https://doc.rust-lang.org/nightly/alloc/string/s [...]
+</div><span id="structfield.steps" class="structfield section-header"><a 
href="#structfield.steps" class="anchor field">§</a><code>steps: <a 
class="struct" 
href="https://doc.rust-lang.org/nightly/alloc/vec/struct.Vec.html"; 
title="struct alloc::vec::Vec">Vec</a>&lt;<a class="struct" 
href="struct.Step.html" title="struct 
iceberg_sqllogictest::schedule::Step">Step</a>&gt;</code></span><div 
class="docblock"><p>List of test steps to run</p>
+</div><h2 id="trait-implementations" class="section-header">Trait 
Implementations<a href="#trait-implementations" class="anchor">§</a></h2><div 
id="trait-implementations-list"><details class="toggle implementors-toggle" 
open><summary><section id="impl-Clone-for-ScheduleConfig" class="impl"><a 
class="src rightside" 
href="../../src/iceberg_sqllogictest/schedule.rs.html#29">Source</a><a 
href="#impl-Clone-for-ScheduleConfig" class="anchor">§</a><h3 
class="code-header">impl <a class="trait" h [...]
+    __D: <a class="trait" 
href="https://docs.rs/serde_core/1.0.228/serde_core/de/trait.Deserializer.html"; 
title="trait 
serde_core::de::Deserializer">Deserializer</a>&lt;'de&gt;,</div></h4></section></summary><div
 class='docblock'>Deserialize this value from the given Serde deserializer. <a 
href="https://docs.rs/serde_core/1.0.228/serde_core/de/trait.Deserialize.html#tymethod.deserialize";>Read
 more</a></div></details></div></details></div><h2 
id="synthetic-implementations" class="section- [...]
     T: 'static + ?<a class="trait" 
href="https://doc.rust-lang.org/nightly/core/marker/trait.Sized.html"; 
title="trait core::marker::Sized">Sized</a>,</div></h3></section></summary><div 
class="impl-items"><details class="toggle method-toggle" open><summary><section 
id="method.type_id" class="method trait-impl"><a class="src rightside" 
href="https://doc.rust-lang.org/nightly/src/core/any.rs.html#139";>Source</a><a 
href="#method.type_id" class="anchor">§</a><h4 class="code-header">fn <a href 
[...]
     T: <a class="trait" 
href="https://doc.rust-lang.org/nightly/core/any/trait.Any.html"; title="trait 
core::any::Any">Any</a>,</div></h3></section></summary><div 
class="impl-items"><section id="method.as_any" class="method trait-impl"><a 
href="#method.as_any" class="anchor">§</a><h4 class="code-header">fn <a 
class="fn">as_any</a>(&amp;self) -&gt; &amp;(dyn <a class="trait" 
href="https://doc.rust-lang.org/nightly/core/any/trait.Any.html"; title="trait 
core::any::Any">Any</a> + 'static)</h4 [...]
     T: ?<a class="trait" 
href="https://doc.rust-lang.org/nightly/core/marker/trait.Sized.html"; 
title="trait core::marker::Sized">Sized</a>,</div></h3></section></summary><div 
class="impl-items"><details class="toggle method-toggle" open><summary><section 
id="method.borrow" class="method trait-impl"><a class="src rightside" 
href="https://doc.rust-lang.org/nightly/src/core/borrow.rs.html#211";>Source</a><a
 href="#method.borrow" class="anchor">§</a><h4 class="code-header">fn <a 
href="https:/ [...]
diff --git a/api/iceberg_sqllogictest/schedule/struct.Step.html 
b/api/iceberg_sqllogictest/schedule/struct.Step.html
index c4978667c..b87af8f3d 100644
--- a/api/iceberg_sqllogictest/schedule/struct.Step.html
+++ b/api/iceberg_sqllogictest/schedule/struct.Step.html
@@ -1,5 +1,5 @@
-<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta 
name="viewport" content="width=device-width, initial-scale=1.0"><meta 
name="generator" content="rustdoc"><meta name="description" content="API 
documentation for the Rust `Step` struct in crate 
`iceberg_sqllogictest`."><title>Step in iceberg_sqllogictest::schedule - 
Rust</title><script>if(window.location.protocol!=="file:")document.head.insertAdjacentHTML("beforeend","SourceSerif4-Regular-6b053e98.ttf.woff2,FiraSans-Italic-8
 [...]
-    __D: <a class="trait" 
href="https://docs.rs/serde_core/1.0.228/serde_core/de/trait.Deserializer.html"; 
title="trait 
serde_core::de::Deserializer">Deserializer</a>&lt;'de&gt;,</div></h4></section></summary><div
 class='docblock'>Deserialize this value from the given Serde deserializer. <a 
href="https://docs.rs/serde_core/1.0.228/serde_core/de/trait.Deserialize.html#tymethod.deserialize";>Read
 more</a></div></details></div></details><details class="toggle 
implementors-toggle" open><summar [...]
+<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta 
name="viewport" content="width=device-width, initial-scale=1.0"><meta 
name="generator" content="rustdoc"><meta name="description" content="API 
documentation for the Rust `Step` struct in crate 
`iceberg_sqllogictest`."><title>Step in iceberg_sqllogictest::schedule - 
Rust</title><script>if(window.location.protocol!=="file:")document.head.insertAdjacentHTML("beforeend","SourceSerif4-Regular-6b053e98.ttf.woff2,FiraSans-Italic-8
 [...]
+    __D: <a class="trait" 
href="https://docs.rs/serde_core/1.0.228/serde_core/de/trait.Deserializer.html"; 
title="trait 
serde_core::de::Deserializer">Deserializer</a>&lt;'de&gt;,</div></h4></section></summary><div
 class='docblock'>Deserialize this value from the given Serde deserializer. <a 
href="https://docs.rs/serde_core/1.0.228/serde_core/de/trait.Deserialize.html#tymethod.deserialize";>Read
 more</a></div></details></div></details><details class="toggle 
implementors-toggle" open><summar [...]
     __S: <a class="trait" 
href="https://docs.rs/serde_core/1.0.228/serde_core/ser/trait.Serializer.html"; 
title="trait 
serde_core::ser::Serializer">Serializer</a>,</div></h4></section></summary><div 
class='docblock'>Serialize this value into the given Serde serializer. <a 
href="https://docs.rs/serde_core/1.0.228/serde_core/ser/trait.Serialize.html#tymethod.serialize";>Read
 more</a></div></details></div></details></div><h2 
id="synthetic-implementations" class="section-header">Auto Trait Imp [...]
     T: 'static + ?<a class="trait" 
href="https://doc.rust-lang.org/nightly/core/marker/trait.Sized.html"; 
title="trait core::marker::Sized">Sized</a>,</div></h3></section></summary><div 
class="impl-items"><details class="toggle method-toggle" open><summary><section 
id="method.type_id" class="method trait-impl"><a class="src rightside" 
href="https://doc.rust-lang.org/nightly/src/core/any.rs.html#139";>Source</a><a 
href="#method.type_id" class="anchor">§</a><h4 class="code-header">fn <a href 
[...]
     T: <a class="trait" 
href="https://doc.rust-lang.org/nightly/core/any/trait.Any.html"; title="trait 
core::any::Any">Any</a>,</div></h3></section></summary><div 
class="impl-items"><section id="method.as_any" class="method trait-impl"><a 
href="#method.as_any" class="anchor">§</a><h4 class="code-header">fn <a 
class="fn">as_any</a>(&amp;self) -&gt; &amp;(dyn <a class="trait" 
href="https://doc.rust-lang.org/nightly/core/any/trait.Any.html"; title="trait 
core::any::Any">Any</a> + 'static)</h4 [...]
diff --git a/api/search-index.js b/api/search-index.js
index f7a41e652..11172f892 100644
--- a/api/search-index.js
+++ b/api/search-index.js
@@ -1,4 +1,4 @@
-var searchIndex = new 
Map(JSON.parse('[["iceberg",{"t":"PPPPPPPPPRKKPPPPPPFGPPPFFFPFPPPPPPPPPPPPPPIPPPPPPPPPPPPFFFPGGPPPPFGNNNNNNNNNNNNNNNCNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNCNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNMNOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNMNQNNNNNNNNNNNNNNNNNNNNCNNNNNNNNNNNNNNNNNNONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNNNNNNNNNNCNNNNNNNNNNNNNNCNMNMNMMNOOCNCNNOOONOMNNNNNNNNNNNNNNNNNNNNNNONOOCMNMNONCOONNNNNONCOCMNNNCNNNNNNNNNNNNNNCCNNNNNNNNNNNNNN
 [...]
+var searchIndex = new 
Map(JSON.parse('[["iceberg",{"t":"PPPPPPPPPRKKPPPPPPFGPPPFFFPFPPPPPPPPPPPPPPIPPPPPPPPPPPPFFFPGGPPPPFGNNNNNNNNNNNNNNNCNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNCNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNMNOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNMNQNNNNNNNNNNNNNNNNNNNNCNNNNNNNNNNNNNNNNNNONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNNNNNNNNNNCNNNNNNNNNNNNNNCNMNMNMMNOOCNCNNOOONOMNNNNNNNNNNNNNNNNNNNNNNONOOCMNMNONCOONNNNNONCOCMNNNCNNNNNNNNNNNNNNCCNNNNNNNNNNNNNN
 [...]
 if (typeof exports !== 'undefined') exports.searchIndex = searchIndex;
 else if (window.initSearch) window.initSearch(searchIndex);
-//{"start":39,"fragment_lengths":[168675,1613,3561,3754,1767,14201,3455,4231,8572,1325,2013,3213,1093]}
\ No newline at end of file
+//{"start":39,"fragment_lengths":[168675,1613,3561,3754,1767,14201,3455,4231,8572,1325,2013,3541,1093]}
\ No newline at end of file
diff --git 
a/api/search.desc/iceberg_sqllogictest/iceberg_sqllogictest-desc-0-.js 
b/api/search.desc/iceberg_sqllogictest/iceberg_sqllogictest-desc-0-.js
index 146aab1a3..6ac04ff9b 100644
--- a/api/search.desc/iceberg_sqllogictest/iceberg_sqllogictest-desc-0-.js
+++ b/api/search.desc/iceberg_sqllogictest/iceberg_sqllogictest-desc-0-.js
@@ -1 +1 @@
-searchState.loadedDescShard("iceberg_sqllogictest", 0, "Contains the error 
value\nContains the success value\nReturns the argument unchanged.\nCalls 
<code>U::from(self)</code>.\n<code>ToString::to_string</code>, but without 
panic on OOM.\nReturns the argument unchanged.\nReturns the argument 
unchanged.\nCalls <code>U::from(self)</code>.\nCalls 
<code>U::from(self)</code>.")
\ No newline at end of file
+searchState.loadedDescShard("iceberg_sqllogictest", 0, "Contains the error 
value\nContains the success value\nReturns the argument unchanged.\nCalls 
<code>U::from(self)</code>.\n<code>ToString::to_string</code>, but without 
panic on OOM.\nRaw configuration parsed from the schedule TOML file\nEngine 
name to engine configuration\nReturns the argument unchanged.\nReturns the 
argument unchanged.\nReturns the argument unchanged.\nCalls 
<code>U::from(self)</code>.\nCalls <code>U::from(self)</c [...]
\ No newline at end of file
diff --git a/api/src/iceberg_sqllogictest/engine/datafusion.rs.html 
b/api/src/iceberg_sqllogictest/engine/datafusion.rs.html
index 3db50a7eb..6992a74eb 100644
--- a/api/src/iceberg_sqllogictest/engine/datafusion.rs.html
+++ b/api/src/iceberg_sqllogictest/engine/datafusion.rs.html
@@ -27,134 +27,138 @@
 <a href=#27 id=27 data-nosnippet>27</a><span class="kw">use 
</span>iceberg::{Catalog, CatalogBuilder, NamespaceIdent, TableCreation};
 <a href=#28 id=28 data-nosnippet>28</a><span class="kw">use 
</span>iceberg_datafusion::IcebergCatalogProvider;
 <a href=#29 id=29 data-nosnippet>29</a><span class="kw">use 
</span>indicatif::ProgressBar;
-<a href=#30 id=30 data-nosnippet>30</a><span class="kw">use </span>toml::Table 
<span class="kw">as </span>TomlTable;
-<a href=#31 id=31 data-nosnippet>31</a>
-<a href=#32 id=32 data-nosnippet>32</a><span class="kw">use </span><span 
class="kw">crate</span>::engine::{EngineRunner, run_slt_with_runner};
-<a href=#33 id=33 data-nosnippet>33</a><span class="kw">use </span><span 
class="kw">crate</span>::error::Result;
-<a href=#34 id=34 data-nosnippet>34</a>
-<a href=#35 id=35 data-nosnippet>35</a><span class="kw">pub struct 
</span>DataFusionEngine {
-<a href=#36 id=36 data-nosnippet>36</a>    test_data_path: PathBuf,
-<a href=#37 id=37 data-nosnippet>37</a>    session_context: SessionContext,
-<a href=#38 id=38 data-nosnippet>38</a>}
-<a href=#39 id=39 data-nosnippet>39</a>
-<a href=#40 id=40 data-nosnippet>40</a><span 
class="attr">#[async_trait::async_trait]
-<a href=#41 id=41 data-nosnippet>41</a></span><span class="kw">impl 
</span>EngineRunner <span class="kw">for </span>DataFusionEngine {
-<a href=#42 id=42 data-nosnippet>42</a>    <span class="kw">async fn 
</span>run_slt_file(<span class="kw-2">&amp;mut </span><span 
class="self">self</span>, path: <span class="kw-2">&amp;</span>Path) -&gt; 
<span class="prelude-ty">Result</span>&lt;()&gt; {
-<a href=#43 id=43 data-nosnippet>43</a>        <span class="kw">let </span>ctx 
= <span class="self">self</span>.session_context.clone();
-<a href=#44 id=44 data-nosnippet>44</a>        <span class="kw">let 
</span>testdata = <span class="self">self</span>.test_data_path.clone();
-<a href=#45 id=45 data-nosnippet>45</a>
-<a href=#46 id=46 data-nosnippet>46</a>        <span class="kw">let 
</span>runner = sqllogictest::Runner::new({
-<a href=#47 id=47 data-nosnippet>47</a>            <span class="kw">move 
</span>|| {
-<a href=#48 id=48 data-nosnippet>48</a>                <span class="kw">let 
</span>ctx = ctx.clone();
-<a href=#49 id=49 data-nosnippet>49</a>                <span class="kw">let 
</span>testdata = testdata.clone();
-<a href=#50 id=50 data-nosnippet>50</a>                <span class="kw">async 
move </span>{
-<a href=#51 id=51 data-nosnippet>51</a>                    <span 
class="comment">// Everything here is owned; no `self` capture.
-<a href=#52 id=52 data-nosnippet>52</a>                    </span><span 
class="prelude-val">Ok</span>(DataFusion::new(ctx, testdata, 
ProgressBar::new(<span class="number">100</span>)))
-<a href=#53 id=53 data-nosnippet>53</a>                }
-<a href=#54 id=54 data-nosnippet>54</a>            }
-<a href=#55 id=55 data-nosnippet>55</a>        });
-<a href=#56 id=56 data-nosnippet>56</a>
-<a href=#57 id=57 data-nosnippet>57</a>        run_slt_with_runner(runner, 
path).<span class="kw">await
-<a href=#58 id=58 data-nosnippet>58</a>    </span>}
-<a href=#59 id=59 data-nosnippet>59</a>}
-<a href=#60 id=60 data-nosnippet>60</a>
-<a href=#61 id=61 data-nosnippet>61</a><span class="kw">impl 
</span>DataFusionEngine {
-<a href=#62 id=62 data-nosnippet>62</a>    <span class="kw">pub async fn 
</span>new(config: TomlTable) -&gt; <span 
class="prelude-ty">Result</span>&lt;<span class="self">Self</span>&gt; {
-<a href=#63 id=63 data-nosnippet>63</a>        <span class="kw">let 
</span>session_config = SessionConfig::new()
-<a href=#64 id=64 data-nosnippet>64</a>            
.with_target_partitions(<span class="number">4</span>)
-<a href=#65 id=65 data-nosnippet>65</a>            
.with_information_schema(<span class="bool-val">true</span>);
-<a href=#66 id=66 data-nosnippet>66</a>        <span class="kw">let </span>ctx 
= SessionContext::new_with_config(session_config);
-<a href=#67 id=67 data-nosnippet>67</a>        ctx.register_catalog(<span 
class="string">"default"</span>, <span 
class="self">Self</span>::create_catalog(<span 
class="kw-2">&amp;</span>config).<span class="kw">await</span><span 
class="question-mark">?</span>);
-<a href=#68 id=68 data-nosnippet>68</a>
-<a href=#69 id=69 data-nosnippet>69</a>        <span 
class="prelude-val">Ok</span>(<span class="self">Self </span>{
-<a href=#70 id=70 data-nosnippet>70</a>            test_data_path: 
PathBuf::from(<span class="string">"testdata"</span>),
-<a href=#71 id=71 data-nosnippet>71</a>            session_context: ctx,
-<a href=#72 id=72 data-nosnippet>72</a>        })
-<a href=#73 id=73 data-nosnippet>73</a>    }
-<a href=#74 id=74 data-nosnippet>74</a>
-<a href=#75 id=75 data-nosnippet>75</a>    <span class="kw">async fn 
</span>create_catalog(<span class="kw">_</span>: <span 
class="kw-2">&amp;</span>TomlTable) -&gt; anyhow::Result&lt;Arc&lt;<span 
class="kw">dyn </span>CatalogProvider&gt;&gt; {
-<a href=#76 id=76 data-nosnippet>76</a>        <span class="comment">// TODO: 
support dynamic catalog configuration
-<a href=#77 id=77 data-nosnippet>77</a>        //  See: 
https://github.com/apache/iceberg-rust/issues/1780
-<a href=#78 id=78 data-nosnippet>78</a>        </span><span class="kw">let 
</span>catalog = MemoryCatalogBuilder::default()
-<a href=#79 id=79 data-nosnippet>79</a>            .load(
-<a href=#80 id=80 data-nosnippet>80</a>                <span 
class="string">"memory"</span>,
-<a href=#81 id=81 data-nosnippet>81</a>                HashMap::from([(
-<a href=#82 id=82 data-nosnippet>82</a>                    
MEMORY_CATALOG_WAREHOUSE.to_string(),
-<a href=#83 id=83 data-nosnippet>83</a>                    <span 
class="string">"memory://"</span>.to_string(),
-<a href=#84 id=84 data-nosnippet>84</a>                )]),
-<a href=#85 id=85 data-nosnippet>85</a>            )
-<a href=#86 id=86 data-nosnippet>86</a>            .<span 
class="kw">await</span><span class="question-mark">?</span>;
-<a href=#87 id=87 data-nosnippet>87</a>
-<a href=#88 id=88 data-nosnippet>88</a>        <span class="comment">// Create 
a test namespace for INSERT INTO tests
-<a href=#89 id=89 data-nosnippet>89</a>        </span><span class="kw">let 
</span>namespace = NamespaceIdent::new(<span 
class="string">"default"</span>.to_string());
-<a href=#90 id=90 data-nosnippet>90</a>        catalog.create_namespace(<span 
class="kw-2">&amp;</span>namespace, HashMap::new()).<span 
class="kw">await</span><span class="question-mark">?</span>;
+<a href=#30 id=30 data-nosnippet>30</a>
+<a href=#31 id=31 data-nosnippet>31</a><span class="kw">use </span><span 
class="kw">crate</span>::engine::{DatafusionCatalogConfig, EngineRunner, 
run_slt_with_runner};
+<a href=#32 id=32 data-nosnippet>32</a><span class="kw">use </span><span 
class="kw">crate</span>::error::Result;
+<a href=#33 id=33 data-nosnippet>33</a>
+<a href=#34 id=34 data-nosnippet>34</a><span class="kw">pub struct 
</span>DataFusionEngine {
+<a href=#35 id=35 data-nosnippet>35</a>    test_data_path: PathBuf,
+<a href=#36 id=36 data-nosnippet>36</a>    session_context: SessionContext,
+<a href=#37 id=37 data-nosnippet>37</a>}
+<a href=#38 id=38 data-nosnippet>38</a>
+<a href=#39 id=39 data-nosnippet>39</a><span 
class="attr">#[async_trait::async_trait]
+<a href=#40 id=40 data-nosnippet>40</a></span><span class="kw">impl 
</span>EngineRunner <span class="kw">for </span>DataFusionEngine {
+<a href=#41 id=41 data-nosnippet>41</a>    <span class="kw">async fn 
</span>run_slt_file(<span class="kw-2">&amp;mut </span><span 
class="self">self</span>, path: <span class="kw-2">&amp;</span>Path) -&gt; 
<span class="prelude-ty">Result</span>&lt;()&gt; {
+<a href=#42 id=42 data-nosnippet>42</a>        <span class="kw">let </span>ctx 
= <span class="self">self</span>.session_context.clone();
+<a href=#43 id=43 data-nosnippet>43</a>        <span class="kw">let 
</span>testdata = <span class="self">self</span>.test_data_path.clone();
+<a href=#44 id=44 data-nosnippet>44</a>
+<a href=#45 id=45 data-nosnippet>45</a>        <span class="kw">let 
</span>runner = sqllogictest::Runner::new({
+<a href=#46 id=46 data-nosnippet>46</a>            <span class="kw">move 
</span>|| {
+<a href=#47 id=47 data-nosnippet>47</a>                <span class="kw">let 
</span>ctx = ctx.clone();
+<a href=#48 id=48 data-nosnippet>48</a>                <span class="kw">let 
</span>testdata = testdata.clone();
+<a href=#49 id=49 data-nosnippet>49</a>                <span class="kw">async 
move </span>{
+<a href=#50 id=50 data-nosnippet>50</a>                    <span 
class="comment">// Everything here is owned; no `self` capture.
+<a href=#51 id=51 data-nosnippet>51</a>                    </span><span 
class="prelude-val">Ok</span>(DataFusion::new(ctx, testdata, 
ProgressBar::new(<span class="number">100</span>)))
+<a href=#52 id=52 data-nosnippet>52</a>                }
+<a href=#53 id=53 data-nosnippet>53</a>            }
+<a href=#54 id=54 data-nosnippet>54</a>        });
+<a href=#55 id=55 data-nosnippet>55</a>
+<a href=#56 id=56 data-nosnippet>56</a>        run_slt_with_runner(runner, 
path).<span class="kw">await
+<a href=#57 id=57 data-nosnippet>57</a>    </span>}
+<a href=#58 id=58 data-nosnippet>58</a>}
+<a href=#59 id=59 data-nosnippet>59</a>
+<a href=#60 id=60 data-nosnippet>60</a><span class="kw">impl 
</span>DataFusionEngine {
+<a href=#61 id=61 data-nosnippet>61</a>    <span class="kw">pub async fn 
</span>new(catalog_config: <span 
class="prelude-ty">Option</span>&lt;DatafusionCatalogConfig&gt;) -&gt; <span 
class="prelude-ty">Result</span>&lt;<span class="self">Self</span>&gt; {
+<a href=#62 id=62 data-nosnippet>62</a>        <span class="kw">let 
</span>session_config = SessionConfig::new()
+<a href=#63 id=63 data-nosnippet>63</a>            
.with_target_partitions(<span class="number">4</span>)
+<a href=#64 id=64 data-nosnippet>64</a>            
.with_information_schema(<span class="bool-val">true</span>);
+<a href=#65 id=65 data-nosnippet>65</a>        <span class="kw">let </span>ctx 
= SessionContext::new_with_config(session_config);
+<a href=#66 id=66 data-nosnippet>66</a>        ctx.register_catalog(
+<a href=#67 id=67 data-nosnippet>67</a>            <span 
class="string">"default"</span>,
+<a href=#68 id=68 data-nosnippet>68</a>            <span 
class="self">Self</span>::create_catalog(catalog_config.as_ref()).<span 
class="kw">await</span><span class="question-mark">?</span>,
+<a href=#69 id=69 data-nosnippet>69</a>        );
+<a href=#70 id=70 data-nosnippet>70</a>
+<a href=#71 id=71 data-nosnippet>71</a>        <span 
class="prelude-val">Ok</span>(<span class="self">Self </span>{
+<a href=#72 id=72 data-nosnippet>72</a>            test_data_path: 
PathBuf::from(<span class="string">"testdata"</span>),
+<a href=#73 id=73 data-nosnippet>73</a>            session_context: ctx,
+<a href=#74 id=74 data-nosnippet>74</a>        })
+<a href=#75 id=75 data-nosnippet>75</a>    }
+<a href=#76 id=76 data-nosnippet>76</a>
+<a href=#77 id=77 data-nosnippet>77</a>    <span class="kw">async fn 
</span>create_catalog(
+<a href=#78 id=78 data-nosnippet>78</a>        _catalog_config: <span 
class="prelude-ty">Option</span>&lt;<span 
class="kw-2">&amp;</span>DatafusionCatalogConfig&gt;,
+<a href=#79 id=79 data-nosnippet>79</a>    ) -&gt; 
anyhow::Result&lt;Arc&lt;<span class="kw">dyn </span>CatalogProvider&gt;&gt; {
+<a href=#80 id=80 data-nosnippet>80</a>        <span class="comment">// TODO: 
Use catalog_config to load different catalog types via iceberg-catalog-loader
+<a href=#81 id=81 data-nosnippet>81</a>        // See: 
https://github.com/apache/iceberg-rust/issues/1780
+<a href=#82 id=82 data-nosnippet>82</a>        </span><span class="kw">let 
</span>catalog = MemoryCatalogBuilder::default()
+<a href=#83 id=83 data-nosnippet>83</a>            .load(
+<a href=#84 id=84 data-nosnippet>84</a>                <span 
class="string">"memory"</span>,
+<a href=#85 id=85 data-nosnippet>85</a>                HashMap::from([(
+<a href=#86 id=86 data-nosnippet>86</a>                    
MEMORY_CATALOG_WAREHOUSE.to_string(),
+<a href=#87 id=87 data-nosnippet>87</a>                    <span 
class="string">"memory://"</span>.to_string(),
+<a href=#88 id=88 data-nosnippet>88</a>                )]),
+<a href=#89 id=89 data-nosnippet>89</a>            )
+<a href=#90 id=90 data-nosnippet>90</a>            .<span 
class="kw">await</span><span class="question-mark">?</span>;
 <a href=#91 id=91 data-nosnippet>91</a>
-<a href=#92 id=92 data-nosnippet>92</a>        <span class="comment">// Create 
test tables
-<a href=#93 id=93 data-nosnippet>93</a>        </span><span 
class="self">Self</span>::create_unpartitioned_table(<span 
class="kw-2">&amp;</span>catalog, <span 
class="kw-2">&amp;</span>namespace).<span class="kw">await</span><span 
class="question-mark">?</span>;
-<a href=#94 id=94 data-nosnippet>94</a>        <span 
class="self">Self</span>::create_partitioned_table(<span 
class="kw-2">&amp;</span>catalog, <span 
class="kw-2">&amp;</span>namespace).<span class="kw">await</span><span 
class="question-mark">?</span>;
+<a href=#92 id=92 data-nosnippet>92</a>        <span class="comment">// Create 
a test namespace for INSERT INTO tests
+<a href=#93 id=93 data-nosnippet>93</a>        </span><span class="kw">let 
</span>namespace = NamespaceIdent::new(<span 
class="string">"default"</span>.to_string());
+<a href=#94 id=94 data-nosnippet>94</a>        catalog.create_namespace(<span 
class="kw-2">&amp;</span>namespace, HashMap::new()).<span 
class="kw">await</span><span class="question-mark">?</span>;
 <a href=#95 id=95 data-nosnippet>95</a>
-<a href=#96 id=96 data-nosnippet>96</a>        <span 
class="prelude-val">Ok</span>(Arc::new(
-<a href=#97 id=97 data-nosnippet>97</a>            
IcebergCatalogProvider::try_new(Arc::new(catalog)).<span 
class="kw">await</span><span class="question-mark">?</span>,
-<a href=#98 id=98 data-nosnippet>98</a>        ))
-<a href=#99 id=99 data-nosnippet>99</a>    }
-<a href=#100 id=100 data-nosnippet>100</a>
-<a href=#101 id=101 data-nosnippet>101</a>    <span class="doccomment">/// 
Create an unpartitioned test table with id and name columns
-<a href=#102 id=102 data-nosnippet>102</a>    /// TODO: this can be removed 
when we support CREATE TABLE
-<a href=#103 id=103 data-nosnippet>103</a>    </span><span class="kw">async fn 
</span>create_unpartitioned_table(
-<a href=#104 id=104 data-nosnippet>104</a>        catalog: <span 
class="kw-2">&amp;</span><span class="kw">impl </span>Catalog,
-<a href=#105 id=105 data-nosnippet>105</a>        namespace: <span 
class="kw-2">&amp;</span>NamespaceIdent,
-<a href=#106 id=106 data-nosnippet>106</a>    ) -&gt; anyhow::Result&lt;()&gt; 
{
-<a href=#107 id=107 data-nosnippet>107</a>        <span class="kw">let 
</span>schema = Schema::builder()
-<a href=#108 id=108 data-nosnippet>108</a>            .with_fields(<span 
class="macro">vec!</span>[
-<a href=#109 id=109 data-nosnippet>109</a>                
NestedField::required(<span class="number">1</span>, <span 
class="string">"id"</span>, Type::Primitive(PrimitiveType::Int)).into(),
-<a href=#110 id=110 data-nosnippet>110</a>                
NestedField::optional(<span class="number">2</span>, <span 
class="string">"name"</span>, Type::Primitive(PrimitiveType::String)).into(),
-<a href=#111 id=111 data-nosnippet>111</a>            ])
-<a href=#112 id=112 data-nosnippet>112</a>            .build()<span 
class="question-mark">?</span>;
-<a href=#113 id=113 data-nosnippet>113</a>
-<a href=#114 id=114 data-nosnippet>114</a>        catalog
-<a href=#115 id=115 data-nosnippet>115</a>            .create_table(
-<a href=#116 id=116 data-nosnippet>116</a>                namespace,
-<a href=#117 id=117 data-nosnippet>117</a>                
TableCreation::builder()
-<a href=#118 id=118 data-nosnippet>118</a>                    .name(<span 
class="string">"test_unpartitioned_table"</span>.to_string())
-<a href=#119 id=119 data-nosnippet>119</a>                    .schema(schema)
-<a href=#120 id=120 data-nosnippet>120</a>                    .build(),
-<a href=#121 id=121 data-nosnippet>121</a>            )
-<a href=#122 id=122 data-nosnippet>122</a>            .<span 
class="kw">await</span><span class="question-mark">?</span>;
-<a href=#123 id=123 data-nosnippet>123</a>
-<a href=#124 id=124 data-nosnippet>124</a>        <span 
class="prelude-val">Ok</span>(())
-<a href=#125 id=125 data-nosnippet>125</a>    }
-<a href=#126 id=126 data-nosnippet>126</a>
-<a href=#127 id=127 data-nosnippet>127</a>    <span class="doccomment">/// 
Create a partitioned test table with id, category, and value columns
-<a href=#128 id=128 data-nosnippet>128</a>    /// Partitioned by category 
using identity transform
-<a href=#129 id=129 data-nosnippet>129</a>    /// TODO: this can be removed 
when we support CREATE TABLE
-<a href=#130 id=130 data-nosnippet>130</a>    </span><span class="kw">async fn 
</span>create_partitioned_table(
-<a href=#131 id=131 data-nosnippet>131</a>        catalog: <span 
class="kw-2">&amp;</span><span class="kw">impl </span>Catalog,
-<a href=#132 id=132 data-nosnippet>132</a>        namespace: <span 
class="kw-2">&amp;</span>NamespaceIdent,
-<a href=#133 id=133 data-nosnippet>133</a>    ) -&gt; anyhow::Result&lt;()&gt; 
{
-<a href=#134 id=134 data-nosnippet>134</a>        <span class="kw">let 
</span>schema = Schema::builder()
-<a href=#135 id=135 data-nosnippet>135</a>            .with_fields(<span 
class="macro">vec!</span>[
-<a href=#136 id=136 data-nosnippet>136</a>                
NestedField::required(<span class="number">1</span>, <span 
class="string">"id"</span>, Type::Primitive(PrimitiveType::Int)).into(),
-<a href=#137 id=137 data-nosnippet>137</a>                
NestedField::required(<span class="number">2</span>, <span 
class="string">"category"</span>, 
Type::Primitive(PrimitiveType::String)).into(),
-<a href=#138 id=138 data-nosnippet>138</a>                
NestedField::optional(<span class="number">3</span>, <span 
class="string">"value"</span>, Type::Primitive(PrimitiveType::String)).into(),
-<a href=#139 id=139 data-nosnippet>139</a>            ])
-<a href=#140 id=140 data-nosnippet>140</a>            .build()<span 
class="question-mark">?</span>;
-<a href=#141 id=141 data-nosnippet>141</a>
-<a href=#142 id=142 data-nosnippet>142</a>        <span class="kw">let 
</span>partition_spec = UnboundPartitionSpec::builder()
-<a href=#143 id=143 data-nosnippet>143</a>            .with_spec_id(<span 
class="number">0</span>)
-<a href=#144 id=144 data-nosnippet>144</a>            
.add_partition_field(<span class="number">2</span>, <span 
class="string">"category"</span>, Transform::Identity)<span 
class="question-mark">?
-<a href=#145 id=145 data-nosnippet>145</a>            </span>.build();
-<a href=#146 id=146 data-nosnippet>146</a>
-<a href=#147 id=147 data-nosnippet>147</a>        catalog
-<a href=#148 id=148 data-nosnippet>148</a>            .create_table(
-<a href=#149 id=149 data-nosnippet>149</a>                namespace,
-<a href=#150 id=150 data-nosnippet>150</a>                
TableCreation::builder()
-<a href=#151 id=151 data-nosnippet>151</a>                    .name(<span 
class="string">"test_partitioned_table"</span>.to_string())
-<a href=#152 id=152 data-nosnippet>152</a>                    .schema(schema)
-<a href=#153 id=153 data-nosnippet>153</a>                    
.partition_spec(partition_spec)
-<a href=#154 id=154 data-nosnippet>154</a>                    .build(),
-<a href=#155 id=155 data-nosnippet>155</a>            )
-<a href=#156 id=156 data-nosnippet>156</a>            .<span 
class="kw">await</span><span class="question-mark">?</span>;
-<a href=#157 id=157 data-nosnippet>157</a>
-<a href=#158 id=158 data-nosnippet>158</a>        <span 
class="prelude-val">Ok</span>(())
-<a href=#159 id=159 data-nosnippet>159</a>    }
-<a href=#160 id=160 
data-nosnippet>160</a>}</code></pre></div></section></main></body></html>
\ No newline at end of file
+<a href=#96 id=96 data-nosnippet>96</a>        <span class="comment">// Create 
test tables
+<a href=#97 id=97 data-nosnippet>97</a>        </span><span 
class="self">Self</span>::create_unpartitioned_table(<span 
class="kw-2">&amp;</span>catalog, <span 
class="kw-2">&amp;</span>namespace).<span class="kw">await</span><span 
class="question-mark">?</span>;
+<a href=#98 id=98 data-nosnippet>98</a>        <span 
class="self">Self</span>::create_partitioned_table(<span 
class="kw-2">&amp;</span>catalog, <span 
class="kw-2">&amp;</span>namespace).<span class="kw">await</span><span 
class="question-mark">?</span>;
+<a href=#99 id=99 data-nosnippet>99</a>
+<a href=#100 id=100 data-nosnippet>100</a>        <span 
class="prelude-val">Ok</span>(Arc::new(
+<a href=#101 id=101 data-nosnippet>101</a>            
IcebergCatalogProvider::try_new(Arc::new(catalog)).<span 
class="kw">await</span><span class="question-mark">?</span>,
+<a href=#102 id=102 data-nosnippet>102</a>        ))
+<a href=#103 id=103 data-nosnippet>103</a>    }
+<a href=#104 id=104 data-nosnippet>104</a>
+<a href=#105 id=105 data-nosnippet>105</a>    <span class="doccomment">/// 
Create an unpartitioned test table with id and name columns
+<a href=#106 id=106 data-nosnippet>106</a>    /// TODO: this can be removed 
when we support CREATE TABLE
+<a href=#107 id=107 data-nosnippet>107</a>    </span><span class="kw">async fn 
</span>create_unpartitioned_table(
+<a href=#108 id=108 data-nosnippet>108</a>        catalog: <span 
class="kw-2">&amp;</span><span class="kw">impl </span>Catalog,
+<a href=#109 id=109 data-nosnippet>109</a>        namespace: <span 
class="kw-2">&amp;</span>NamespaceIdent,
+<a href=#110 id=110 data-nosnippet>110</a>    ) -&gt; anyhow::Result&lt;()&gt; 
{
+<a href=#111 id=111 data-nosnippet>111</a>        <span class="kw">let 
</span>schema = Schema::builder()
+<a href=#112 id=112 data-nosnippet>112</a>            .with_fields(<span 
class="macro">vec!</span>[
+<a href=#113 id=113 data-nosnippet>113</a>                
NestedField::required(<span class="number">1</span>, <span 
class="string">"id"</span>, Type::Primitive(PrimitiveType::Int)).into(),
+<a href=#114 id=114 data-nosnippet>114</a>                
NestedField::optional(<span class="number">2</span>, <span 
class="string">"name"</span>, Type::Primitive(PrimitiveType::String)).into(),
+<a href=#115 id=115 data-nosnippet>115</a>            ])
+<a href=#116 id=116 data-nosnippet>116</a>            .build()<span 
class="question-mark">?</span>;
+<a href=#117 id=117 data-nosnippet>117</a>
+<a href=#118 id=118 data-nosnippet>118</a>        catalog
+<a href=#119 id=119 data-nosnippet>119</a>            .create_table(
+<a href=#120 id=120 data-nosnippet>120</a>                namespace,
+<a href=#121 id=121 data-nosnippet>121</a>                
TableCreation::builder()
+<a href=#122 id=122 data-nosnippet>122</a>                    .name(<span 
class="string">"test_unpartitioned_table"</span>.to_string())
+<a href=#123 id=123 data-nosnippet>123</a>                    .schema(schema)
+<a href=#124 id=124 data-nosnippet>124</a>                    .build(),
+<a href=#125 id=125 data-nosnippet>125</a>            )
+<a href=#126 id=126 data-nosnippet>126</a>            .<span 
class="kw">await</span><span class="question-mark">?</span>;
+<a href=#127 id=127 data-nosnippet>127</a>
+<a href=#128 id=128 data-nosnippet>128</a>        <span 
class="prelude-val">Ok</span>(())
+<a href=#129 id=129 data-nosnippet>129</a>    }
+<a href=#130 id=130 data-nosnippet>130</a>
+<a href=#131 id=131 data-nosnippet>131</a>    <span class="doccomment">/// 
Create a partitioned test table with id, category, and value columns
+<a href=#132 id=132 data-nosnippet>132</a>    /// Partitioned by category 
using identity transform
+<a href=#133 id=133 data-nosnippet>133</a>    /// TODO: this can be removed 
when we support CREATE TABLE
+<a href=#134 id=134 data-nosnippet>134</a>    </span><span class="kw">async fn 
</span>create_partitioned_table(
+<a href=#135 id=135 data-nosnippet>135</a>        catalog: <span 
class="kw-2">&amp;</span><span class="kw">impl </span>Catalog,
+<a href=#136 id=136 data-nosnippet>136</a>        namespace: <span 
class="kw-2">&amp;</span>NamespaceIdent,
+<a href=#137 id=137 data-nosnippet>137</a>    ) -&gt; anyhow::Result&lt;()&gt; 
{
+<a href=#138 id=138 data-nosnippet>138</a>        <span class="kw">let 
</span>schema = Schema::builder()
+<a href=#139 id=139 data-nosnippet>139</a>            .with_fields(<span 
class="macro">vec!</span>[
+<a href=#140 id=140 data-nosnippet>140</a>                
NestedField::required(<span class="number">1</span>, <span 
class="string">"id"</span>, Type::Primitive(PrimitiveType::Int)).into(),
+<a href=#141 id=141 data-nosnippet>141</a>                
NestedField::required(<span class="number">2</span>, <span 
class="string">"category"</span>, 
Type::Primitive(PrimitiveType::String)).into(),
+<a href=#142 id=142 data-nosnippet>142</a>                
NestedField::optional(<span class="number">3</span>, <span 
class="string">"value"</span>, Type::Primitive(PrimitiveType::String)).into(),
+<a href=#143 id=143 data-nosnippet>143</a>            ])
+<a href=#144 id=144 data-nosnippet>144</a>            .build()<span 
class="question-mark">?</span>;
+<a href=#145 id=145 data-nosnippet>145</a>
+<a href=#146 id=146 data-nosnippet>146</a>        <span class="kw">let 
</span>partition_spec = UnboundPartitionSpec::builder()
+<a href=#147 id=147 data-nosnippet>147</a>            .with_spec_id(<span 
class="number">0</span>)
+<a href=#148 id=148 data-nosnippet>148</a>            
.add_partition_field(<span class="number">2</span>, <span 
class="string">"category"</span>, Transform::Identity)<span 
class="question-mark">?
+<a href=#149 id=149 data-nosnippet>149</a>            </span>.build();
+<a href=#150 id=150 data-nosnippet>150</a>
+<a href=#151 id=151 data-nosnippet>151</a>        catalog
+<a href=#152 id=152 data-nosnippet>152</a>            .create_table(
+<a href=#153 id=153 data-nosnippet>153</a>                namespace,
+<a href=#154 id=154 data-nosnippet>154</a>                
TableCreation::builder()
+<a href=#155 id=155 data-nosnippet>155</a>                    .name(<span 
class="string">"test_partitioned_table"</span>.to_string())
+<a href=#156 id=156 data-nosnippet>156</a>                    .schema(schema)
+<a href=#157 id=157 data-nosnippet>157</a>                    
.partition_spec(partition_spec)
+<a href=#158 id=158 data-nosnippet>158</a>                    .build(),
+<a href=#159 id=159 data-nosnippet>159</a>            )
+<a href=#160 id=160 data-nosnippet>160</a>            .<span 
class="kw">await</span><span class="question-mark">?</span>;
+<a href=#161 id=161 data-nosnippet>161</a>
+<a href=#162 id=162 data-nosnippet>162</a>        <span 
class="prelude-val">Ok</span>(())
+<a href=#163 id=163 data-nosnippet>163</a>    }
+<a href=#164 id=164 
data-nosnippet>164</a>}</code></pre></div></section></main></body></html>
\ No newline at end of file
diff --git a/api/src/iceberg_sqllogictest/engine/mod.rs.html 
b/api/src/iceberg_sqllogictest/engine/mod.rs.html
index f042f64d4..a375c5b28 100644
--- a/api/src/iceberg_sqllogictest/engine/mod.rs.html
+++ b/api/src/iceberg_sqllogictest/engine/mod.rs.html
@@ -1,4 +1,4 @@
-<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta 
name="viewport" content="width=device-width, initial-scale=1.0"><meta 
name="generator" content="rustdoc"><meta name="description" content="Source of 
the Rust file `crates/sqllogictest/src/engine/mod.rs`."><title>mod.rs - 
source</title><script>if(window.location.protocol!=="file:")document.head.insertAdjacentHTML("beforeend","SourceSerif4-Regular-6b053e98.ttf.woff2,FiraSans-Italic-81dc35de.woff2,FiraSans-Regular-0fe48ade.wof
 [...]
+<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta 
name="viewport" content="width=device-width, initial-scale=1.0"><meta 
name="generator" content="rustdoc"><meta name="description" content="Source of 
the Rust file `crates/sqllogictest/src/engine/mod.rs`."><title>mod.rs - 
source</title><script>if(window.location.protocol!=="file:")document.head.insertAdjacentHTML("beforeend","SourceSerif4-Regular-6b053e98.ttf.woff2,FiraSans-Italic-81dc35de.woff2,FiraSans-Regular-0fe48ade.wof
 [...]
 <a href=#2 id=2 data-nosnippet>2</a>// or more contributor license agreements. 
 See the NOTICE file
 <a href=#3 id=3 data-nosnippet>3</a>// distributed with this work for 
additional information
 <a href=#4 id=4 data-nosnippet>4</a>// regarding copyright ownership.  The ASF 
licenses this file
@@ -17,77 +17,127 @@
 <a href=#17 id=17 data-nosnippet>17</a>
 <a href=#18 id=18 data-nosnippet>18</a></span><span class="kw">mod 
</span>datafusion;
 <a href=#19 id=19 data-nosnippet>19</a>
-<a href=#20 id=20 data-nosnippet>20</a><span class="kw">use 
</span>std::path::Path;
-<a href=#21 id=21 data-nosnippet>21</a>
-<a href=#22 id=22 data-nosnippet>22</a><span class="kw">use 
</span>anyhow::anyhow;
-<a href=#23 id=23 data-nosnippet>23</a><span class="kw">use 
</span>sqllogictest::{AsyncDB, MakeConnection, Runner, parse_file};
-<a href=#24 id=24 data-nosnippet>24</a><span class="kw">use </span>toml::Table 
<span class="kw">as </span>TomlTable;
-<a href=#25 id=25 data-nosnippet>25</a>
-<a href=#26 id=26 data-nosnippet>26</a><span class="kw">use </span><span 
class="kw">crate</span>::engine::datafusion::DataFusionEngine;
-<a href=#27 id=27 data-nosnippet>27</a><span class="kw">use </span><span 
class="kw">crate</span>::error::{Error, <span class="prelude-ty">Result</span>};
-<a href=#28 id=28 data-nosnippet>28</a>
-<a href=#29 id=29 data-nosnippet>29</a><span class="kw">const 
</span>TYPE_DATAFUSION: <span class="kw-2">&amp;</span>str = <span 
class="string">"datafusion"</span>;
-<a href=#30 id=30 data-nosnippet>30</a>
-<a href=#31 id=31 data-nosnippet>31</a><span 
class="attr">#[async_trait::async_trait]
-<a href=#32 id=32 data-nosnippet>32</a></span><span class="kw">pub trait 
</span>EngineRunner: Send {
-<a href=#33 id=33 data-nosnippet>33</a>    <span class="kw">async fn 
</span>run_slt_file(<span class="kw-2">&amp;mut </span><span 
class="self">self</span>, path: <span class="kw-2">&amp;</span>Path) -&gt; 
<span class="prelude-ty">Result</span>&lt;()&gt;;
-<a href=#34 id=34 data-nosnippet>34</a>}
-<a href=#35 id=35 data-nosnippet>35</a>
-<a href=#36 id=36 data-nosnippet>36</a><span class="kw">pub async fn 
</span>load_engine_runner(
-<a href=#37 id=37 data-nosnippet>37</a>    engine_type: <span 
class="kw-2">&amp;</span>str,
-<a href=#38 id=38 data-nosnippet>38</a>    cfg: TomlTable,
-<a href=#39 id=39 data-nosnippet>39</a>) -&gt; <span 
class="prelude-ty">Result</span>&lt;Box&lt;<span class="kw">dyn 
</span>EngineRunner&gt;&gt; {
-<a href=#40 id=40 data-nosnippet>40</a>    <span class="kw">match 
</span>engine_type {
-<a href=#41 id=41 data-nosnippet>41</a>        TYPE_DATAFUSION =&gt; <span 
class="prelude-val">Ok</span>(Box::new(DataFusionEngine::new(cfg).<span 
class="kw">await</span><span class="question-mark">?</span>)),
-<a href=#42 id=42 data-nosnippet>42</a>        <span class="kw">_ </span>=&gt; 
<span class="prelude-val">Err</span>(<span 
class="macro">anyhow::anyhow!</span>(<span class="string">"Unsupported engine 
type: {engine_type}"</span>).into()),
-<a href=#43 id=43 data-nosnippet>43</a>    }
-<a href=#44 id=44 data-nosnippet>44</a>}
-<a href=#45 id=45 data-nosnippet>45</a>
-<a href=#46 id=46 data-nosnippet>46</a><span class="kw">pub async fn 
</span>run_slt_with_runner&lt;D, M&gt;(
-<a href=#47 id=47 data-nosnippet>47</a>    <span class="kw-2">mut 
</span>runner: Runner&lt;D, M&gt;,
-<a href=#48 id=48 data-nosnippet>48</a>    step_slt_file: <span 
class="kw">impl </span>AsRef&lt;Path&gt;,
-<a href=#49 id=49 data-nosnippet>49</a>) -&gt; <span 
class="prelude-ty">Result</span>&lt;()&gt;
-<a href=#50 id=50 data-nosnippet>50</a><span class="kw">where
-<a href=#51 id=51 data-nosnippet>51</a>    </span>D: AsyncDB + Send + <span 
class="lifetime">'static</span>,
-<a href=#52 id=52 data-nosnippet>52</a>    M: MakeConnection&lt;Conn = D&gt; + 
Send + <span class="lifetime">'static</span>,
-<a href=#53 id=53 data-nosnippet>53</a>{
-<a href=#54 id=54 data-nosnippet>54</a>    <span class="kw">let </span>path = 
step_slt_file.as_ref().canonicalize()<span class="question-mark">?</span>;
-<a href=#55 id=55 data-nosnippet>55</a>    <span class="kw">let </span>records 
= parse_file(<span class="kw-2">&amp;</span>path).map_err(|e| Error(<span 
class="macro">anyhow!</span>(<span class="string">"parsing slt file failed: 
{e}"</span>)))<span class="question-mark">?</span>;
-<a href=#56 id=56 data-nosnippet>56</a>
-<a href=#57 id=57 data-nosnippet>57</a>    <span class="kw">for </span>record 
<span class="kw">in </span>records {
-<a href=#58 id=58 data-nosnippet>58</a>        <span class="kw">if let 
</span><span class="prelude-val">Err</span>(err) = 
runner.run_async(record).<span class="kw">await </span>{
-<a href=#59 id=59 data-nosnippet>59</a>            <span class="kw">return 
</span><span class="prelude-val">Err</span>(Error(<span 
class="macro">anyhow!</span>(<span class="string">"SLT record execution failed: 
{err}"</span>)));
-<a href=#60 id=60 data-nosnippet>60</a>        }
-<a href=#61 id=61 data-nosnippet>61</a>    }
-<a href=#62 id=62 data-nosnippet>62</a>
-<a href=#63 id=63 data-nosnippet>63</a>    <span 
class="prelude-val">Ok</span>(())
-<a href=#64 id=64 data-nosnippet>64</a>}
-<a href=#65 id=65 data-nosnippet>65</a>
-<a href=#66 id=66 data-nosnippet>66</a><span class="attr">#[cfg(test)]
-<a href=#67 id=67 data-nosnippet>67</a></span><span class="kw">mod 
</span>tests {
-<a href=#68 id=68 data-nosnippet>68</a>    <span class="kw">use </span><span 
class="kw">crate</span>::engine::{TYPE_DATAFUSION, load_engine_runner};
-<a href=#69 id=69 data-nosnippet>69</a>
-<a href=#70 id=70 data-nosnippet>70</a>    <span class="attr">#[tokio::test]
-<a href=#71 id=71 data-nosnippet>71</a>    </span><span class="kw">async fn 
</span>test_engine_invalid_type() {
-<a href=#72 id=72 data-nosnippet>72</a>        <span class="kw">let 
</span>input = <span class="string">r#"
-<a href=#73 id=73 data-nosnippet>73</a>            [engines]
-<a href=#74 id=74 data-nosnippet>74</a>            random = { type = 
"random_engine", url = "http://localhost:8181"; }
-<a href=#75 id=75 data-nosnippet>75</a>        "#</span>;
-<a href=#76 id=76 data-nosnippet>76</a>        <span class="kw">let </span>tbl 
= toml::from_str(input).unwrap();
-<a href=#77 id=77 data-nosnippet>77</a>        <span class="kw">let 
</span>result = load_engine_runner(<span class="string">"random_engine"</span>, 
tbl).<span class="kw">await</span>;
+<a href=#20 id=20 data-nosnippet>20</a><span class="kw">use 
</span>std::collections::HashMap;
+<a href=#21 id=21 data-nosnippet>21</a><span class="kw">use 
</span>std::path::Path;
+<a href=#22 id=22 data-nosnippet>22</a>
+<a href=#23 id=23 data-nosnippet>23</a><span class="kw">use 
</span>anyhow::anyhow;
+<a href=#24 id=24 data-nosnippet>24</a><span class="kw">use 
</span>serde::Deserialize;
+<a href=#25 id=25 data-nosnippet>25</a><span class="kw">use 
</span>sqllogictest::{AsyncDB, MakeConnection, Runner, parse_file};
+<a href=#26 id=26 data-nosnippet>26</a>
+<a href=#27 id=27 data-nosnippet>27</a><span class="kw">use </span><span 
class="kw">crate</span>::engine::datafusion::DataFusionEngine;
+<a href=#28 id=28 data-nosnippet>28</a><span class="kw">use </span><span 
class="kw">crate</span>::error::{Error, <span class="prelude-ty">Result</span>};
+<a href=#29 id=29 data-nosnippet>29</a>
+<a href=#30 id=30 data-nosnippet>30</a><span class="doccomment">/// 
Configuration for the catalog used by the DataFusion engine
+<a href=#31 id=31 data-nosnippet>31</a></span><span 
class="attr">#[derive(Debug, Clone, Deserialize)]
+<a href=#32 id=32 data-nosnippet>32</a></span><span class="kw">pub struct 
</span>DatafusionCatalogConfig {
+<a href=#33 id=33 data-nosnippet>33</a>    <span class="doccomment">/// 
Catalog type: "memory", "rest", "glue", "hms", "s3tables", "sql"
+<a href=#34 id=34 data-nosnippet>34</a>    </span><span 
class="attr">#[serde(rename = <span class="string">"type"</span>)]
+<a href=#35 id=35 data-nosnippet>35</a>    </span><span class="kw">pub 
</span>catalog_type: String,
+<a href=#36 id=36 data-nosnippet>36</a>    <span class="doccomment">/// 
Catalog properties passed to the catalog loader
+<a href=#37 id=37 data-nosnippet>37</a>    </span><span 
class="attr">#[serde(default)]
+<a href=#38 id=38 data-nosnippet>38</a>    </span><span class="kw">pub 
</span>props: HashMap&lt;String, String&gt;,
+<a href=#39 id=39 data-nosnippet>39</a>}
+<a href=#40 id=40 data-nosnippet>40</a>
+<a href=#41 id=41 data-nosnippet>41</a><span class="doccomment">/// Engine 
configuration as a tagged enum
+<a href=#42 id=42 data-nosnippet>42</a></span><span 
class="attr">#[derive(Debug, Clone, Deserialize)]
+<a href=#43 id=43 data-nosnippet>43</a>#[serde(tag = <span 
class="string">"type"</span>, rename_all = <span 
class="string">"lowercase"</span>)]
+<a href=#44 id=44 data-nosnippet>44</a></span><span class="kw">pub enum 
</span>EngineConfig {
+<a href=#45 id=45 data-nosnippet>45</a>    Datafusion {
+<a href=#46 id=46 data-nosnippet>46</a>        <span 
class="attr">#[serde(default)]
+<a href=#47 id=47 data-nosnippet>47</a>        </span>catalog: <span 
class="prelude-ty">Option</span>&lt;DatafusionCatalogConfig&gt;,
+<a href=#48 id=48 data-nosnippet>48</a>    },
+<a href=#49 id=49 data-nosnippet>49</a>}
+<a href=#50 id=50 data-nosnippet>50</a>
+<a href=#51 id=51 data-nosnippet>51</a><span 
class="attr">#[async_trait::async_trait]
+<a href=#52 id=52 data-nosnippet>52</a></span><span class="kw">pub trait 
</span>EngineRunner: Send {
+<a href=#53 id=53 data-nosnippet>53</a>    <span class="kw">async fn 
</span>run_slt_file(<span class="kw-2">&amp;mut </span><span 
class="self">self</span>, path: <span class="kw-2">&amp;</span>Path) -&gt; 
<span class="prelude-ty">Result</span>&lt;()&gt;;
+<a href=#54 id=54 data-nosnippet>54</a>}
+<a href=#55 id=55 data-nosnippet>55</a>
+<a href=#56 id=56 data-nosnippet>56</a><span class="kw">pub async fn 
</span>load_engine_runner(config: EngineConfig) -&gt; <span 
class="prelude-ty">Result</span>&lt;Box&lt;<span class="kw">dyn 
</span>EngineRunner&gt;&gt; {
+<a href=#57 id=57 data-nosnippet>57</a>    <span class="kw">match 
</span>config {
+<a href=#58 id=58 data-nosnippet>58</a>        EngineConfig::Datafusion { 
catalog } =&gt; <span 
class="prelude-val">Ok</span>(Box::new(DataFusionEngine::new(catalog).<span 
class="kw">await</span><span class="question-mark">?</span>)),
+<a href=#59 id=59 data-nosnippet>59</a>    }
+<a href=#60 id=60 data-nosnippet>60</a>}
+<a href=#61 id=61 data-nosnippet>61</a>
+<a href=#62 id=62 data-nosnippet>62</a><span class="kw">pub async fn 
</span>run_slt_with_runner&lt;D, M&gt;(
+<a href=#63 id=63 data-nosnippet>63</a>    <span class="kw-2">mut 
</span>runner: Runner&lt;D, M&gt;,
+<a href=#64 id=64 data-nosnippet>64</a>    step_slt_file: <span 
class="kw">impl </span>AsRef&lt;Path&gt;,
+<a href=#65 id=65 data-nosnippet>65</a>) -&gt; <span 
class="prelude-ty">Result</span>&lt;()&gt;
+<a href=#66 id=66 data-nosnippet>66</a><span class="kw">where
+<a href=#67 id=67 data-nosnippet>67</a>    </span>D: AsyncDB + Send + <span 
class="lifetime">'static</span>,
+<a href=#68 id=68 data-nosnippet>68</a>    M: MakeConnection&lt;Conn = D&gt; + 
Send + <span class="lifetime">'static</span>,
+<a href=#69 id=69 data-nosnippet>69</a>{
+<a href=#70 id=70 data-nosnippet>70</a>    <span class="kw">let </span>path = 
step_slt_file.as_ref().canonicalize()<span class="question-mark">?</span>;
+<a href=#71 id=71 data-nosnippet>71</a>    <span class="kw">let </span>records 
= parse_file(<span class="kw-2">&amp;</span>path).map_err(|e| Error(<span 
class="macro">anyhow!</span>(<span class="string">"parsing slt file failed: 
{e}"</span>)))<span class="question-mark">?</span>;
+<a href=#72 id=72 data-nosnippet>72</a>
+<a href=#73 id=73 data-nosnippet>73</a>    <span class="kw">for </span>record 
<span class="kw">in </span>records {
+<a href=#74 id=74 data-nosnippet>74</a>        <span class="kw">if let 
</span><span class="prelude-val">Err</span>(err) = 
runner.run_async(record).<span class="kw">await </span>{
+<a href=#75 id=75 data-nosnippet>75</a>            <span class="kw">return 
</span><span class="prelude-val">Err</span>(Error(<span 
class="macro">anyhow!</span>(<span class="string">"SLT record execution failed: 
{err}"</span>)));
+<a href=#76 id=76 data-nosnippet>76</a>        }
+<a href=#77 id=77 data-nosnippet>77</a>    }
 <a href=#78 id=78 data-nosnippet>78</a>
-<a href=#79 id=79 data-nosnippet>79</a>        <span 
class="macro">assert!</span>(result.is_err());
-<a href=#80 id=80 data-nosnippet>80</a>    }
+<a href=#79 id=79 data-nosnippet>79</a>    <span 
class="prelude-val">Ok</span>(())
+<a href=#80 id=80 data-nosnippet>80</a>}
 <a href=#81 id=81 data-nosnippet>81</a>
-<a href=#82 id=82 data-nosnippet>82</a>    <span class="attr">#[tokio::test]
-<a href=#83 id=83 data-nosnippet>83</a>    </span><span class="kw">async fn 
</span>test_load_datafusion() {
-<a href=#84 id=84 data-nosnippet>84</a>        <span class="kw">let 
</span>input = <span class="string">r#"
-<a href=#85 id=85 data-nosnippet>85</a>            [engines]
-<a href=#86 id=86 data-nosnippet>86</a>            df = { type = "datafusion" }
-<a href=#87 id=87 data-nosnippet>87</a>        "#</span>;
-<a href=#88 id=88 data-nosnippet>88</a>        <span class="kw">let </span>tbl 
= toml::from_str(input).unwrap();
-<a href=#89 id=89 data-nosnippet>89</a>        <span class="kw">let 
</span>result = load_engine_runner(TYPE_DATAFUSION, tbl).<span 
class="kw">await</span>;
-<a href=#90 id=90 data-nosnippet>90</a>
-<a href=#91 id=91 data-nosnippet>91</a>        <span 
class="macro">assert!</span>(result.is_ok());
+<a href=#82 id=82 data-nosnippet>82</a><span class="attr">#[cfg(test)]
+<a href=#83 id=83 data-nosnippet>83</a></span><span class="kw">mod 
</span>tests {
+<a href=#84 id=84 data-nosnippet>84</a>    <span class="kw">use </span><span 
class="kw">crate</span>::engine::{DatafusionCatalogConfig, EngineConfig, 
load_engine_runner};
+<a href=#85 id=85 data-nosnippet>85</a>
+<a href=#86 id=86 data-nosnippet>86</a>    <span class="attr">#[test]
+<a href=#87 id=87 data-nosnippet>87</a>    </span><span class="kw">fn 
</span>test_deserialize_engine_config() {
+<a href=#88 id=88 data-nosnippet>88</a>        <span class="kw">let 
</span>input = <span class="string">r#"type = "datafusion""#</span>;
+<a href=#89 id=89 data-nosnippet>89</a>
+<a href=#90 id=90 data-nosnippet>90</a>        <span class="kw">let 
</span>config: EngineConfig = toml::from_str(input).unwrap();
+<a href=#91 id=91 data-nosnippet>91</a>        <span 
class="macro">assert!</span>(<span class="macro">matches!</span>(config, 
EngineConfig::Datafusion { catalog: <span class="prelude-val">None </span>}));
 <a href=#92 id=92 data-nosnippet>92</a>    }
-<a href=#93 id=93 
data-nosnippet>93</a>}</code></pre></div></section></main></body></html>
\ No newline at end of file
+<a href=#93 id=93 data-nosnippet>93</a>
+<a href=#94 id=94 data-nosnippet>94</a>    <span class="attr">#[test]
+<a href=#95 id=95 data-nosnippet>95</a>    </span><span class="kw">fn 
</span>test_deserialize_engine_config_with_catalog() {
+<a href=#96 id=96 data-nosnippet>96</a>        <span class="kw">let 
</span>input = <span class="string">r#"
+<a href=#97 id=97 data-nosnippet>97</a>            type = "datafusion"
+<a href=#98 id=98 data-nosnippet>98</a>
+<a href=#99 id=99 data-nosnippet>99</a>            [catalog]
+<a href=#100 id=100 data-nosnippet>100</a>            type = "rest"
+<a href=#101 id=101 data-nosnippet>101</a>
+<a href=#102 id=102 data-nosnippet>102</a>            [catalog.props]
+<a href=#103 id=103 data-nosnippet>103</a>            uri = 
"http://localhost:8181";
+<a href=#104 id=104 data-nosnippet>104</a>        "#</span>;
+<a href=#105 id=105 data-nosnippet>105</a>
+<a href=#106 id=106 data-nosnippet>106</a>        <span class="kw">let 
</span>config: EngineConfig = toml::from_str(input).unwrap();
+<a href=#107 id=107 data-nosnippet>107</a>        <span class="kw">match 
</span>config {
+<a href=#108 id=108 data-nosnippet>108</a>            EngineConfig::Datafusion 
{ catalog: <span class="prelude-val">Some</span>(cat) } =&gt; {
+<a href=#109 id=109 data-nosnippet>109</a>                <span 
class="macro">assert_eq!</span>(cat.catalog_type, <span 
class="string">"rest"</span>);
+<a href=#110 id=110 data-nosnippet>110</a>                <span 
class="macro">assert_eq!</span>(
+<a href=#111 id=111 data-nosnippet>111</a>                    
cat.props.get(<span class="string">"uri"</span>),
+<a href=#112 id=112 data-nosnippet>112</a>                    <span 
class="prelude-val">Some</span>(<span class="kw-2">&amp;</span><span 
class="string">"http://localhost:8181";</span>.to_string())
+<a href=#113 id=113 data-nosnippet>113</a>                );
+<a href=#114 id=114 data-nosnippet>114</a>            }
+<a href=#115 id=115 data-nosnippet>115</a>            <span class="kw">_ 
</span>=&gt; <span class="macro">panic!</span>(<span class="string">"Expected 
Datafusion with catalog"</span>),
+<a href=#116 id=116 data-nosnippet>116</a>        }
+<a href=#117 id=117 data-nosnippet>117</a>    }
+<a href=#118 id=118 data-nosnippet>118</a>
+<a href=#119 id=119 data-nosnippet>119</a>    <span class="attr">#[test]
+<a href=#120 id=120 data-nosnippet>120</a>    </span><span class="kw">fn 
</span>test_deserialize_catalog_config() {
+<a href=#121 id=121 data-nosnippet>121</a>        <span class="kw">let 
</span>input = <span class="string">r#"
+<a href=#122 id=122 data-nosnippet>122</a>            type = "memory"
+<a href=#123 id=123 data-nosnippet>123</a>
+<a href=#124 id=124 data-nosnippet>124</a>            [props]
+<a href=#125 id=125 data-nosnippet>125</a>            warehouse = 
"file:///tmp/warehouse"
+<a href=#126 id=126 data-nosnippet>126</a>        "#</span>;
+<a href=#127 id=127 data-nosnippet>127</a>
+<a href=#128 id=128 data-nosnippet>128</a>        <span class="kw">let 
</span>config: DatafusionCatalogConfig = toml::from_str(input).unwrap();
+<a href=#129 id=129 data-nosnippet>129</a>        <span 
class="macro">assert_eq!</span>(config.catalog_type, <span 
class="string">"memory"</span>);
+<a href=#130 id=130 data-nosnippet>130</a>        <span 
class="macro">assert_eq!</span>(
+<a href=#131 id=131 data-nosnippet>131</a>            config.props.get(<span 
class="string">"warehouse"</span>),
+<a href=#132 id=132 data-nosnippet>132</a>            <span 
class="prelude-val">Some</span>(<span class="kw-2">&amp;</span><span 
class="string">"file:///tmp/warehouse"</span>.to_string())
+<a href=#133 id=133 data-nosnippet>133</a>        );
+<a href=#134 id=134 data-nosnippet>134</a>    }
+<a href=#135 id=135 data-nosnippet>135</a>
+<a href=#136 id=136 data-nosnippet>136</a>    <span class="attr">#[tokio::test]
+<a href=#137 id=137 data-nosnippet>137</a>    </span><span class="kw">async fn 
</span>test_load_datafusion() {
+<a href=#138 id=138 data-nosnippet>138</a>        <span class="kw">let 
</span>config = EngineConfig::Datafusion { catalog: <span 
class="prelude-val">None </span>};
+<a href=#139 id=139 data-nosnippet>139</a>
+<a href=#140 id=140 data-nosnippet>140</a>        <span class="kw">let 
</span>result = load_engine_runner(config).<span class="kw">await</span>;
+<a href=#141 id=141 data-nosnippet>141</a>        <span 
class="macro">assert!</span>(result.is_ok());
+<a href=#142 id=142 data-nosnippet>142</a>    }
+<a href=#143 id=143 
data-nosnippet>143</a>}</code></pre></div></section></main></body></html>
\ No newline at end of file
diff --git a/api/src/iceberg_sqllogictest/schedule.rs.html 
b/api/src/iceberg_sqllogictest/schedule.rs.html
index 70ce419d6..45ffb5d03 100644
--- a/api/src/iceberg_sqllogictest/schedule.rs.html
+++ b/api/src/iceberg_sqllogictest/schedule.rs.html
@@ -21,187 +21,235 @@
 <a href=#21 id=21 data-nosnippet>21</a>
 <a href=#22 id=22 data-nosnippet>22</a><span class="kw">use 
</span>anyhow::{Context, anyhow};
 <a href=#23 id=23 data-nosnippet>23</a><span class="kw">use 
</span>serde::{Deserialize, Serialize};
-<a href=#24 id=24 data-nosnippet>24</a><span class="kw">use 
</span>toml::{Table <span class="kw">as </span>TomlTable, Value};
-<a href=#25 id=25 data-nosnippet>25</a><span class="kw">use 
</span>tracing::info;
-<a href=#26 id=26 data-nosnippet>26</a>
-<a href=#27 id=27 data-nosnippet>27</a><span class="kw">use </span><span 
class="kw">crate</span>::engine::{EngineRunner, load_engine_runner};
-<a href=#28 id=28 data-nosnippet>28</a>
-<a href=#29 id=29 data-nosnippet>29</a><span class="kw">pub struct 
</span>Schedule {
-<a href=#30 id=30 data-nosnippet>30</a>    <span class="doccomment">/// Engine 
names to engine instances
-<a href=#31 id=31 data-nosnippet>31</a>    </span>engines: HashMap&lt;String, 
Box&lt;<span class="kw">dyn </span>EngineRunner&gt;&gt;,
-<a href=#32 id=32 data-nosnippet>32</a>    <span class="doccomment">/// List 
of test steps to run
-<a href=#33 id=33 data-nosnippet>33</a>    </span>steps: Vec&lt;Step&gt;,
-<a href=#34 id=34 data-nosnippet>34</a>    <span class="doccomment">/// Path 
of the schedule file
-<a href=#35 id=35 data-nosnippet>35</a>    </span>schedule_file: String,
-<a href=#36 id=36 data-nosnippet>36</a>}
-<a href=#37 id=37 data-nosnippet>37</a>
-<a href=#38 id=38 data-nosnippet>38</a><span class="attr">#[derive(Debug, 
Clone, Serialize, Deserialize)]
-<a href=#39 id=39 data-nosnippet>39</a></span><span class="kw">pub struct 
</span>Step {
-<a href=#40 id=40 data-nosnippet>40</a>    <span class="doccomment">/// Engine 
name
-<a href=#41 id=41 data-nosnippet>41</a>    </span>engine: String,
-<a href=#42 id=42 data-nosnippet>42</a>    <span class="doccomment">/// Stl 
file path
-<a href=#43 id=43 data-nosnippet>43</a>    </span>slt: String,
+<a href=#24 id=24 data-nosnippet>24</a><span class="kw">use 
</span>tracing::info;
+<a href=#25 id=25 data-nosnippet>25</a>
+<a href=#26 id=26 data-nosnippet>26</a><span class="kw">use </span><span 
class="kw">crate</span>::engine::{EngineConfig, EngineRunner, 
load_engine_runner};
+<a href=#27 id=27 data-nosnippet>27</a>
+<a href=#28 id=28 data-nosnippet>28</a><span class="doccomment">/// Raw 
configuration parsed from the schedule TOML file
+<a href=#29 id=29 data-nosnippet>29</a></span><span 
class="attr">#[derive(Debug, Clone, Deserialize)]
+<a href=#30 id=30 data-nosnippet>30</a></span><span class="kw">pub struct 
</span>ScheduleConfig {
+<a href=#31 id=31 data-nosnippet>31</a>    <span class="doccomment">/// Engine 
name to engine configuration
+<a href=#32 id=32 data-nosnippet>32</a>    </span><span class="kw">pub 
</span>engines: HashMap&lt;String, EngineConfig&gt;,
+<a href=#33 id=33 data-nosnippet>33</a>    <span class="doccomment">/// List 
of test steps to run
+<a href=#34 id=34 data-nosnippet>34</a>    </span><span class="kw">pub 
</span>steps: Vec&lt;Step&gt;,
+<a href=#35 id=35 data-nosnippet>35</a>}
+<a href=#36 id=36 data-nosnippet>36</a>
+<a href=#37 id=37 data-nosnippet>37</a><span class="kw">pub struct 
</span>Schedule {
+<a href=#38 id=38 data-nosnippet>38</a>    <span class="doccomment">/// Engine 
names to engine instances
+<a href=#39 id=39 data-nosnippet>39</a>    </span>engines: HashMap&lt;String, 
Box&lt;<span class="kw">dyn </span>EngineRunner&gt;&gt;,
+<a href=#40 id=40 data-nosnippet>40</a>    <span class="doccomment">/// List 
of test steps to run
+<a href=#41 id=41 data-nosnippet>41</a>    </span>steps: Vec&lt;Step&gt;,
+<a href=#42 id=42 data-nosnippet>42</a>    <span class="doccomment">/// Path 
of the schedule file
+<a href=#43 id=43 data-nosnippet>43</a>    </span>schedule_file: String,
 <a href=#44 id=44 data-nosnippet>44</a>}
 <a href=#45 id=45 data-nosnippet>45</a>
-<a href=#46 id=46 data-nosnippet>46</a><span class="kw">impl </span>Schedule {
-<a href=#47 id=47 data-nosnippet>47</a>    <span class="kw">pub fn </span>new(
-<a href=#48 id=48 data-nosnippet>48</a>        engines: HashMap&lt;String, 
Box&lt;<span class="kw">dyn </span>EngineRunner&gt;&gt;,
-<a href=#49 id=49 data-nosnippet>49</a>        steps: Vec&lt;Step&gt;,
-<a href=#50 id=50 data-nosnippet>50</a>        schedule_file: String,
-<a href=#51 id=51 data-nosnippet>51</a>    ) -&gt; <span class="self">Self 
</span>{
-<a href=#52 id=52 data-nosnippet>52</a>        <span class="self">Self </span>{
-<a href=#53 id=53 data-nosnippet>53</a>            engines,
-<a href=#54 id=54 data-nosnippet>54</a>            steps,
-<a href=#55 id=55 data-nosnippet>55</a>            schedule_file,
-<a href=#56 id=56 data-nosnippet>56</a>        }
-<a href=#57 id=57 data-nosnippet>57</a>    }
-<a href=#58 id=58 data-nosnippet>58</a>
-<a href=#59 id=59 data-nosnippet>59</a>    <span class="kw">pub async fn 
</span>from_file&lt;P: AsRef&lt;Path&gt;&gt;(path: P) -&gt; 
anyhow::Result&lt;<span class="self">Self</span>&gt; {
-<a href=#60 id=60 data-nosnippet>60</a>        <span class="kw">let 
</span>path_str = path.as_ref().to_string_lossy().to_string();
-<a href=#61 id=61 data-nosnippet>61</a>        <span class="kw">let 
</span>content = read_to_string(path)<span class="question-mark">?</span>;
-<a href=#62 id=62 data-nosnippet>62</a>        <span class="kw">let 
</span>toml_value = content.parse::&lt;Value&gt;()<span 
class="question-mark">?</span>;
-<a href=#63 id=63 data-nosnippet>63</a>        <span class="kw">let 
</span>toml_table = toml_value
-<a href=#64 id=64 data-nosnippet>64</a>            .as_table()
-<a href=#65 id=65 data-nosnippet>65</a>            .ok_or_else(|| <span 
class="macro">anyhow!</span>(<span class="string">"Schedule file must be a TOML 
table"</span>))<span class="question-mark">?</span>;
+<a href=#46 id=46 data-nosnippet>46</a><span class="attr">#[derive(Debug, 
Clone, Serialize, Deserialize)]
+<a href=#47 id=47 data-nosnippet>47</a></span><span class="kw">pub struct 
</span>Step {
+<a href=#48 id=48 data-nosnippet>48</a>    <span class="doccomment">/// Engine 
name
+<a href=#49 id=49 data-nosnippet>49</a>    </span>engine: String,
+<a href=#50 id=50 data-nosnippet>50</a>    <span class="doccomment">/// Stl 
file path
+<a href=#51 id=51 data-nosnippet>51</a>    </span>slt: String,
+<a href=#52 id=52 data-nosnippet>52</a>}
+<a href=#53 id=53 data-nosnippet>53</a>
+<a href=#54 id=54 data-nosnippet>54</a><span class="kw">impl </span>Schedule {
+<a href=#55 id=55 data-nosnippet>55</a>    <span class="kw">pub fn </span>new(
+<a href=#56 id=56 data-nosnippet>56</a>        engines: HashMap&lt;String, 
Box&lt;<span class="kw">dyn </span>EngineRunner&gt;&gt;,
+<a href=#57 id=57 data-nosnippet>57</a>        steps: Vec&lt;Step&gt;,
+<a href=#58 id=58 data-nosnippet>58</a>        schedule_file: String,
+<a href=#59 id=59 data-nosnippet>59</a>    ) -&gt; <span class="self">Self 
</span>{
+<a href=#60 id=60 data-nosnippet>60</a>        <span class="self">Self </span>{
+<a href=#61 id=61 data-nosnippet>61</a>            engines,
+<a href=#62 id=62 data-nosnippet>62</a>            steps,
+<a href=#63 id=63 data-nosnippet>63</a>            schedule_file,
+<a href=#64 id=64 data-nosnippet>64</a>        }
+<a href=#65 id=65 data-nosnippet>65</a>    }
 <a href=#66 id=66 data-nosnippet>66</a>
-<a href=#67 id=67 data-nosnippet>67</a>        <span class="kw">let 
</span>engines = Schedule::parse_engines(toml_table).<span 
class="kw">await</span><span class="question-mark">?</span>;
-<a href=#68 id=68 data-nosnippet>68</a>        <span class="kw">let 
</span>steps = Schedule::parse_steps(toml_table)<span 
class="question-mark">?</span>;
-<a href=#69 id=69 data-nosnippet>69</a>
-<a href=#70 id=70 data-nosnippet>70</a>        <span 
class="prelude-val">Ok</span>(<span class="self">Self</span>::new(engines, 
steps, path_str))
-<a href=#71 id=71 data-nosnippet>71</a>    }
-<a href=#72 id=72 data-nosnippet>72</a>
-<a href=#73 id=73 data-nosnippet>73</a>    <span class="kw">pub async fn 
</span>run(<span class="kw-2">mut </span><span class="self">self</span>) -&gt; 
anyhow::Result&lt;()&gt; {
-<a href=#74 id=74 data-nosnippet>74</a>        <span 
class="macro">info!</span>(<span class="string">"Starting test run with 
schedule: {}"</span>, <span class="self">self</span>.schedule_file);
+<a href=#67 id=67 data-nosnippet>67</a>    <span class="kw">pub async fn 
</span>from_file&lt;P: AsRef&lt;Path&gt;&gt;(path: P) -&gt; 
anyhow::Result&lt;<span class="self">Self</span>&gt; {
+<a href=#68 id=68 data-nosnippet>68</a>        <span class="kw">let 
</span>path_str = path.as_ref().to_string_lossy().to_string();
+<a href=#69 id=69 data-nosnippet>69</a>        <span class="kw">let 
</span>content = read_to_string(path)<span class="question-mark">?</span>;
+<a href=#70 id=70 data-nosnippet>70</a>
+<a href=#71 id=71 data-nosnippet>71</a>        <span class="kw">let 
</span>config: ScheduleConfig = toml::from_str(<span 
class="kw-2">&amp;</span>content)
+<a href=#72 id=72 data-nosnippet>72</a>            .with_context(|| <span 
class="macro">format!</span>(<span class="string">"Failed to parse schedule 
file: {path_str}"</span>))<span class="question-mark">?</span>;
+<a href=#73 id=73 data-nosnippet>73</a>
+<a href=#74 id=74 data-nosnippet>74</a>        <span class="kw">let 
</span>engines = <span 
class="self">Self</span>::instantiate_engines(config.engines).<span 
class="kw">await</span><span class="question-mark">?</span>;
 <a href=#75 id=75 data-nosnippet>75</a>
-<a href=#76 id=76 data-nosnippet>76</a>        <span class="kw">for 
</span>(idx, step) <span class="kw">in </span><span 
class="self">self</span>.steps.iter().enumerate() {
-<a href=#77 id=77 data-nosnippet>77</a>            <span 
class="macro">info!</span>(
-<a href=#78 id=78 data-nosnippet>78</a>                <span 
class="string">"Running step {}/{}, using engine {}, slt file path: {}"</span>,
-<a href=#79 id=79 data-nosnippet>79</a>                idx + <span 
class="number">1</span>,
-<a href=#80 id=80 data-nosnippet>80</a>                <span 
class="self">self</span>.steps.len(),
-<a href=#81 id=81 data-nosnippet>81</a>                <span 
class="kw-2">&amp;</span>step.engine,
-<a href=#82 id=82 data-nosnippet>82</a>                <span 
class="kw-2">&amp;</span>step.slt
-<a href=#83 id=83 data-nosnippet>83</a>            );
+<a href=#76 id=76 data-nosnippet>76</a>        <span 
class="prelude-val">Ok</span>(<span class="self">Self</span>::new(engines, 
config.steps, path_str))
+<a href=#77 id=77 data-nosnippet>77</a>    }
+<a href=#78 id=78 data-nosnippet>78</a>
+<a href=#79 id=79 data-nosnippet>79</a>    <span class="doccomment">/// 
Instantiate engine runners from their configurations
+<a href=#80 id=80 data-nosnippet>80</a>    </span><span class="kw">async fn 
</span>instantiate_engines(
+<a href=#81 id=81 data-nosnippet>81</a>        configs: HashMap&lt;String, 
EngineConfig&gt;,
+<a href=#82 id=82 data-nosnippet>82</a>    ) -&gt; 
anyhow::Result&lt;HashMap&lt;String, Box&lt;<span class="kw">dyn 
</span>EngineRunner&gt;&gt;&gt; {
+<a href=#83 id=83 data-nosnippet>83</a>        <span class="kw">let 
</span><span class="kw-2">mut </span>engines = HashMap::new();
 <a href=#84 id=84 data-nosnippet>84</a>
-<a href=#85 id=85 data-nosnippet>85</a>            <span class="kw">let 
</span>engine = <span class="self">self
-<a href=#86 id=86 data-nosnippet>86</a>                </span>.engines
-<a href=#87 id=87 data-nosnippet>87</a>                .get_mut(<span 
class="kw-2">&amp;</span>step.engine)
-<a href=#88 id=88 data-nosnippet>88</a>                .ok_or_else(|| <span 
class="macro">anyhow!</span>(<span class="string">"Engine {} not found"</span>, 
step.engine))<span class="question-mark">?</span>;
+<a href=#85 id=85 data-nosnippet>85</a>        <span class="kw">for 
</span>(name, config) <span class="kw">in </span>configs {
+<a href=#86 id=86 data-nosnippet>86</a>            <span class="kw">let 
</span>engine = load_engine_runner(config).<span class="kw">await</span><span 
class="question-mark">?</span>;
+<a href=#87 id=87 data-nosnippet>87</a>            engines.insert(name, 
engine);
+<a href=#88 id=88 data-nosnippet>88</a>        }
 <a href=#89 id=89 data-nosnippet>89</a>
-<a href=#90 id=90 data-nosnippet>90</a>            <span class="kw">let 
</span>step_sql_path = PathBuf::from(<span class="macro">format!</span>(
-<a href=#91 id=91 data-nosnippet>91</a>                <span 
class="string">"{}/testdata/slts/{}"</span>,
-<a href=#92 id=92 data-nosnippet>92</a>                <span 
class="macro">env!</span>(<span class="string">"CARGO_MANIFEST_DIR"</span>),
-<a href=#93 id=93 data-nosnippet>93</a>                <span 
class="kw-2">&amp;</span>step.slt
-<a href=#94 id=94 data-nosnippet>94</a>            ));
+<a href=#90 id=90 data-nosnippet>90</a>        <span 
class="prelude-val">Ok</span>(engines)
+<a href=#91 id=91 data-nosnippet>91</a>    }
+<a href=#92 id=92 data-nosnippet>92</a>
+<a href=#93 id=93 data-nosnippet>93</a>    <span class="kw">pub async fn 
</span>run(<span class="kw-2">mut </span><span class="self">self</span>) -&gt; 
anyhow::Result&lt;()&gt; {
+<a href=#94 id=94 data-nosnippet>94</a>        <span 
class="macro">info!</span>(<span class="string">"Starting test run with 
schedule: {}"</span>, <span class="self">self</span>.schedule_file);
 <a href=#95 id=95 data-nosnippet>95</a>
-<a href=#96 id=96 data-nosnippet>96</a>            engine.run_slt_file(<span 
class="kw-2">&amp;</span>step_sql_path).<span class="kw">await</span><span 
class="question-mark">?</span>;
-<a href=#97 id=97 data-nosnippet>97</a>
-<a href=#98 id=98 data-nosnippet>98</a>            <span 
class="macro">info!</span>(
-<a href=#99 id=99 data-nosnippet>99</a>                <span 
class="string">"Completed step {}/{}, engine {}, slt file path: {}"</span>,
-<a href=#100 id=100 data-nosnippet>100</a>                idx + <span 
class="number">1</span>,
-<a href=#101 id=101 data-nosnippet>101</a>                <span 
class="self">self</span>.steps.len(),
-<a href=#102 id=102 data-nosnippet>102</a>                <span 
class="kw-2">&amp;</span>step.engine,
-<a href=#103 id=103 data-nosnippet>103</a>                <span 
class="kw-2">&amp;</span>step.slt
-<a href=#104 id=104 data-nosnippet>104</a>            );
-<a href=#105 id=105 data-nosnippet>105</a>        }
-<a href=#106 id=106 data-nosnippet>106</a>        <span 
class="prelude-val">Ok</span>(())
-<a href=#107 id=107 data-nosnippet>107</a>    }
-<a href=#108 id=108 data-nosnippet>108</a>
-<a href=#109 id=109 data-nosnippet>109</a>    <span class="kw">async fn 
</span>parse_engines(
-<a href=#110 id=110 data-nosnippet>110</a>        table: <span 
class="kw-2">&amp;</span>TomlTable,
-<a href=#111 id=111 data-nosnippet>111</a>    ) -&gt; 
anyhow::Result&lt;HashMap&lt;String, Box&lt;<span class="kw">dyn 
</span>EngineRunner&gt;&gt;&gt; {
-<a href=#112 id=112 data-nosnippet>112</a>        <span class="kw">let 
</span>engines_tbl = table
-<a href=#113 id=113 data-nosnippet>113</a>            .get(<span 
class="string">"engines"</span>)
-<a href=#114 id=114 data-nosnippet>114</a>            .with_context(|| <span 
class="string">"Schedule file must have an 'engines' table"</span>)<span 
class="question-mark">?
-<a href=#115 id=115 data-nosnippet>115</a>            </span>.as_table()
-<a href=#116 id=116 data-nosnippet>116</a>            .ok_or_else(|| <span 
class="macro">anyhow!</span>(<span class="string">"'engines' must be a 
table"</span>))<span class="question-mark">?</span>;
+<a href=#96 id=96 data-nosnippet>96</a>        <span class="kw">for 
</span>(idx, step) <span class="kw">in </span><span 
class="self">self</span>.steps.iter().enumerate() {
+<a href=#97 id=97 data-nosnippet>97</a>            <span 
class="macro">info!</span>(
+<a href=#98 id=98 data-nosnippet>98</a>                <span 
class="string">"Running step {}/{}, using engine {}, slt file path: {}"</span>,
+<a href=#99 id=99 data-nosnippet>99</a>                idx + <span 
class="number">1</span>,
+<a href=#100 id=100 data-nosnippet>100</a>                <span 
class="self">self</span>.steps.len(),
+<a href=#101 id=101 data-nosnippet>101</a>                <span 
class="kw-2">&amp;</span>step.engine,
+<a href=#102 id=102 data-nosnippet>102</a>                <span 
class="kw-2">&amp;</span>step.slt
+<a href=#103 id=103 data-nosnippet>103</a>            );
+<a href=#104 id=104 data-nosnippet>104</a>
+<a href=#105 id=105 data-nosnippet>105</a>            <span class="kw">let 
</span>engine = <span class="self">self
+<a href=#106 id=106 data-nosnippet>106</a>                </span>.engines
+<a href=#107 id=107 data-nosnippet>107</a>                .get_mut(<span 
class="kw-2">&amp;</span>step.engine)
+<a href=#108 id=108 data-nosnippet>108</a>                .ok_or_else(|| <span 
class="macro">anyhow!</span>(<span class="string">"Engine {} not found"</span>, 
step.engine))<span class="question-mark">?</span>;
+<a href=#109 id=109 data-nosnippet>109</a>
+<a href=#110 id=110 data-nosnippet>110</a>            <span class="kw">let 
</span>step_sql_path = PathBuf::from(<span class="macro">format!</span>(
+<a href=#111 id=111 data-nosnippet>111</a>                <span 
class="string">"{}/testdata/slts/{}"</span>,
+<a href=#112 id=112 data-nosnippet>112</a>                <span 
class="macro">env!</span>(<span class="string">"CARGO_MANIFEST_DIR"</span>),
+<a href=#113 id=113 data-nosnippet>113</a>                <span 
class="kw-2">&amp;</span>step.slt
+<a href=#114 id=114 data-nosnippet>114</a>            ));
+<a href=#115 id=115 data-nosnippet>115</a>
+<a href=#116 id=116 data-nosnippet>116</a>            
engine.run_slt_file(<span class="kw-2">&amp;</span>step_sql_path).<span 
class="kw">await</span><span class="question-mark">?</span>;
 <a href=#117 id=117 data-nosnippet>117</a>
-<a href=#118 id=118 data-nosnippet>118</a>        <span class="kw">let 
</span><span class="kw-2">mut </span>engines = HashMap::new();
-<a href=#119 id=119 data-nosnippet>119</a>
-<a href=#120 id=120 data-nosnippet>120</a>        <span class="kw">for 
</span>(name, engine_val) <span class="kw">in </span>engines_tbl {
-<a href=#121 id=121 data-nosnippet>121</a>            <span class="kw">let 
</span>cfg_tbl = engine_val
-<a href=#122 id=122 data-nosnippet>122</a>                .as_table()
-<a href=#123 id=123 data-nosnippet>123</a>                .ok_or_else(|| <span 
class="macro">anyhow!</span>(<span class="string">"Config of engine '{name}' is 
not a table"</span>))<span class="question-mark">?
-<a href=#124 id=124 data-nosnippet>124</a>                </span>.clone();
-<a href=#125 id=125 data-nosnippet>125</a>
-<a href=#126 id=126 data-nosnippet>126</a>            <span class="kw">let 
</span>engine_type = cfg_tbl
-<a href=#127 id=127 data-nosnippet>127</a>                .get(<span 
class="string">"type"</span>)
-<a href=#128 id=128 data-nosnippet>128</a>                .ok_or_else(|| <span 
class="macro">anyhow::anyhow!</span>(<span class="string">"Engine {name} 
doesn't have a 'type' field"</span>))<span class="question-mark">?
-<a href=#129 id=129 data-nosnippet>129</a>                </span>.as_str()
-<a href=#130 id=130 data-nosnippet>130</a>                .ok_or_else(|| <span 
class="macro">anyhow::anyhow!</span>(<span class="string">"Engine {name} type 
must be a string"</span>))<span class="question-mark">?</span>;
-<a href=#131 id=131 data-nosnippet>131</a>
-<a href=#132 id=132 data-nosnippet>132</a>            <span class="kw">let 
</span>engine = load_engine_runner(engine_type, cfg_tbl.clone()).<span 
class="kw">await</span><span class="question-mark">?</span>;
-<a href=#133 id=133 data-nosnippet>133</a>
-<a href=#134 id=134 data-nosnippet>134</a>            <span class="kw">if 
</span>engines.insert(name.clone(), engine).is_some() {
-<a href=#135 id=135 data-nosnippet>135</a>                <span 
class="kw">return </span><span class="prelude-val">Err</span>(<span 
class="macro">anyhow!</span>(<span class="string">"Duplicate engine 
'{name}'"</span>));
-<a href=#136 id=136 data-nosnippet>136</a>            }
-<a href=#137 id=137 data-nosnippet>137</a>        }
-<a href=#138 id=138 data-nosnippet>138</a>
-<a href=#139 id=139 data-nosnippet>139</a>        <span 
class="prelude-val">Ok</span>(engines)
-<a href=#140 id=140 data-nosnippet>140</a>    }
-<a href=#141 id=141 data-nosnippet>141</a>
-<a href=#142 id=142 data-nosnippet>142</a>    <span class="kw">fn 
</span>parse_steps(table: <span class="kw-2">&amp;</span>TomlTable) -&gt; 
anyhow::Result&lt;Vec&lt;Step&gt;&gt; {
-<a href=#143 id=143 data-nosnippet>143</a>        <span class="kw">let 
</span>steps_val = table
-<a href=#144 id=144 data-nosnippet>144</a>            .get(<span 
class="string">"steps"</span>)
-<a href=#145 id=145 data-nosnippet>145</a>            .with_context(|| <span 
class="string">"Schedule file must have a 'steps' array"</span>)<span 
class="question-mark">?</span>;
-<a href=#146 id=146 data-nosnippet>146</a>
-<a href=#147 id=147 data-nosnippet>147</a>        <span class="kw">let 
</span>steps: Vec&lt;Step&gt; = steps_val
-<a href=#148 id=148 data-nosnippet>148</a>            .clone()
-<a href=#149 id=149 data-nosnippet>149</a>            .try_into()
-<a href=#150 id=150 data-nosnippet>150</a>            .with_context(|| <span 
class="string">"Failed to deserialize steps"</span>)<span 
class="question-mark">?</span>;
-<a href=#151 id=151 data-nosnippet>151</a>
-<a href=#152 id=152 data-nosnippet>152</a>        <span 
class="prelude-val">Ok</span>(steps)
-<a href=#153 id=153 data-nosnippet>153</a>    }
-<a href=#154 id=154 data-nosnippet>154</a>}
-<a href=#155 id=155 data-nosnippet>155</a>
-<a href=#156 id=156 data-nosnippet>156</a><span class="attr">#[cfg(test)]
-<a href=#157 id=157 data-nosnippet>157</a></span><span class="kw">mod 
</span>tests {
-<a href=#158 id=158 data-nosnippet>158</a>    <span class="kw">use 
</span>toml::Table <span class="kw">as </span>TomlTable;
-<a href=#159 id=159 data-nosnippet>159</a>
-<a href=#160 id=160 data-nosnippet>160</a>    <span class="kw">use 
</span><span class="kw">crate</span>::schedule::Schedule;
-<a href=#161 id=161 data-nosnippet>161</a>
-<a href=#162 id=162 data-nosnippet>162</a>    <span class="attr">#[test]
-<a href=#163 id=163 data-nosnippet>163</a>    </span><span class="kw">fn 
</span>test_parse_steps() {
-<a href=#164 id=164 data-nosnippet>164</a>        <span class="kw">let 
</span>input = <span class="string">r#"
-<a href=#165 id=165 data-nosnippet>165</a>            [[steps]]
-<a href=#166 id=166 data-nosnippet>166</a>            engine = "datafusion"
-<a href=#167 id=167 data-nosnippet>167</a>            slt = "test.slt"
-<a href=#168 id=168 data-nosnippet>168</a>
-<a href=#169 id=169 data-nosnippet>169</a>            [[steps]]
-<a href=#170 id=170 data-nosnippet>170</a>            engine = "spark"
-<a href=#171 id=171 data-nosnippet>171</a>            slt = "test2.slt"
-<a href=#172 id=172 data-nosnippet>172</a>        "#</span>;
-<a href=#173 id=173 data-nosnippet>173</a>
-<a href=#174 id=174 data-nosnippet>174</a>        <span class="kw">let 
</span>tbl: TomlTable = toml::from_str(input).unwrap();
-<a href=#175 id=175 data-nosnippet>175</a>        <span class="kw">let 
</span>steps = Schedule::parse_steps(<span 
class="kw-2">&amp;</span>tbl).unwrap();
-<a href=#176 id=176 data-nosnippet>176</a>
-<a href=#177 id=177 data-nosnippet>177</a>        <span 
class="macro">assert_eq!</span>(steps.len(), <span class="number">2</span>);
-<a href=#178 id=178 data-nosnippet>178</a>        <span 
class="macro">assert_eq!</span>(steps[<span class="number">0</span>].engine, 
<span class="string">"datafusion"</span>);
-<a href=#179 id=179 data-nosnippet>179</a>        <span 
class="macro">assert_eq!</span>(steps[<span class="number">0</span>].slt, <span 
class="string">"test.slt"</span>);
-<a href=#180 id=180 data-nosnippet>180</a>        <span 
class="macro">assert_eq!</span>(steps[<span class="number">1</span>].engine, 
<span class="string">"spark"</span>);
-<a href=#181 id=181 data-nosnippet>181</a>        <span 
class="macro">assert_eq!</span>(steps[<span class="number">1</span>].slt, <span 
class="string">"test2.slt"</span>);
-<a href=#182 id=182 data-nosnippet>182</a>    }
-<a href=#183 id=183 data-nosnippet>183</a>
-<a href=#184 id=184 data-nosnippet>184</a>    <span class="attr">#[test]
-<a href=#185 id=185 data-nosnippet>185</a>    </span><span class="kw">fn 
</span>test_parse_steps_empty() {
-<a href=#186 id=186 data-nosnippet>186</a>        <span class="kw">let 
</span>input = <span class="string">r#"
-<a href=#187 id=187 data-nosnippet>187</a>            [[steps]]
-<a href=#188 id=188 data-nosnippet>188</a>        "#</span>;
-<a href=#189 id=189 data-nosnippet>189</a>
-<a href=#190 id=190 data-nosnippet>190</a>        <span class="kw">let 
</span>tbl: TomlTable = toml::from_str(input).unwrap();
-<a href=#191 id=191 data-nosnippet>191</a>        <span class="kw">let 
</span>steps = Schedule::parse_steps(<span class="kw-2">&amp;</span>tbl);
-<a href=#192 id=192 data-nosnippet>192</a>
-<a href=#193 id=193 data-nosnippet>193</a>        <span 
class="macro">assert!</span>(steps.is_err());
-<a href=#194 id=194 data-nosnippet>194</a>    }
-<a href=#195 id=195 data-nosnippet>195</a>
-<a href=#196 id=196 data-nosnippet>196</a>    <span class="attr">#[tokio::test]
-<a href=#197 id=197 data-nosnippet>197</a>    </span><span class="kw">async fn 
</span>test_parse_engines_invalid_table() {
-<a href=#198 id=198 data-nosnippet>198</a>        <span class="kw">let 
</span>toml_content = <span class="string">r#"
-<a href=#199 id=199 data-nosnippet>199</a>            engines = "not_a_table"
-<a href=#200 id=200 data-nosnippet>200</a>        "#</span>;
-<a href=#201 id=201 data-nosnippet>201</a>
-<a href=#202 id=202 data-nosnippet>202</a>        <span class="kw">let 
</span>table: TomlTable = toml::from_str(toml_content).unwrap();
-<a href=#203 id=203 data-nosnippet>203</a>        <span class="kw">let 
</span>result = Schedule::parse_engines(<span 
class="kw-2">&amp;</span>table).<span class="kw">await</span>;
-<a href=#204 id=204 data-nosnippet>204</a>
-<a href=#205 id=205 data-nosnippet>205</a>        <span 
class="macro">assert!</span>(result.is_err());
-<a href=#206 id=206 data-nosnippet>206</a>    }
-<a href=#207 id=207 
data-nosnippet>207</a>}</code></pre></div></section></main></body></html>
\ No newline at end of file
+<a href=#118 id=118 data-nosnippet>118</a>            <span 
class="macro">info!</span>(
+<a href=#119 id=119 data-nosnippet>119</a>                <span 
class="string">"Completed step {}/{}, engine {}, slt file path: {}"</span>,
+<a href=#120 id=120 data-nosnippet>120</a>                idx + <span 
class="number">1</span>,
+<a href=#121 id=121 data-nosnippet>121</a>                <span 
class="self">self</span>.steps.len(),
+<a href=#122 id=122 data-nosnippet>122</a>                <span 
class="kw-2">&amp;</span>step.engine,
+<a href=#123 id=123 data-nosnippet>123</a>                <span 
class="kw-2">&amp;</span>step.slt
+<a href=#124 id=124 data-nosnippet>124</a>            );
+<a href=#125 id=125 data-nosnippet>125</a>        }
+<a href=#126 id=126 data-nosnippet>126</a>        <span 
class="prelude-val">Ok</span>(())
+<a href=#127 id=127 data-nosnippet>127</a>    }
+<a href=#128 id=128 data-nosnippet>128</a>}
+<a href=#129 id=129 data-nosnippet>129</a>
+<a href=#130 id=130 data-nosnippet>130</a><span class="attr">#[cfg(test)]
+<a href=#131 id=131 data-nosnippet>131</a></span><span class="kw">mod 
</span>tests {
+<a href=#132 id=132 data-nosnippet>132</a>    <span class="kw">use 
</span><span class="kw">crate</span>::engine::EngineConfig;
+<a href=#133 id=133 data-nosnippet>133</a>    <span class="kw">use 
</span><span class="kw">crate</span>::schedule::ScheduleConfig;
+<a href=#134 id=134 data-nosnippet>134</a>
+<a href=#135 id=135 data-nosnippet>135</a>    <span class="attr">#[test]
+<a href=#136 id=136 data-nosnippet>136</a>    </span><span class="kw">fn 
</span>test_deserialize_schedule_config() {
+<a href=#137 id=137 data-nosnippet>137</a>        <span class="kw">let 
</span>input = <span class="string">r#"
+<a href=#138 id=138 data-nosnippet>138</a>            [engines]
+<a href=#139 id=139 data-nosnippet>139</a>            df = { type = 
"datafusion" }
+<a href=#140 id=140 data-nosnippet>140</a>
+<a href=#141 id=141 data-nosnippet>141</a>            [[steps]]
+<a href=#142 id=142 data-nosnippet>142</a>            engine = "df"
+<a href=#143 id=143 data-nosnippet>143</a>            slt = "test.slt"
+<a href=#144 id=144 data-nosnippet>144</a>        "#</span>;
+<a href=#145 id=145 data-nosnippet>145</a>
+<a href=#146 id=146 data-nosnippet>146</a>        <span class="kw">let 
</span>config: ScheduleConfig = toml::from_str(input).unwrap();
+<a href=#147 id=147 data-nosnippet>147</a>
+<a href=#148 id=148 data-nosnippet>148</a>        <span 
class="macro">assert_eq!</span>(config.engines.len(), <span 
class="number">1</span>);
+<a href=#149 id=149 data-nosnippet>149</a>        <span 
class="macro">assert!</span>(config.engines.contains_key(<span 
class="string">"df"</span>));
+<a href=#150 id=150 data-nosnippet>150</a>        <span 
class="macro">assert!</span>(<span 
class="macro">matches!</span>(config.engines[<span class="string">"df"</span>], 
EngineConfig::Datafusion {
+<a href=#151 id=151 data-nosnippet>151</a>            catalog: <span 
class="prelude-val">None
+<a href=#152 id=152 data-nosnippet>152</a>        </span>}));
+<a href=#153 id=153 data-nosnippet>153</a>        <span 
class="macro">assert_eq!</span>(config.steps.len(), <span 
class="number">1</span>);
+<a href=#154 id=154 data-nosnippet>154</a>        <span 
class="macro">assert_eq!</span>(config.steps[<span 
class="number">0</span>].engine, <span class="string">"df"</span>);
+<a href=#155 id=155 data-nosnippet>155</a>        <span 
class="macro">assert_eq!</span>(config.steps[<span 
class="number">0</span>].slt, <span class="string">"test.slt"</span>);
+<a href=#156 id=156 data-nosnippet>156</a>    }
+<a href=#157 id=157 data-nosnippet>157</a>
+<a href=#158 id=158 data-nosnippet>158</a>    <span class="attr">#[test]
+<a href=#159 id=159 data-nosnippet>159</a>    </span><span class="kw">fn 
</span>test_deserialize_multiple_steps() {
+<a href=#160 id=160 data-nosnippet>160</a>        <span class="kw">let 
</span>input = <span class="string">r#"
+<a href=#161 id=161 data-nosnippet>161</a>            [engines]
+<a href=#162 id=162 data-nosnippet>162</a>            datafusion = { type = 
"datafusion" }
+<a href=#163 id=163 data-nosnippet>163</a>
+<a href=#164 id=164 data-nosnippet>164</a>            [[steps]]
+<a href=#165 id=165 data-nosnippet>165</a>            engine = "datafusion"
+<a href=#166 id=166 data-nosnippet>166</a>            slt = "test.slt"
+<a href=#167 id=167 data-nosnippet>167</a>
+<a href=#168 id=168 data-nosnippet>168</a>            [[steps]]
+<a href=#169 id=169 data-nosnippet>169</a>            engine = "datafusion"
+<a href=#170 id=170 data-nosnippet>170</a>            slt = "test2.slt"
+<a href=#171 id=171 data-nosnippet>171</a>        "#</span>;
+<a href=#172 id=172 data-nosnippet>172</a>
+<a href=#173 id=173 data-nosnippet>173</a>        <span class="kw">let 
</span>config: ScheduleConfig = toml::from_str(input).unwrap();
+<a href=#174 id=174 data-nosnippet>174</a>
+<a href=#175 id=175 data-nosnippet>175</a>        <span 
class="macro">assert_eq!</span>(config.steps.len(), <span 
class="number">2</span>);
+<a href=#176 id=176 data-nosnippet>176</a>        <span 
class="macro">assert_eq!</span>(config.steps[<span 
class="number">0</span>].engine, <span class="string">"datafusion"</span>);
+<a href=#177 id=177 data-nosnippet>177</a>        <span 
class="macro">assert_eq!</span>(config.steps[<span 
class="number">0</span>].slt, <span class="string">"test.slt"</span>);
+<a href=#178 id=178 data-nosnippet>178</a>        <span 
class="macro">assert_eq!</span>(config.steps[<span 
class="number">1</span>].engine, <span class="string">"datafusion"</span>);
+<a href=#179 id=179 data-nosnippet>179</a>        <span 
class="macro">assert_eq!</span>(config.steps[<span 
class="number">1</span>].slt, <span class="string">"test2.slt"</span>);
+<a href=#180 id=180 data-nosnippet>180</a>    }
+<a href=#181 id=181 data-nosnippet>181</a>
+<a href=#182 id=182 data-nosnippet>182</a>    <span class="attr">#[test]
+<a href=#183 id=183 data-nosnippet>183</a>    </span><span class="kw">fn 
</span>test_deserialize_with_catalog_config() {
+<a href=#184 id=184 data-nosnippet>184</a>        <span class="kw">let 
</span>input = <span class="string">r#"
+<a href=#185 id=185 data-nosnippet>185</a>            [engines.df]
+<a href=#186 id=186 data-nosnippet>186</a>            type = "datafusion"
+<a href=#187 id=187 data-nosnippet>187</a>
+<a href=#188 id=188 data-nosnippet>188</a>            [engines.df.catalog]
+<a href=#189 id=189 data-nosnippet>189</a>            type = "rest"
+<a href=#190 id=190 data-nosnippet>190</a>
+<a href=#191 id=191 data-nosnippet>191</a>            
[engines.df.catalog.props]
+<a href=#192 id=192 data-nosnippet>192</a>            uri = 
"http://localhost:8181";
+<a href=#193 id=193 data-nosnippet>193</a>
+<a href=#194 id=194 data-nosnippet>194</a>            [[steps]]
+<a href=#195 id=195 data-nosnippet>195</a>            engine = "df"
+<a href=#196 id=196 data-nosnippet>196</a>            slt = "test.slt"
+<a href=#197 id=197 data-nosnippet>197</a>        "#</span>;
+<a href=#198 id=198 data-nosnippet>198</a>
+<a href=#199 id=199 data-nosnippet>199</a>        <span class="kw">let 
</span>config: ScheduleConfig = toml::from_str(input).unwrap();
+<a href=#200 id=200 data-nosnippet>200</a>
+<a href=#201 id=201 data-nosnippet>201</a>        <span class="kw">match 
</span><span class="kw-2">&amp;</span>config.engines[<span 
class="string">"df"</span>] {
+<a href=#202 id=202 data-nosnippet>202</a>            EngineConfig::Datafusion 
{ catalog: <span class="prelude-val">Some</span>(cat) } =&gt; {
+<a href=#203 id=203 data-nosnippet>203</a>                <span 
class="macro">assert_eq!</span>(cat.catalog_type, <span 
class="string">"rest"</span>);
+<a href=#204 id=204 data-nosnippet>204</a>                <span 
class="macro">assert_eq!</span>(
+<a href=#205 id=205 data-nosnippet>205</a>                    
cat.props.get(<span class="string">"uri"</span>),
+<a href=#206 id=206 data-nosnippet>206</a>                    <span 
class="prelude-val">Some</span>(<span class="kw-2">&amp;</span><span 
class="string">"http://localhost:8181";</span>.to_string())
+<a href=#207 id=207 data-nosnippet>207</a>                );
+<a href=#208 id=208 data-nosnippet>208</a>            }
+<a href=#209 id=209 data-nosnippet>209</a>            <span class="kw">_ 
</span>=&gt; <span class="macro">panic!</span>(<span class="string">"Expected 
Datafusion with catalog config"</span>),
+<a href=#210 id=210 data-nosnippet>210</a>        }
+<a href=#211 id=211 data-nosnippet>211</a>    }
+<a href=#212 id=212 data-nosnippet>212</a>
+<a href=#213 id=213 data-nosnippet>213</a>    <span class="attr">#[test]
+<a href=#214 id=214 data-nosnippet>214</a>    </span><span class="kw">fn 
</span>test_deserialize_missing_engine_type() {
+<a href=#215 id=215 data-nosnippet>215</a>        <span class="kw">let 
</span>input = <span class="string">r#"
+<a href=#216 id=216 data-nosnippet>216</a>            [engines]
+<a href=#217 id=217 data-nosnippet>217</a>            df = { }
+<a href=#218 id=218 data-nosnippet>218</a>
+<a href=#219 id=219 data-nosnippet>219</a>            [[steps]]
+<a href=#220 id=220 data-nosnippet>220</a>            engine = "df"
+<a href=#221 id=221 data-nosnippet>221</a>            slt = "test.slt"
+<a href=#222 id=222 data-nosnippet>222</a>        "#</span>;
+<a href=#223 id=223 data-nosnippet>223</a>
+<a href=#224 id=224 data-nosnippet>224</a>        <span class="kw">let 
</span>result: <span class="prelude-ty">Result</span>&lt;ScheduleConfig, <span 
class="kw">_</span>&gt; = toml::from_str(input);
+<a href=#225 id=225 data-nosnippet>225</a>        <span 
class="macro">assert!</span>(result.is_err());
+<a href=#226 id=226 data-nosnippet>226</a>    }
+<a href=#227 id=227 data-nosnippet>227</a>
+<a href=#228 id=228 data-nosnippet>228</a>    <span class="attr">#[test]
+<a href=#229 id=229 data-nosnippet>229</a>    </span><span class="kw">fn 
</span>test_deserialize_invalid_engine_type() {
+<a href=#230 id=230 data-nosnippet>230</a>        <span class="kw">let 
</span>input = <span class="string">r#"
+<a href=#231 id=231 data-nosnippet>231</a>            [engines]
+<a href=#232 id=232 data-nosnippet>232</a>            df = { type = 
"unknown_engine" }
+<a href=#233 id=233 data-nosnippet>233</a>
+<a href=#234 id=234 data-nosnippet>234</a>            [[steps]]
+<a href=#235 id=235 data-nosnippet>235</a>            engine = "df"
+<a href=#236 id=236 data-nosnippet>236</a>            slt = "test.slt"
+<a href=#237 id=237 data-nosnippet>237</a>        "#</span>;
+<a href=#238 id=238 data-nosnippet>238</a>
+<a href=#239 id=239 data-nosnippet>239</a>        <span class="kw">let 
</span>result: <span class="prelude-ty">Result</span>&lt;ScheduleConfig, <span 
class="kw">_</span>&gt; = toml::from_str(input);
+<a href=#240 id=240 data-nosnippet>240</a>        <span 
class="macro">assert!</span>(result.is_err());
+<a href=#241 id=241 data-nosnippet>241</a>    }
+<a href=#242 id=242 data-nosnippet>242</a>
+<a href=#243 id=243 data-nosnippet>243</a>    <span class="attr">#[test]
+<a href=#244 id=244 data-nosnippet>244</a>    </span><span class="kw">fn 
</span>test_deserialize_missing_step_fields() {
+<a href=#245 id=245 data-nosnippet>245</a>        <span class="kw">let 
</span>input = <span class="string">r#"
+<a href=#246 id=246 data-nosnippet>246</a>            [engines]
+<a href=#247 id=247 data-nosnippet>247</a>            df = { type = 
"datafusion" }
+<a href=#248 id=248 data-nosnippet>248</a>
+<a href=#249 id=249 data-nosnippet>249</a>            [[steps]]
+<a href=#250 id=250 data-nosnippet>250</a>        "#</span>;
+<a href=#251 id=251 data-nosnippet>251</a>
+<a href=#252 id=252 data-nosnippet>252</a>        <span class="kw">let 
</span>result: <span class="prelude-ty">Result</span>&lt;ScheduleConfig, <span 
class="kw">_</span>&gt; = toml::from_str(input);
+<a href=#253 id=253 data-nosnippet>253</a>        <span 
class="macro">assert!</span>(result.is_err());
+<a href=#254 id=254 data-nosnippet>254</a>    }
+<a href=#255 id=255 
data-nosnippet>255</a>}</code></pre></div></section></main></body></html>
\ No newline at end of file
diff --git a/api/trait.impl/core/clone/trait.Clone.js 
b/api/trait.impl/core/clone/trait.Clone.js
index aa960c9a7..dd73748d5 100644
--- a/api/trait.impl/core/clone/trait.Clone.js
+++ b/api/trait.impl/core/clone/trait.Clone.js
@@ -1,9 +1,9 @@
 (function() {
-    var implementors = Object.fromEntries([["iceberg",[["impl <a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/clone/trait.Clone.html\"; 
title=\"trait core::clone::Clone\">Clone</a> for <a class=\"enum\" 
href=\"iceberg/arrow/enum.FieldMatchMode.html\" title=\"enum 
iceberg::arrow::FieldMatchMode\">FieldMatchMode</a>"],["impl <a class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/clone/trait.Clone.html\"; 
title=\"trait core::clone::Clone\">Clone</a> for <a class=\"e [...]
+    var implementors = Object.fromEntries([["iceberg",[["impl <a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/clone/trait.Clone.html\"; 
title=\"trait core::clone::Clone\">Clone</a> for <a class=\"enum\" 
href=\"iceberg/arrow/enum.FieldMatchMode.html\" title=\"enum 
iceberg::arrow::FieldMatchMode\">FieldMatchMode</a>"],["impl <a class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/clone/trait.Clone.html\"; 
title=\"trait core::clone::Clone\">Clone</a> for <a class=\"e [...]
     if (window.register_implementors) {
         window.register_implementors(implementors);
     } else {
         window.pending_implementors = implementors;
     }
 })()
-//{"start":57,"fragment_lengths":[29935,4159,1073,314]}
\ No newline at end of file
+//{"start":57,"fragment_lengths":[29935,4159,1073,631]}
\ No newline at end of file
diff --git a/api/trait.impl/core/fmt/trait.Debug.js 
b/api/trait.impl/core/fmt/trait.Debug.js
index 195daca26..67e12c6c3 100644
--- a/api/trait.impl/core/fmt/trait.Debug.js
+++ b/api/trait.impl/core/fmt/trait.Debug.js
@@ -1,9 +1,9 @@
 (function() {
-    var implementors = Object.fromEntries([["iceberg",[["impl <a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/fmt/trait.Debug.html\"; 
title=\"trait core::fmt::Debug\">Debug</a> for <a class=\"enum\" 
href=\"iceberg/arrow/enum.FieldMatchMode.html\" title=\"enum 
iceberg::arrow::FieldMatchMode\">FieldMatchMode</a>"],["impl <a class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/fmt/trait.Debug.html\"; 
title=\"trait core::fmt::Debug\">Debug</a> for <a class=\"enum\" hr [...]
+    var implementors = Object.fromEntries([["iceberg",[["impl <a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/fmt/trait.Debug.html\"; 
title=\"trait core::fmt::Debug\">Debug</a> for <a class=\"enum\" 
href=\"iceberg/arrow/enum.FieldMatchMode.html\" title=\"enum 
iceberg::arrow::FieldMatchMode\">FieldMatchMode</a>"],["impl <a class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/fmt/trait.Debug.html\"; 
title=\"trait core::fmt::Debug\">Debug</a> for <a class=\"enum\" hr [...]
     if (window.register_implementors) {
         window.register_implementors(implementors);
     } else {
         window.pending_implementors = implementors;
     }
 })()
-//{"start":57,"fragment_lengths":[40475,618,905,5271,662,887,2089,327,590,327]}
\ No newline at end of file
+//{"start":57,"fragment_lengths":[40475,618,905,5271,662,887,2089,327,903,327]}
\ No newline at end of file
diff --git a/api/trait.impl/core/marker/trait.Freeze.js 
b/api/trait.impl/core/marker/trait.Freeze.js
index 29914d900..adf875bd2 100644
--- a/api/trait.impl/core/marker/trait.Freeze.js
+++ b/api/trait.impl/core/marker/trait.Freeze.js
@@ -1,9 +1,9 @@
 (function() {
-    var implementors = Object.fromEntries([["iceberg",[["impl !<a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Freeze.html\"; 
title=\"trait core::marker::Freeze\">Freeze</a> for <a class=\"enum\" 
href=\"iceberg/enum.TableUpdate.html\" title=\"enum 
iceberg::TableUpdate\">TableUpdate</a>",1,["iceberg::catalog::TableUpdate"]],["impl
 !<a class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Freeze.html\"; 
title=\"trait core::marker::Freeze\">F [...]
+    var implementors = Object.fromEntries([["iceberg",[["impl !<a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Freeze.html\"; 
title=\"trait core::marker::Freeze\">Freeze</a> for <a class=\"enum\" 
href=\"iceberg/enum.TableUpdate.html\" title=\"enum 
iceberg::TableUpdate\">TableUpdate</a>",1,["iceberg::catalog::TableUpdate"]],["impl
 !<a class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Freeze.html\"; 
title=\"trait core::marker::Freeze\">F [...]
     if (window.register_implementors) {
         window.register_implementors(implementors);
     } else {
         window.pending_implementors = implementors;
     }
 })()
-//{"start":57,"fragment_lengths":[58212,401,741,1088,397,6364,801,1064,2542,381,390,1043,384]}
\ No newline at end of file
+//{"start":57,"fragment_lengths":[58212,401,741,1088,397,6364,801,1064,2542,381,390,1418,384]}
\ No newline at end of file
diff --git a/api/trait.impl/core/marker/trait.Send.js 
b/api/trait.impl/core/marker/trait.Send.js
index 117d8119e..55cd6405f 100644
--- a/api/trait.impl/core/marker/trait.Send.js
+++ b/api/trait.impl/core/marker/trait.Send.js
@@ -1,9 +1,9 @@
 (function() {
-    var implementors = Object.fromEntries([["iceberg",[["impl <a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Send.html\"; 
title=\"trait core::marker::Send\">Send</a> for <a class=\"enum\" 
href=\"iceberg/arrow/enum.FieldMatchMode.html\" title=\"enum 
iceberg::arrow::FieldMatchMode\">FieldMatchMode</a>",1,["iceberg::arrow::value::FieldMatchMode"]],["impl
 <a class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Send.html\"; 
title=\"trait core [...]
+    var implementors = Object.fromEntries([["iceberg",[["impl <a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Send.html\"; 
title=\"trait core::marker::Send\">Send</a> for <a class=\"enum\" 
href=\"iceberg/arrow/enum.FieldMatchMode.html\" title=\"enum 
iceberg::arrow::FieldMatchMode\">FieldMatchMode</a>",1,["iceberg::arrow::value::FieldMatchMode"]],["impl
 <a class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Send.html\"; 
title=\"trait core [...]
     if (window.register_implementors) {
         window.register_implementors(implementors);
     } else {
         window.pending_implementors = implementors;
     }
 })()
-//{"start":57,"fragment_lengths":[52312,395,729,1070,391,6258,789,1046,2506,375,384,1025,378]}
\ No newline at end of file
+//{"start":57,"fragment_lengths":[52312,395,729,1070,391,6258,789,1046,2506,375,384,1394,378]}
\ No newline at end of file
diff --git a/api/trait.impl/core/marker/trait.Sync.js 
b/api/trait.impl/core/marker/trait.Sync.js
index 1c85e190b..5f2e5d72c 100644
--- a/api/trait.impl/core/marker/trait.Sync.js
+++ b/api/trait.impl/core/marker/trait.Sync.js
@@ -1,9 +1,9 @@
 (function() {
-    var implementors = Object.fromEntries([["iceberg",[["impl !<a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Sync.html\"; 
title=\"trait core::marker::Sync\">Sync</a> for <a class=\"struct\" 
href=\"iceberg/puffin/struct.PuffinWriter.html\" title=\"struct 
iceberg::puffin::PuffinWriter\">PuffinWriter</a>",1,["iceberg::puffin::writer::PuffinWriter"]],["impl
 !<a class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Sync.html\"; 
title=\"trait  [...]
+    var implementors = Object.fromEntries([["iceberg",[["impl !<a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Sync.html\"; 
title=\"trait core::marker::Sync\">Sync</a> for <a class=\"struct\" 
href=\"iceberg/puffin/struct.PuffinWriter.html\" title=\"struct 
iceberg::puffin::PuffinWriter\">PuffinWriter</a>",1,["iceberg::puffin::writer::PuffinWriter"]],["impl
 !<a class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Sync.html\"; 
title=\"trait  [...]
     if (window.register_implementors) {
         window.register_implementors(implementors);
     } else {
         window.pending_implementors = implementors;
     }
 })()
-//{"start":57,"fragment_lengths":[55383,395,729,1070,391,6258,789,1046,2506,375,384,1026,378]}
\ No newline at end of file
+//{"start":57,"fragment_lengths":[55383,395,729,1070,391,6258,789,1046,2506,375,384,1395,378]}
\ No newline at end of file
diff --git a/api/trait.impl/core/marker/trait.Unpin.js 
b/api/trait.impl/core/marker/trait.Unpin.js
index 2fd11b108..2d4caa29d 100644
--- a/api/trait.impl/core/marker/trait.Unpin.js
+++ b/api/trait.impl/core/marker/trait.Unpin.js
@@ -1,9 +1,9 @@
 (function() {
-    var implementors = Object.fromEntries([["iceberg",[["impl <a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Unpin.html\"; 
title=\"trait core::marker::Unpin\">Unpin</a> for <a class=\"enum\" 
href=\"iceberg/arrow/enum.FieldMatchMode.html\" title=\"enum 
iceberg::arrow::FieldMatchMode\">FieldMatchMode</a>",1,["iceberg::arrow::value::FieldMatchMode"]],["impl
 <a class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Unpin.html\"; 
title=\"trait  [...]
+    var implementors = Object.fromEntries([["iceberg",[["impl <a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Unpin.html\"; 
title=\"trait core::marker::Unpin\">Unpin</a> for <a class=\"enum\" 
href=\"iceberg/arrow/enum.FieldMatchMode.html\" title=\"enum 
iceberg::arrow::FieldMatchMode\">FieldMatchMode</a>",1,["iceberg::arrow::value::FieldMatchMode"]],["impl
 <a class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/marker/trait.Unpin.html\"; 
title=\"trait  [...]
     if (window.register_implementors) {
         window.register_implementors(implementors);
     } else {
         window.pending_implementors = implementors;
     }
 })()
-//{"start":57,"fragment_lengths":[58842,398,735,1079,394,6309,795,1055,2524,378,387,1034,381]}
\ No newline at end of file
+//{"start":57,"fragment_lengths":[58842,398,735,1079,394,6309,795,1055,2524,378,387,1406,381]}
\ No newline at end of file
diff --git a/api/trait.impl/core/marker/trait.UnsafeUnpin.js 
b/api/trait.impl/core/marker/trait.UnsafeUnpin.js
index 9acd37323..be2992486 100644
--- a/api/trait.impl/core/marker/trait.UnsafeUnpin.js
+++ b/api/trait.impl/core/marker/trait.UnsafeUnpin.js
@@ -1,9 +1,9 @@
 (function() {
-    var implementors = Object.fromEntries([["iceberg",[["impl UnsafeUnpin for 
<a class=\"enum\" href=\"iceberg/arrow/enum.FieldMatchMode.html\" title=\"enum 
iceberg::arrow::FieldMatchMode\">FieldMatchMode</a>",1,["iceberg::arrow::value::FieldMatchMode"]],["impl
 UnsafeUnpin for <a class=\"enum\" href=\"iceberg/enum.ErrorKind.html\" 
title=\"enum 
iceberg::ErrorKind\">ErrorKind</a>",1,["iceberg::error::ErrorKind"]],["impl 
UnsafeUnpin for <a class=\"enum\" href=\"iceberg/enum.TableRequirement [...]
+    var implementors = Object.fromEntries([["iceberg",[["impl UnsafeUnpin for 
<a class=\"enum\" href=\"iceberg/arrow/enum.FieldMatchMode.html\" title=\"enum 
iceberg::arrow::FieldMatchMode\">FieldMatchMode</a>",1,["iceberg::arrow::value::FieldMatchMode"]],["impl
 UnsafeUnpin for <a class=\"enum\" href=\"iceberg/enum.ErrorKind.html\" 
title=\"enum 
iceberg::ErrorKind\">ErrorKind</a>",1,["iceberg::error::ErrorKind"]],["impl 
UnsafeUnpin for <a class=\"enum\" href=\"iceberg/enum.TableRequirement [...]
     if (window.register_implementors) {
         window.register_implementors(implementors);
     } else {
         window.pending_implementors = implementors;
     }
 })()
-//{"start":57,"fragment_lengths":[36053,273,485,704,269,4184,545,680,1774,253,262,659,256]}
\ No newline at end of file
+//{"start":57,"fragment_lengths":[36053,273,485,704,269,4184,545,680,1774,253,262,906,256]}
\ No newline at end of file
diff --git a/api/trait.impl/core/panic/unwind_safe/trait.RefUnwindSafe.js 
b/api/trait.impl/core/panic/unwind_safe/trait.RefUnwindSafe.js
index 769ea1686..2218f20de 100644
--- a/api/trait.impl/core/panic/unwind_safe/trait.RefUnwindSafe.js
+++ b/api/trait.impl/core/panic/unwind_safe/trait.RefUnwindSafe.js
@@ -1,9 +1,9 @@
 (function() {
-    var implementors = Object.fromEntries([["iceberg",[["impl !<a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/panic/unwind_safe/trait.RefUnwindSafe.html\";
 title=\"trait core::panic::unwind_safe::RefUnwindSafe\">RefUnwindSafe</a> for 
<a class=\"struct\" 
href=\"iceberg/arrow/partition_value_calculator/struct.PartitionValueCalculator.html\"
 title=\"struct 
iceberg::arrow::partition_value_calculator::PartitionValueCalculator\">PartitionValueCalculator</a>",1,["iceberg::arrow
 [...]
+    var implementors = Object.fromEntries([["iceberg",[["impl !<a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/panic/unwind_safe/trait.RefUnwindSafe.html\";
 title=\"trait core::panic::unwind_safe::RefUnwindSafe\">RefUnwindSafe</a> for 
<a class=\"struct\" 
href=\"iceberg/arrow/partition_value_calculator/struct.PartitionValueCalculator.html\"
 title=\"struct 
iceberg::arrow::partition_value_calculator::PartitionValueCalculator\">PartitionValueCalculator</a>",1,["iceberg::arrow
 [...]
     if (window.register_implementors) {
         window.register_implementors(implementors);
     } else {
         window.pending_implementors = implementors;
     }
 })()
-//{"start":57,"fragment_lengths":[62400,446,830,1221,441,7110,891,1197,2811,425,435,1176,428]}
\ No newline at end of file
+//{"start":57,"fragment_lengths":[62400,446,830,1221,441,7110,891,1197,2811,425,435,1595,428]}
\ No newline at end of file
diff --git a/api/trait.impl/core/panic/unwind_safe/trait.UnwindSafe.js 
b/api/trait.impl/core/panic/unwind_safe/trait.UnwindSafe.js
index d69e48f77..ba928fd2a 100644
--- a/api/trait.impl/core/panic/unwind_safe/trait.UnwindSafe.js
+++ b/api/trait.impl/core/panic/unwind_safe/trait.UnwindSafe.js
@@ -1,9 +1,9 @@
 (function() {
-    var implementors = Object.fromEntries([["iceberg",[["impl !<a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/panic/unwind_safe/trait.UnwindSafe.html\";
 title=\"trait core::panic::unwind_safe::UnwindSafe\">UnwindSafe</a> for <a 
class=\"struct\" 
href=\"iceberg/arrow/partition_value_calculator/struct.PartitionValueCalculator.html\"
 title=\"struct 
iceberg::arrow::partition_value_calculator::PartitionValueCalculator\">PartitionValueCalculator</a>",1,["iceberg::arrow::partiti
 [...]
+    var implementors = Object.fromEntries([["iceberg",[["impl !<a 
class=\"trait\" 
href=\"https://doc.rust-lang.org/nightly/core/panic/unwind_safe/trait.UnwindSafe.html\";
 title=\"trait core::panic::unwind_safe::UnwindSafe\">UnwindSafe</a> for <a 
class=\"struct\" 
href=\"iceberg/arrow/partition_value_calculator/struct.PartitionValueCalculator.html\"
 title=\"struct 
iceberg::arrow::partition_value_calculator::PartitionValueCalculator\">PartitionValueCalculator</a>",1,["iceberg::arrow::partiti
 [...]
     if (window.register_implementors) {
         window.register_implementors(implementors);
     } else {
         window.pending_implementors = implementors;
     }
 })()
-//{"start":57,"fragment_lengths":[60960,437,812,1194,432,6957,873,1170,2757,416,426,1149,419]}
\ No newline at end of file
+//{"start":57,"fragment_lengths":[60960,437,812,1194,432,6957,873,1170,2757,416,426,1559,419]}
\ No newline at end of file
diff --git a/api/trait.impl/serde_core/de/trait.Deserialize.js 
b/api/trait.impl/serde_core/de/trait.Deserialize.js
index 527189832..714a82474 100644
--- a/api/trait.impl/serde_core/de/trait.Deserialize.js
+++ b/api/trait.impl/serde_core/de/trait.Deserialize.js
@@ -1,9 +1,9 @@
 (function() {
-    var implementors = Object.fromEntries([["iceberg",[["impl&lt;'de&gt; <a 
class=\"trait\" 
href=\"https://docs.rs/serde_core/1.0.228/serde_core/de/trait.Deserialize.html\";
 title=\"trait serde_core::de::Deserialize\">Deserialize</a>&lt;'de&gt; for <a 
class=\"enum\" href=\"iceberg/enum.TableRequirement.html\" title=\"enum 
iceberg::TableRequirement\">TableRequirement</a>"],["impl&lt;'de&gt; <a 
class=\"trait\" 
href=\"https://docs.rs/serde_core/1.0.228/serde_core/de/trait.Deserialize.html\";
  [...]
+    var implementors = Object.fromEntries([["iceberg",[["impl&lt;'de&gt; <a 
class=\"trait\" 
href=\"https://docs.rs/serde_core/1.0.228/serde_core/de/trait.Deserialize.html\";
 title=\"trait serde_core::de::Deserialize\">Deserialize</a>&lt;'de&gt; for <a 
class=\"enum\" href=\"iceberg/enum.TableRequirement.html\" title=\"enum 
iceberg::TableRequirement\">TableRequirement</a>"],["impl&lt;'de&gt; <a 
class=\"trait\" 
href=\"https://docs.rs/serde_core/1.0.228/serde_core/de/trait.Deserialize.html\";
  [...]
     if (window.register_implementors) {
         window.register_implementors(implementors);
     } else {
         window.pending_implementors = implementors;
     }
 })()
-//{"start":57,"fragment_lengths":[20496,5445,361]}
\ No newline at end of file
+//{"start":57,"fragment_lengths":[20496,5445,725]}
\ No newline at end of file

Reply via email to