问题描述
我目前正在尝试为 monetdb DBMS 开发附加功能。我一直在阅读代码并尝试使用 VSCODE 调试代码,这实际上工作正常。但是,我在尝试使用 Mtest.py
运行存储库中已经存在的测试时遇到了困难。
现在,我已经分叉了最新版本的 monetdb (11.40.0) 并按照随附的说明继续在我的 ubuntu 20.04 上安装它Debian 文档:
CONfigURE_OPTIONS="-DCMAKE_BUILD_TYPE=Debug -DASSERT=ON -DSTRICT=ON"
cd build
cmake $CONfigURE_OPTIONS
cmake --build .
cmake --build . --target install
以上语句将应用程序安装在默认位置。我还尝试使用 -DCMAKE_INSTALL_PREFIX
标志更改安装方向。但是,这会导致相同的结果和运行测试的问题。
为了运行特定的测试用例,我尝试了以下两件事:
- cmake:
cmake --build . --target mtest
- Mtest.py:
Mtest.py sql/test/Tests/
两次尝试都导致相同的控制台输出:
Perl available,but monetdb driver or DBI module not available
abort: there is no Mercurial repository here (.hg not found)
cannot write timeout message mserver5 --debug=10 --set gdk_nr_threads=0 --set mapi_listenaddr=all --set mapi_port=30201 --set mapi_usock=/var/tmp/mtest-16710/.s.monetdb.30201 --forcemito --dbpath=/usr/local/var/monetdb/mTests
Mtest.py: ERROR: No output from mserver5 when checking for Bits,Modules & Threads!?
它指出启动的 mserver5
实例以某种方式没有正确响应。我目前不知道如何解决这个问题。谁能告诉我我是否可能错过了什么?
我已经检查了构建标志,并且相应的 TESTING 标志已默认设置。我在 mserver5 上有什么问题吗,或者我可能需要单独配置?
期待您的回音, 马丁
解决方法
我终于找到了运行 MonetDB 测试时出现问题的原因。感谢 @Joeri van Ruth 使用 mserver5
应用程序。
问题是我在文件 _SQL_COMPILE
中的 sql_execute.sql
定义中进行了注释,以便查看生成的 MAL 代码和编译过程中生成的其他调试输出。问题在于它调用 mnstr_printf
并打印到 stdout
。此调试输出以某种方式干扰了所需的通信,mserver5
无法正确响应。