无法在 MonetDB

问题描述

我目前正在尝试为 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 无法正确响应。