Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
Python-100-Days
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
huangkq
Python-100-Days
Commits
60986aa6
Commit
60986aa6
authored
Jun 13, 2018
by
jackfrued
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
修复了文档中的bug
parent
d4d159d1
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
76 additions
and
1 deletion
+76
-1
Web前端概述.md
Day21-30/Web前端概述.md
+5
-0
05.解析动态内容.md
Day66-75/05.解析动态内容.md
+2
-0
README.md
README.md
+1
-1
selenium-ide.png
res/selenium-ide.png
+0
-0
关于测试.md
关于测试.md
+68
-0
No files found.
Day21-30/Web前端概述.md
View file @
60986aa6
...
@@ -286,6 +286,7 @@
...
@@ -286,6 +286,7 @@
-
从CDN加载jQuery
-
从CDN加载jQuery
```
HTML
```
HTML
<script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
<script>
<script>
window.jQuery ||
window.jQuery ||
...
@@ -334,6 +335,7 @@
...
@@ -334,6 +335,7 @@
#### 检测页面是否可用
#### 检测页面是否可用
```
HTML
```
HTML
<script>
<script>
$(document).ready(function() {
$(document).ready(function() {
...
@@ -342,6 +344,7 @@
...
@@ -342,6 +344,7 @@
```
```
```
HTML
```
HTML
<script>
<script>
$(function() {
$(function() {
...
@@ -361,6 +364,7 @@
...
@@ -361,6 +364,7 @@
先引入其他库再引入jQuery的情况。
先引入其他库再引入jQuery的情况。
```
HTML
```
HTML
<script src="other.js"></script>
<script src="other.js"></script>
<script src="jquery.js"></script>
<script src="jquery.js"></script>
<script>
<script>
...
@@ -374,6 +378,7 @@
...
@@ -374,6 +378,7 @@
先引入jQuery再引入其他库的情况。
先引入jQuery再引入其他库的情况。
```
HTML
```
HTML
<script src="jquery.js"></script>
<script src="jquery.js"></script>
<script src="other.js"></script>
<script src="other.js"></script>
<script>
<script>
...
...
Day66-75/05.解析动态内容.md
View file @
60986aa6
## 解析动态内容
## 解析动态内容
根据权威机构发布的全球互联网可访问性审计报告,全球约有四分之三的网站其内容或部分内容是通过JavaScript动态生成的,这就意味着在浏览器窗口中“查看网页源代码”时无法在HTML代码中找到这些内容,也就是说我们之前用的抓取数据的方式无法正常运转了。解决这样的问题基本上有两种方案,一是JavaScript逆向工程;另一种是渲染JavaScript获得渲染后的内容。
### JavaScript逆向工程
### JavaScript逆向工程
...
...
README.md
View file @
60986aa6
...
@@ -74,7 +74,7 @@
...
@@ -74,7 +74,7 @@
-
for循环 - 基本结构 / range类型 / 循环中的分支结构 / 嵌套的循环 / 提前结束程序
-
for循环 - 基本结构 / range类型 / 循环中的分支结构 / 嵌套的循环 / 提前结束程序
-
应用案例 - 1~100求和 / 判断素数 / 猜数字游戏 / 打印九九表 / 打印三角形图案 / 猴子吃桃 / 百钱百鸡
-
应用案例 - 1~100求和 / 判断素数 / 猜数字游戏 / 打印九九表 / 打印三角形图案 / 猴子吃桃 / 百钱百鸡
#### Day05 - [总结和练习](./Day01-15/Day05/练习.md)
#### Day05 - [总结和练习](./Day01-15/Day05/
总结和
练习.md)
-
基础练习 - 水仙花数 / 完美数 / 五人分鱼 / Fibonacci数列 / 回文素数
-
基础练习 - 水仙花数 / 完美数 / 五人分鱼 / Fibonacci数列 / 回文素数
-
综合练习 - Craps赌博游戏
-
综合练习 - Craps赌博游戏
...
...
res/selenium-ide.png
0 → 100644
View file @
60986aa6
116 KB
关于测试.md
0 → 100644
View file @
60986aa6
## 自动化测试
### 软件测试概述
软件测试是一种用来促进鉴定软件的正确性、完整性、安全性和品质的过程,也就是在规定的条件下对程序进行操作以发现程序中的错误,衡量软件的品质并对其是否能满足设计要求进行评估的过程。
#### 测试的方法
黑盒测试:测试应用程序的功能,而不是其内部结构或运作。测试者不需具备应用程序的代码、内部结构和编程语言的专门知识。测试者只需知道什么是系统应该做的事,即当键入一个特定的输入,可得到一定的输出。测试案例是依应用系统应该做的功能,照规范、规格或要求等设计。测试者选择有效输入和无效输入来验证是否正确的输出。此测试方法可适合大部分的软件测试,例如集成测试和系统测试。
白盒测试:测试应用程序的内部结构或运作,而不是测试应用程序的功能(即黑箱测试)。在白箱测试时,以编程语言的角度来设计测试案例。测试者输入数据验证数据流在程序中的流动路径,并确定适当的输出,类似测试电路中的节点。
#### 测试的种类(阶段)
单元测试:对软件组成单元进行测试,其目的是检验软件基本组成单位的正确性,测试的对象是软件设计的最小单位 - 函数。
集成测试:将程序模块采用适当的集成策略组装起来,对系统的接口及集成后的功能进行正确性检测的测试工作。其主要目的是检查软件单位之间的接口是否正确,集成测试的对象是已经经过单元测试的模块。
系统测试:系统测试主要包括功能测试、界面测试、可靠性测试、易用性测试、性能测试。
回归测试:为了检测代码修改而引入的错误所进行的测试活动。回归测试是软件维护阶段的重要工作,有研究表明,回归测试带来的耗费占软件生命周期的1/3总费用以上。
#### 单元测试
Python的标准库里有为编写单元测试而准备的unittest模块,执行测试时建议使用
[
pytest
](
https://docs.pytest.org/en/latest/
)
。pytest是一款能够自动搜索并执行测试的测试执行工具,并且会输出详细的错误报告。关于单元测试可以看看
[
《Python必会的单元测试框架 - unittest》
](
https://blog.csdn.net/huilan_same/article/details/52944782
)
。
可以安装
[
testfixtures
](
https://pypi.org/project/testfixtures/
)
库来辅助单元测试,它整合了多种典型配置器,提供了生成目录、更改系统日期、生成mock对象的功能模块,这些模块能够帮助我们将单元测试与单元测试所依赖的环境分离开。
[
mock
](
https://pypi.org/project/mock/
)
是将测试对象所依赖的对象替换为虚拟对象的库,在测试的时候,我们可以为虚拟对象指定其在被调用时的返回值以及是否发生异常等。
[
WebTest
](
https://pypi.org/project/WebTest/
)
是用于Web应用功能测试的库。它会对WSGI应用执行模拟请求并获取结果。基本上所有WSGI应用的测试都可以用它。
tox能便捷地为我们准备好执行测试所需的环境。tox会在多个virtualenv环境中搭建测试 环境,然后在这些环境中执行测试并显示结果。它能够把测试工具的选项及环境变量等内容统 一起来,所以我们只需执行tox命令即能轻松完成所需的测试。
### Selenium
Selenium是实现Web应用程序的功能测试以及集成测试自动化的浏览器驱动测试工具群。和使用浏览器的用户相同,Selenium可以在浏览器进行的鼠标操作、在表单中输入文字、验证表单的值等,利用这一点就可以将手动操作变成自动化操作。
#### Selenium优点
1.
自动化测试用例制作简单。Selenium提供了Selenium IDE工具,该工具可以捕获鼠标、键盘的操作,然后通过重放功能来重复这些操作,这样就可以简单的制作测试用例。
2.
支持多种浏览器和操作系统。
#### Selenium的组件
1.
[
Selenium IDE
](
https://www.seleniumhq.org/projects/ide/
)
。
2.
[
Selenium Remote Control
](
https://www.seleniumhq.org/projects/remote-control/
)
。
3.
[
Selenium WebDriver
](
https://www.seleniumhq.org/projects/webdriver/
)
。
#### 与持续集成工具协作
持续集成指的是频繁的将代码集成到主干。它的好处主要有两个:
1.
快速发现错误。每完成一点更新,就集成到主干,可以快速发现错误,定位错误也比较容易。
2.
防止分支大幅偏离主干。如果不是经常集成,主干又在不断更新,会导致以后集成的难度变大,甚至难以集成。
持续集成的目的,就是让产品可以快速迭代,同时还能保持高质量。它的核心措施是代码集成到主干之前,必须通过自动化测试,只要有一个测试用例失败,就不能集成。编程大师Martin Fowler曾经说过:“持续集成并不能消除Bug,而是让它们非常容易发现和改正。”
可以在Jenkins中安装“Seleniumhq Plugin”插件,这样就可以将Selenium IDE制作的测试用例保存为HTML格式并提供给Jenkins来使用,基本步骤是:
1.
在执行测试的机器上,从版本控制系统中下载测试套件和测试用例。
2.
在执行测试的机器上下载Selenium Server。
3.
从Jenkins的“系统管理”中选择“插件管理”来安装“Seleniumhq Plugin”。
4.
在Jenkins的“系统管理”中选择“系统设置”并配置“Selenium Remote Control”下的“HTMLSuite Runner”。
5.
新建测试用的Jenkins任务并进行配置,配置的内容包括:浏览器、起始URL、测试套件和测试结果输出文件。
配置完成后,就可以执行Jenkins的“立即构建”了。
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment