1

我已经在 Azure 上设置了一个构建管道来执行 pytests 等。此外,我还想检查是否没有错过任何迁移。

运行alembic命令--autogenerate将生成一个新的迁移文件,以防它尚不存在。

单独执行修订命令时

 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"
4

1 回答 1

1

鉴于我们在讨论中发现 alembic 输出将发送到 stderr 而不是 stdout,这将做我认为你想要的:

[[ $(alembic revision --autogenerate 2>&1 | grep '^[[:blank:]]*Generating.*done[[:blank:]]*$') ]] && echo "test"

如果这仍然不是您想要的,请再次编辑您的问题以进一步澄清。

于 2019-04-11T04:41:45.993 回答