使用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)
相关推荐
Mr.Jessy5 分钟前
Web APIs 学习第五天:日期对象与DOM节点
开发语言·前端·javascript·学习·html
杨福瑞10 分钟前
数据结构:单链表(2)
c语言·开发语言·数据结构
进化中的码农10 分钟前
Go中的泛型编程和reflect(反射)
开发语言·笔记·golang
音符犹如代码1 小时前
Java并发List实战:CopyOnWriteArrayList原理与ArrayList常见面试题
java·开发语言·面试·list
又是忙碌的一天1 小时前
抽象类和接口
java·开发语言
亮剑20181 小时前
第2节:程序逻辑与控制流——让程序“思考”
开发语言·c++·人工智能
lly2024061 小时前
Go 语言接口
开发语言
霜绛1 小时前
C#知识补充(二)——命名空间、泛型、委托和事件
开发语言·学习·unity·c#
Dxxyyyy1 小时前
零基础学JAVA--Day26(枚举类)
java·开发语言
大鱼七成饱1 小时前
读懂 Pin,一次搞清 Rust 最难的指针
rust