我已经在Azure上设置了一个构建管道来执行pytest之类的。此外,我还想检查是否没有错过任何迁移。
在--autogenerate中运行alembic命令将生成一个新的迁移文件,以防它还不存在。
当单独执行修订命令时
alembic revision --autogenerate输出如下所示(1)
INFO [alembic.runtime.migration] Will assume transactional DDL.
INFO [alembic.ddl.postgresql] Detected sequence ...
INFO [alembic.ddl.postgresql] Detected sequence ...
INFO [alembic.ddl.postgresql] Detected sequence ...
INFO [alembic.autogenerate.compare] Detected added column ...
Generating /.../alembic/versions/dc3dae7487df_.py ... done我已经试过了,检查如下
[[ $(alembic revision --autogenerate | grep "^Generating.*done$") ]] && echo "test"但是,grep似乎不能处理alembic输出,因为即使生成了新的迁移文件,我也从未收到过echo test。
运行命令
alembic revision --autogenerate | grep 'Generating.*done' | cat -v生成输出,如(1)所示。
更改正则表达式也不会得到预期的结果
[[ $(alembic revision --autogenerate | grep "^[[:blank:]]*Generating.*done\r$") ]] && echo "test"发布于 2019-04-11 12:41:46
在我们的讨论中,我们发现alembic输出将是stderr而不是stdout,我认为这将执行您想要的操作:
[[ $(alembic revision --autogenerate 2>&1 | grep '^[[:blank:]]*Generating.*done[[:blank:]]*$') ]] && echo "test"如果这仍然不是你想要的,那么再次编辑你的问题以进一步澄清。
https://stackoverflow.com/questions/55624713
复制相似问题