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><<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><dyn EngineRunner>>,
steps: <a class="struct"
href="https://doc.rust-lang.org/nightly/alloc/vec/struct.Vec.html"
title="struct alloc::vec::Vec">Vec</a><<a class="struct"
href="struct.Step.html" title="struct
iceberg_sqllogictest::schedule::Step">Step</a>>,
schedule_file: <a class="struct"
href="https://doc.rust-lang.org/nightly/alloc/string/struct.String.html"
title="struct alloc::string::String">String</a>,
-) -> 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><P: <a class="trait"
href="https://doc.rust-lang.org/nightly/core/convert/trait.AsRef.html"
title="trait core::convert::AsRef">AsRef</a><<a class="struct"
href="https://doc.rust-lang.org/nightly/std/path/struct.Path.html" title= [...]
+) -> 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><P: <a class="trait"
href="https://doc.rust-lang.org/nightly/core/convert/trait.AsRef.html"
title="trait core::convert::AsRef">AsRef</a><<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>(&self) -> &(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><'de>,</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><<a
class="struct"
href="https://doc.rust-lang.org/nightly/alloc/string/struct.String.html"
title="struct alloc::string::String">String</a>, EngineConfig>,
+ pub steps: <a class="struct"
href="https://doc.rust-lang.org/nightly/alloc/vec/struct.Vec.html"
title="struct alloc::vec::Vec">Vec</a><<a class="struct"
href="struct.Step.html" title="struct
iceberg_sqllogictest::schedule::Step">Step</a>>,
+}</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><<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><<a class="struct"
href="struct.Step.html" title="struct
iceberg_sqllogictest::schedule::Step">Step</a>></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><'de>,</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>(&self) -> &(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><'de>,</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><'de>,</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>(&self) -> &(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">&mut </span><span
class="self">self</span>, path: <span class="kw-2">&</span>Path) ->
<span class="prelude-ty">Result</span><()> {
-<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) -> <span
class="prelude-ty">Result</span><<span class="self">Self</span>> {
-<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">&</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">&</span>TomlTable) -> anyhow::Result<Arc<<span
class="kw">dyn </span>CatalogProvider>> {
-<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">&</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">&mut </span><span
class="self">self</span>, path: <span class="kw-2">&</span>Path) ->
<span class="prelude-ty">Result</span><()> {
+<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><DatafusionCatalogConfig>) -> <span
class="prelude-ty">Result</span><<span class="self">Self</span>> {
+<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><<span
class="kw-2">&</span>DatafusionCatalogConfig>,
+<a href=#79 id=79 data-nosnippet>79</a> ) ->
anyhow::Result<Arc<<span class="kw">dyn </span>CatalogProvider>> {
+<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">&</span>catalog, <span
class="kw-2">&</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">&</span>catalog, <span
class="kw-2">&</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">&</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">&</span><span class="kw">impl </span>Catalog,
-<a href=#105 id=105 data-nosnippet>105</a> namespace: <span
class="kw-2">&</span>NamespaceIdent,
-<a href=#106 id=106 data-nosnippet>106</a> ) -> anyhow::Result<()>
{
-<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">&</span><span class="kw">impl </span>Catalog,
-<a href=#132 id=132 data-nosnippet>132</a> namespace: <span
class="kw-2">&</span>NamespaceIdent,
-<a href=#133 id=133 data-nosnippet>133</a> ) -> anyhow::Result<()>
{
-<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">&</span>catalog, <span
class="kw-2">&</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">&</span>catalog, <span
class="kw-2">&</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">&</span><span class="kw">impl </span>Catalog,
+<a href=#109 id=109 data-nosnippet>109</a> namespace: <span
class="kw-2">&</span>NamespaceIdent,
+<a href=#110 id=110 data-nosnippet>110</a> ) -> anyhow::Result<()>
{
+<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">&</span><span class="kw">impl </span>Catalog,
+<a href=#136 id=136 data-nosnippet>136</a> namespace: <span
class="kw-2">&</span>NamespaceIdent,
+<a href=#137 id=137 data-nosnippet>137</a> ) -> anyhow::Result<()>
{
+<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">&</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">&mut </span><span
class="self">self</span>, path: <span class="kw-2">&</span>Path) ->
<span class="prelude-ty">Result</span><()>;
-<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">&</span>str,
-<a href=#38 id=38 data-nosnippet>38</a> cfg: TomlTable,
-<a href=#39 id=39 data-nosnippet>39</a>) -> <span
class="prelude-ty">Result</span><Box<<span class="kw">dyn
</span>EngineRunner>> {
-<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 => <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>=>
<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<D, M>(
-<a href=#47 id=47 data-nosnippet>47</a> <span class="kw-2">mut
</span>runner: Runner<D, M>,
-<a href=#48 id=48 data-nosnippet>48</a> step_slt_file: <span
class="kw">impl </span>AsRef<Path>,
-<a href=#49 id=49 data-nosnippet>49</a>) -> <span
class="prelude-ty">Result</span><()>
-<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<Conn = D> +
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">&</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<String, String>,
+<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><DatafusionCatalogConfig>,
+<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">&mut </span><span
class="self">self</span>, path: <span class="kw-2">&</span>Path) ->
<span class="prelude-ty">Result</span><()>;
+<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) -> <span
class="prelude-ty">Result</span><Box<<span class="kw">dyn
</span>EngineRunner>> {
+<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 } => <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<D, M>(
+<a href=#63 id=63 data-nosnippet>63</a> <span class="kw-2">mut
</span>runner: Runner<D, M>,
+<a href=#64 id=64 data-nosnippet>64</a> step_slt_file: <span
class="kw">impl </span>AsRef<Path>,
+<a href=#65 id=65 data-nosnippet>65</a>) -> <span
class="prelude-ty">Result</span><()>
+<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<Conn = D> +
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">&</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) } => {
+<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">&</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>=> <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">&</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<String,
Box<<span class="kw">dyn </span>EngineRunner>>,
-<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<Step>,
-<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<String, EngineConfig>,
+<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<Step>,
+<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<String,
Box<<span class="kw">dyn </span>EngineRunner>>,
+<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<Step>,
+<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<String,
Box<<span class="kw">dyn </span>EngineRunner>>,
-<a href=#49 id=49 data-nosnippet>49</a> steps: Vec<Step>,
-<a href=#50 id=50 data-nosnippet>50</a> schedule_file: String,
-<a href=#51 id=51 data-nosnippet>51</a> ) -> <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<P: AsRef<Path>>(path: P) ->
anyhow::Result<<span class="self">Self</span>> {
-<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::<Value>()<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<String,
Box<<span class="kw">dyn </span>EngineRunner>>,
+<a href=#57 id=57 data-nosnippet>57</a> steps: Vec<Step>,
+<a href=#58 id=58 data-nosnippet>58</a> schedule_file: String,
+<a href=#59 id=59 data-nosnippet>59</a> ) -> <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>) ->
anyhow::Result<()> {
-<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<P: AsRef<Path>>(path: P) ->
anyhow::Result<<span class="self">Self</span>> {
+<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">&</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">&</span>step.engine,
-<a href=#82 id=82 data-nosnippet>82</a> <span
class="kw-2">&</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<String,
EngineConfig>,
+<a href=#82 id=82 data-nosnippet>82</a> ) ->
anyhow::Result<HashMap<String, Box<<span class="kw">dyn
</span>EngineRunner>>> {
+<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">&</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">&</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>) ->
anyhow::Result<()> {
+<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">&</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">&</span>step.engine,
-<a href=#103 id=103 data-nosnippet>103</a> <span
class="kw-2">&</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">&</span>TomlTable,
-<a href=#111 id=111 data-nosnippet>111</a> ) ->
anyhow::Result<HashMap<String, Box<<span class="kw">dyn
</span>EngineRunner>>> {
-<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">&</span>step.engine,
+<a href=#102 id=102 data-nosnippet>102</a> <span
class="kw-2">&</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">&</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">&</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">&</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">&</span>TomlTable) ->
anyhow::Result<Vec<Step>> {
-<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<Step> = 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">&</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">&</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">&</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">&</span>step.engine,
+<a href=#123 id=123 data-nosnippet>123</a> <span
class="kw-2">&</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">&</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) } => {
+<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">&</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>=> <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><ScheduleConfig, <span
class="kw">_</span>> = 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><ScheduleConfig, <span
class="kw">_</span>> = 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><ScheduleConfig, <span
class="kw">_</span>> = 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<'de> <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><'de> for <a
class=\"enum\" href=\"iceberg/enum.TableRequirement.html\" title=\"enum
iceberg::TableRequirement\">TableRequirement</a>"],["impl<'de> <a
class=\"trait\"
href=\"https://docs.rs/serde_core/1.0.228/serde_core/de/trait.Deserialize.html\"
[...]
+ var implementors = Object.fromEntries([["iceberg",[["impl<'de> <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><'de> for <a
class=\"enum\" href=\"iceberg/enum.TableRequirement.html\" title=\"enum
iceberg::TableRequirement\">TableRequirement</a>"],["impl<'de> <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