我面临的问题很小但很烦人:
一位同事正在开发版本控制系统 X (VCS-X) 中的一个项目。另一位同事正在另一个版本控制系统 Y 中工作,并使用 X 中的包。
不幸的是,VCS-X 中的同事使用本地导入并sys.path.append('trunk/my_location')
在他们的代码中修改了他的路径。
我的观点是,这是错误的做法,因为 X 中的同事强迫 Y 同事在能够运行代码之前对其进行编辑,仅仅是因为他们的 repo 命名不同。
应该如何管理这些依赖关系?
例子:
开发商 X:
>>> sys.path.append('my_repo/my_location')
>>> from my_location import toolbox
>>> nosetests -v
toolbox.test1 ... ok
toolbox.test2 ... ok
...
开发商 Y:
步骤1:
>>> nosetests -v
toolbox.test1 ... fail
...
第2步:
>>> sys.path.append('my_repo/my_location')
>>> from my_location import toolbox
Import error: No such package.
第 3 步:
>>> sys.path.append('my_colleagues_repo/my_location')
>>> from my_location import toolbox
>>> nosetests -v
toolbox.test1 ... ok
toolbox.test2 ... ok
“......叹了口气;代码正在运行......”