专栏首页自动化测试实战Flask第五篇——设置debug模式

Flask第五篇——设置debug模式

flask默认是没有开启debug模式的,开启debug模式有很多好处:

第一,可以帮助我们查找代码里面的错误,比如:

# coding: utf-8

from flask import Flask

# __name__是用来确定flask运行的主文件
app = Flask(__name__)

@app.route('/')

def hello_world():
    x = 10
    y = 0
    res = x/y
    print res
    return 'Hello World!'

if __name__ == '__main__':
    app.run()

我们都知道,除数是不能为0的,但是上面的代码里y的值是0,我们运行这段代码,然后去地址查看,只能看到内部服务错误,但是没有任何错误原因的说明,我们找起原因就会非常费劲:

除了方便找到bug以外,还有另一个原因促使我们开启debug模式,就是如果我们不开启debug模式,我们修改了上面代码里y的值不等于0,然后ctrl+s保存代码,去页面刷新页面仍然是上图,也就是说Ctrl+s没有重新加载代码的运行,如果我们每次修改代码都要重新运行代码才能看到结果,是不是非常的不方便呢?以上两个原因,让我们需要开启debug模式:

开启debug模式只需要我们加一句app.debug = True即可。重新运行代码以后我们发现控制台输出的内容也和之前不一样了,系统会提示你重启了服务并且开启了debug模式。

现在去刷新页面,会发现页面提示了我们报错的原因:

而且在报错的最下面可以看到代码报错的位置和原因:

现在我们来说一下控制台输出的最后一行的PIN码:

我们先来到报错页面代码报错的位置,将鼠标放在报错语句上会看到后面有一个命令行样子的图标:

现在点击那个图标:

会发现页面弹出了这么一个框:

上面说着(翻译):控制台被锁定,需要输入PIN来解锁。PIN已经在你运行服务(就是你的代码)的shell(就是工具,我们用的是pychram)标准输出里打印出来了,你可以在那里找到它。

我们把PIN码粘贴过去就能看到:

我们可以直接在这里调试了,我们需要看一下y的值是不是真的是0,我们print y一下:

这样就快速的定位到了问题的所在了。而且这个PIN值是不需要你每次都输入的,你只要输入一次,8小时以内都不需要再次输入的,因为flask会生成一个cookie信息,记录你的登录状态。

当然开启debug模式并不是只有上面一种方式:

  • app.run(debug=True)
# coding: utf-8

from flask import Flask

# __name__是用来确定flask运行的主文件
app = Flask(__name__)

# 开启debug模式方法一
# app.debug = True

@app.route('/')
def hello_world():
    x = 10
    y = 0
    res = x/y
    print res
    return 'Hello World!'

if __name__ == '__main__':    
    # 开启debug模式方法二
    app.run(debug=True)
  • 第三种开启debug的方法是通过配置文件

app.config.update(DEBUG=True)

注意Debug必须要大写哦

# coding: utf-8

from flask import Flask

# __name__是用来确定flask运行的主文件
app = Flask(__name__)

app.config.update(DEBUG=True)

@app.route('/')
def hello_world():
    x = 10
    y = 0
    res = x/y
    print res
    return 'Hello World!'

if __name__ == '__main__':
    app.run()
  • 第四种开启方式——加载文件

我们新建一个名为configs的py文件,内面写:

# coding: utf-8
DEBUG = True

然后在代码里先导入import configs再引用这个文件

app.config.from_object(configs)Ctrl+s保存就会看到设置生效了:

代码如下:

# coding: utf-8

from flask import Flask
import configs

# __name__是用来确定flask运行的主文件
app = Flask(__name__)

app.config.from_object(configs)

@app.route('/')
def hello_world():
    x = 10
    y = 0
    res = x/y
    print res
    return 'Hello World!'

if __name__ == '__main__':
    app.run()

此外,如果你不导入import configsconfigs文件想用配置,那你也可以将上面代码里的app.config.from_object(configs)修改为

app.config.from_object('configs')就是加个引号,这样也是可以的:

虽然方式有这么多,但是我们还是习惯第一种最简单直接的方式——

app.debug=True

本文分享自微信公众号 - 自动化测试实战(gh_839e78b6ba28),作者:孟船长

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2018-03-03

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 《软件测试52讲》总结-01

    作为测试工程师,大家设计测试用例的目标是保证系统在各种应用场景下的功能是符合设计要求,所以大家在设计测试用例的时候就需要保证用例覆盖尽可能的更多、更全面。以“用...

    用户2149234
  • 接口测试框架分析

    用户2149234
  • 《selenium2 python 自动化测试实战》(13)——上传文件

    用户2149234
  • 微信小程序云开发数据库操作更新记录

    王小婷
  • 微信小程序云开发数据库操作查询记录

    数据库操作参考API:https://developers.weixin.qq.com/miniprogram/dev/wxcloud/reference-cl...

    王小婷
  • Yii 框架应用(Applications)操作实例详解

    本文实例讲述了Yii 框架应用(Applications)操作。分享给大家供大家参考,具体如下:

    砸漏
  • Flask视图_

    版权声明:Copyright © ...

    zhengzongwei
  • Android app 功能代码覆盖率--Jacoco(二)

    1.在项目根目录下,进入dos,运行:gradlew.bat jacocoInit,会再app下生成code-voerage文件夹

    厦门-安仔
  • 如何使用mybatis逆向生成工具

    剽悍一小兔
  • [738]Flask集成sentry实现错误监控

    sentry是个开源的实时错误报告工具,支持 web 前后端、移动应用以及游戏,支持 Python、OC、Java、Go、Node、Django、RoR 等主流...

    周小董

扫码关注云+社区

领取腾讯云代金券