我有一个测试:
cc_test(
name = "common_test",
linkstatic = 1,
srcs = glob([
"common/test/*.cpp",
]),
linkopts = [
"-L/usr/local/lib",
"-L/usr/lib64",
"-g",
"-lcppunit",
"-ldl",
"-lz",
"-ltbb",
"-llz4",
],
data= [
"@:testdata"
]
)
我的testdata定义于:
filegroup(
name = "testdata",
srcs = glob([
"testdata/biz_test/*.json",
]),
visibility = ["//visibility:public"]
)
TEST_PATH来到这里:
TESTBASE_BASE() {
char cwdBuf[10240];
if (getcwd(cwdBuf, 10240) == NULL) {
std::cerr << "get cwd failed, error:" << strerror(errno) << std::endl;
assert(false);
}
_testRootPath = cwdBuf;
}
std::string GET_TEST_DATA_PATH(std::string bazelTestPath = "") const {
return _testRootPath + bazelTestPath + std::string("/testdata/");
}
在我的测试代码中:
GET_TEST_DATA_PATH() +"/biz_info_test/" can't find the testdata
GET_TEST_DATA_PATH('/external/my_project') +"/biz_info_test/" is ok
因为我有很多项目需要更改为bazel编译,我需要一种更通用的方法来解决testdata路径问题。我不想写这样的代码:
GET_TEST_DATA_PATH('/external/my_project1') +"/biz_info_test/"
GET_TEST_DATA_PATH('/external/my_project2') +"/biz_info_test/"
GET_TEST_DATA_PATH('/external/my_project3') +"/biz_info_test/"
我希望bazel可以这样做: 它可以找到我的WORKSPACE目录。
my_pj/
├── my_pj
│ └── BUILD
├── testdata
└── WORKSPACE
so my testdata dir is: _testRootPath + std::string("/testdata/")
答案 0 :(得分:0)
这是一个已知问题,我们正在努力改变它以符合您的期望。不幸的是,这是一个艰难的变化,因为它会影响Bazel构建的所有项目(包括Google的所有项目)。