使用DeepSeek辅助测试一个rust编写的postgresql协议工具包convergence

convergence是rust编写支持postgresql协议的工具包。

它的convergence/convergence-arrow/examples/datafusion.rs是一个支持datafusion后台数据引擎DeepSeek的简易服务器示例程序。

通过询问DeepSeek,我知道了怎么运行这个示例。

Rust 项目中的 examples 目录通常用于存放示例代码,这些示例展示了如何使用你这个库(在这里是 convergence-arrow)的功能。

可以在这个项目下的任何目录中运行cargo run --example datafusion, Cargo 会自动识别。但是因为它又依赖一个csv文件,所以还是要在正确的目录下执行,否则会报文件不存在的错误。

bash 复制代码
/par/convergence/convergence-arrow# cargo run --example datafusion
   Compiling convergence-arrow v0.17.1 (/par/convergence/convergence-arrow)
    Finished `dev` profile [unoptimized + debuginfo] target(s) in 56.39s
     Running `/par/convergence/target/debug/examples/datafusion`

thread 'tokio-runtime-worker' panicked at convergence-arrow/examples/datafusion.rs:33:6:
failed to register csv: ObjectStore(NotFound { path: "/par/convergence/convergence-arrow/convergence-arrow/data/100_4buckets.csv", source: Os { code: 2, kind: NotFound, message: "No such file or directory" } })
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace

改到上一级目录执行,就不报错了。

bash 复制代码
/par/convergence/convergence-arrow# cd ..
/par/convergence# cargo run --example datafusion
    Finished `dev` profile [unoptimized + debuginfo] target(s) in 3.44s
     Running `target/debug/examples/datafusion`

thread 'tokio-runtime-worker' panicked at /par/convergence/convergence/src/server.rs:52:27:
called `Result::unwrap()` on an `Err` value: ConnectionClosed
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace

thread 'tokio-runtime-worker' panicked at /par/convergence/convergence/src/server.rs:52:27:
called `Result::unwrap()` on an `Err` value: ConnectionClosed

thread 'tokio-runtime-worker' panicked at /par/convergence/convergence/src/server.rs:52:27:
called `Result::unwrap()` on an `Err` value: ConnectionClosed

另开一个终端,沿用我们的postgresql协议客户端工具pgproto,一开始脚本中的表不存在就报错,后来改成查询示例中注册的test_100_4buckets表(其实是datafusion访问data/100_4buckets.csv文件),就能查询出结果了。

bash 复制代码
/par/pgproto/src# ./pgproto -h 127.0.0.1 -p 5432 -f /par/pgpo2.txt
Failed to connect to host=127.0.0.1 port=5432.
/par/pgproto/src# ./pgproto -h 127.0.0.1 -p 5432 -f /par/pgpo2.txt
FE=> Query (query="SELECT * FROM foods where category='meat' limit 2")
<= BE ErrorResponse(C 22000 S ERROR M Error during planning: table 'datafusion.public.foods' not found )
<= BE ReadyForQuery(I)

/par/pgproto/src# ./pgproto -h 127.0.0.1 -p 5432 -f /par/pgpo3.txt
FE=> Query (query="select count(*) from test_100_4buckets")
<= BE RowDescription
解析出的字段名:
字段数量: 1
字段 1: count(*)
<= BE DataRow
100
<= BE CommandComplete(SELECT 1)
<= BE ReadyForQuery(I)
FE=> Query (query="select bucket, count(*) from test_100_4buckets group by bucket order by bucket")
<= BE RowDescription
解析出的字段名:
字段数量: 2
字段 1: bucket
字段 2: count(*)
<= BE DataRow
a|25
<= BE DataRow
b|25
<= BE DataRow
c|25
<= BE DataRow
d|25
<= BE CommandComplete(SELECT 4)
<= BE ReadyForQuery(I)

除了运行example, 还可以运行test, 可以test一个文件,

bash 复制代码
cargo test --test test_datafusion
   Compiling convergence-arrow v0.17.1 (/par/convergence/convergence-arrow)
    Finished `test` profile [unoptimized + debuginfo] target(s) in 2m 34s
     Running tests/test_datafusion.rs (target/debug/deps/test_datafusion-5bfe2727a2979e23)

running 2 tests
test count_rows ... ok
test grouped_counts ... ok

也可以test一个函数, cargo会自动在各个文件中找这个函数。

bash 复制代码
/par/convergence# cargo test count_rows
   Compiling convergence-arrow v0.17.1 (/par/convergence/convergence-arrow)
    Finished `test` profile [unoptimized + debuginfo] target(s) in 2m 12s
     Running unittests src/lib.rs (target/debug/deps/convergence-59c3fb083bdbbb67)

running 0 tests

test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s

     Running tests/test_connection.rs (target/debug/deps/test_connection-96a75e35b0056308)

running 0 tests

test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 6 filtered out; finished in 0.00s

     Running unittests src/lib.rs (target/debug/deps/convergence_arrow-a62e8f28e1b474cd)

running 0 tests

test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s

     Running tests/test_arrow.rs (target/debug/deps/test_arrow-cfca8d83e13540b8)

running 0 tests

test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 1 filtered out; finished in 0.00s

     Running tests/test_datafusion.rs (target/debug/deps/test_datafusion-5bfe2727a2979e23)

running 1 test
test count_rows ... ok

test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 1 filtered out; finished in 1.73s

这个工具包的功能还不完善,create table语句就不能成功,统一返回一个表已存在的错误

bash 复制代码
/par/pgproto/src# ./pgproto -h 127.0.0.1 -p 5432 -f /par/pgpo4.txt
FE=> Query (query="create table test(i int, j varchar(10))")
<= BE ErrorResponse(C 22000 S ERROR M Execution error: Table 'test' already exists )
<= BE ReadyForQuery(I)
FE=> Query (query="create table test1(i int, j varchar(10))")
<= BE ErrorResponse(C 22000 S ERROR M Execution error: Table 'test1' already exists )
<= BE ReadyForQuery(I)
相关推荐
小卡皮巴拉3 小时前
【笔试强训】Day1
开发语言·数据结构·c++·算法
步行cgn3 小时前
HttpSessionBindingListener
java·开发语言·数据仓库·servlet
Kiri霧3 小时前
Rust数组与向量
开发语言·后端·rust
特立独行的猫a3 小时前
Rust语言入门难,难在哪?所有权、借用检查器、生命周期和泛型介绍
开发语言·后端·rust
JC033 小时前
JAVA解题——求阶乘和(附源代码)
java·开发语言·算法
psgogogo20254 小时前
Apache POI:Java操作Office文档的利器
java·开发语言·其他·apache
向前跑丶加油4 小时前
IDEA lombok注解无效的问题,运行时提示java: 找不到符号或者方法
java·开发语言·intellij-idea
IvanCodes4 小时前
七、Scala 包、样例类与样例对象
大数据·开发语言·scala
浩浩kids4 小时前
Scala • basis
java·开发语言·scala