15. 接口开发环境搭建之Django环境搭建

项目背景

讲了Python基础、网络基础、requests库、单元测试,终于讲到接口自动化测试实战了。我们做功能测试的时候知道,一个产品基本上都会有增删改查功能,对应接口也就是增删改查接口。做了2年接口自动化测试,觉得最难的点应该是数据的初始化,其实测试一个接口、对接口使用单元测试框架、生成测试报告这些功能,可能用个1到2次就可以熟练使用了。但是数据初始化不一样。你要足够的了解业务,同时对数据库表结构有较深的理解。

在想项目的时候,第一反应就是用django搭建一个简易博客系统。因为只开发纯接口,所以花个半天不到时间就搞定增删改查功能。我们测试该博客系统接口的时候,建议配合Postman进行调试。关于Postman内容在下面会进行简单介绍。

Django介绍

Django官网地址
Django是一个开放源代码的Web应用框架,由Python写成。它最初是被开发来用于管理劳伦斯出版集团旗下的一些以新闻内容为主的网站的,即是CMS(内容管理系统)软件。这套框架是以比利时的吉普赛爵士吉他手Django Reinhardt来命名的。

简单来说,当我们想开发一个web应用的时候,我们可以使用Python。我们熟知的豆瓣、知乎都是用Python来开发的。Python下有很多框架,比如Django、 Flask、Tornado。每个框架都有不同的特色,当我们开发一个小型应用时,可以使用Flask,反之用Flask、Tornado可能会好点。关于每个框架有什么不同,有哪些优势、劣势,读者朋友可以自己去网上进行了解。

Django环境搭建

因为我们已经安装了Python3,Python3自带pip,所以我们只需要使用pip进行安装就可以了。我们打开cmd命令窗口,输入如下命令:pip install django==2.1.4,我们安装指定版本Django,当然如果我们不指定版本号,那么是安装最新版本。安装成功如下图所示:

《15. 接口开发环境搭建之Django环境搭建》

创建项目与应用

创建项目

如果你想把你的项目放在D盘,请在D盘打开cmd命令窗口(按住shift+鼠标右键)。输入django-admin,出现如下内容

D:\>django-admin

Type 'django-admin help <subcommand>' for help on a specific subcommand.

Available subcommands:

[django]
    check
    compilemessages
    createcachetable
    dbshell
    diffsettings
    dumpdata
    flush
    inspectdb
    loaddata
    makemessages
    makemigrations
    migrate
    runserver
    sendtestemail
    shell
    showmigrations
    sqlflush
    sqlmigrate
    sqlsequencereset
    squashmigrations
    startapp
    startproject
    test
    testserver
Note that only Django core commands are listed as settings are not properly configured (error: Requested setting INSTALLED_APPS, but
settings are not configured. You must either define the environment variable DJANGO_SETTINGS_MODULE or call settings.configure() befo
re accessing settings.).

我们使用startproject命令来创建项目,项目命名为blog。D:\>django-admin startproject blog
我们用pycharm打开blog(FileOpen),项目结构如下:

《15. 接口开发环境搭建之Django环境搭建》

结构介绍

  • blog/init.py: 一个空的文件, 用它标识一个目录为 Python 的标准包。
  • blog/settings.py: Django 项目的配置文件, 包括 Django 模块应用配置, 数据库配置, 模板配置等。
  • blog/urls.py: Django 项目的 URL 声明。
  • blog/wsgi.py: 为 WSGI 兼容的 Web 服务器服务项目的切入点。
  • manage.py: 一个命令行工具, 可以让你在使用 Django 项目时以不同的方式进行交互。

创建应用

我们使用cd命令进入blog目录,然后输入python manage.py(注意,我把python重命名为python3,你们输入python即可),出现如下内容:

D:\>cd blog
D:\blog>python3 manage.py 
Type 'manage.py help <subcommand>' for help on a specific subcommand.

Available subcommands:

[auth]
    changepassword
    createsuperuser

[contenttypes]
    remove_stale_contenttypes

[django]
    check
    compilemessages
    createcachetable
    dbshell
    diffsettings
    dumpdata
    flush
    inspectdb
    loaddata
    makemessages
    makemigrations
    migrate
    sendtestemail
    shell
    showmigrations
    sqlflush
    sqlmigrate
    sqlsequencereset
    squashmigrations
    startapp
    startproject
    test
    testserver

[sessions]
    clearsessions

[staticfiles]
    collectstatic
    findstatic
    runserver 

我们使用startapp命令来创建应用,应用命名为article。D:\blog>python3 manage.py startapp article
我们重新查看pycharm中blog项目目录,会发现目录发生了一些改变。

《15. 接口开发环境搭建之Django环境搭建》

结构介绍

  • migrations/: 用于记录 models 中数据的变更。
  • admin.py: 映射 models 中的数据到 Django 自带的 admin 后台。
  • apps.py: 在新的 Django 版本中新增, 用于应用程序的配置。
  • models.py: 创建应用程序数据表模型(对应数据库的相关操作) 。
  • tests.py: 创建 Django 测试。
  • views.py: 控制向前端显示哪些数据。

运行Hello World

1.我们打开settings.py,修改INSTALLED_APPS,增加一行’article’,如下代码所示:

《15. 接口开发环境搭建之Django环境搭建》

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'article',  # 新增
]

2.打开urls.py,输入如下代码:

from django.contrib import admin
from django.urls import path
from article import views #新增

urlpatterns = [
    path('admin/', admin.site.urls),
    path('index/', views.index), #新增

]

3.在article应用下面创建 templates/hello.html 文件,hello.html输入hello world,注意templates是固定写法,如下图所示:

《15. 接口开发环境搭建之Django环境搭建》

  1. 打开views.py,输入如下代码:
from django.http import HttpResponse 
from django.shortcuts import render


# Create your views here.

def index(request):
    return render(request, "hello.html")
  1. 我们当前还在blog目录,在cmd窗口输入python manage.py runserver,如下内容所示:
D:\blog>python3 manage.py runserver
Performing system checks...

System check identified no issues (0 silenced).

You have 15 unapplied migration(s). Your project may not work properly until you …ttypes, sessions.
Run 'python manage.py migrate' to apply them.
January 16, 2019 - 16:39:20
Django version 2.1.4, using settings 'blog.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CTRL-BREAK.
  1. 浏览器访问http://127.0.0.1:8000/index/,出现下图所示,说明访问成功。
    《15. 接口开发环境搭建之Django环境搭建》

小结:想想看,我们做了啥 。我们首先通过django-admin blog创建一个blog项目,然后使用python manage.py startapp article创建一个应用。修改了settings.py目的是为了添加article应用,然后修改url.py,是为了新增一个请求地址,通过该请求地址,指向index函数。那么为什么会返回hello world呢?因为我们的index函数指向了hello.html文件。流程如下:

《15. 接口开发环境搭建之Django环境搭建》

欢迎关注微信公众号:软件测试汪。软件测试交流群:809111560

    原文作者:软件测试汪
    原文地址: https://www.jianshu.com/p/31574a45ea09
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞