作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个从虚拟环境运行的 Django 应用程序。我正在编写一个 bash 脚本来测试虚拟环境。postgresql 用户名和密码是虚拟环境中的环境变量,Django 将其拉入settings.py
。
为了测试与数据库的连接,我写了如下内容:
echo -n 'Testing database connection ...'
export COMMAND="from psycopg2 import connect; import sys; c=connect(dbname='myappdb',\
user='$POSTGRESQL_USER', password='$POSTGRESQL_PWD', host='127.0.0.1', port=5432); \
sys.exit(c.closed)"
test `python -c "$COMMAND" 2>/dev/null && echo true `
其中 test 是一个函数:
function test {
[ $1 ] && echo "[OK]" || echo "[FAIL]"
}
似乎即使使用错误的凭据,也不会引发异常并且 c.closed
始终为零。有什么方法可以测试凭据在虚拟环境中是否正确?
最佳答案
它是 bash,不是 python,所以不确定它是否适合您的需要:
vao@vao-X102BA:~$ psql -d "postgresql://p:goodpassword@localhost/t" -c "select now()"
now
-------------------------------
2017-07-14 11:42:40.712981+03
(1 row)
vao@vao-X102BA:~$ echo $?
0
vao@vao-X102BA:~$ psql -d "postgresql://p:badpassword@localhost/t" -c "select now()"
psql: FATAL: password authentication failed for user "p"
FATAL: password authentication failed for user "p"
vao@vao-X102BA:~$ echo $?
2
如果你想抑制输出,而不是 select now()
,你可以使用 -c "\q"
退出
关于django - 如何从 bash 测试 postgresql 凭据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45097992/
我是一名优秀的程序员,十分优秀!