烧瓶测试:self.client.delete()返回200,但失败,因为他没有删除任何内容

时间:2018-12-27 20:52:32

标签: python flask sqlalchemy python-unittest flask-testing

我有一个使用SQL Alchemy和Postgresql的CRUD足球烧瓶应用程序。 我正在尝试通过unittest和flask-testing对其进行测试,但是当我测试播放器上的删除和补丁请求(基于其编号)时,返回的状态为200,但未从数据库中删除该播放器,因此测试失败

我的app.py:

app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI']='postgresql://postgres:password@localhost:5432/flask-sql-alchemy'
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
db = SQLAlchemy(app)
modus = Modus(app)


class om_player(db.Model):

    __tablename__ = "players"

    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.Text)
    number = db.Column(db.Integer)
    age = db.Column(db.Integer)

    def __init__(self, name, number, age):
        self.name = name
        self.number = number
        self.age = age

@app.route('/joueurs/<int:number>', methods=["GET", "PATCH", "DELETE"])
def show(number):
    found_player = om_player.query.filter_by(number=number).first()

    if request.method == b"PATCH":
        found_player.name = request.form['name']
        found_player.number = request.form['number']
        found_player.age = request.form['age']
        db.session.add(found_player)
        db.session.commit()
        return redirect(url_for('show', number=request.form['number']))
    if request.method == b"DELETE":
        db.session.delete(found_player)
        db.session.commit()
        return redirect(url_for('joueurs'))
    return render_template('show.html', player=found_player)

我的test.py:

from app import app,db, om_player
from flask_testing import TestCase
import unittest

class BaseTestCase(TestCase):
    def create_app(self):
        app.config['SQLALCHEMY_DATABASE_URI'] = 'postgresql://postgres:password@localhost:5432/flask-sql-alchemy'
        app.config['PRESERVE_CONTEXT_ON_EXCEPTION'] = False
        return app

    def test_delete(self):
        response = self.client.delete('/joueurs/18', follow_redirects=True)
        self.assertEqual(response.status_code, 200)
        self.assertNotIn(b"AMAVI", response.data)


if __name__ == '__main__':
    unittest.main()

(joueurs表示法语中的玩家)

当我运行python test.py时:

AssertionError:在b'my edit.html文件中意外发现了b'AMAVI'

因此编号为18且名为“ AMAVI”的播放器不会被删除,我也不明白为什么会这样,因为删除请求返回200,并且我的应用在本地服务器上运行正常。

1 个答案:

答案 0 :(得分:0)

如果您使用的是Python3,则b"PATCH"b"DELETE"不再能满足您的期望。这些测试无法通过“ POST”测试,并陷入默认的“ GET”情况。

评估

"POST" == b"POST"

在Python3 REPL中进行确认。