自动化测试与构建

概述

  1. 自动化测试
    • 一段程序代码,不提供具体的程序功能,只保证主要程序功能符合预期
    • 编写需要很高的成本
  2. 自动化构建 => 通过一系列自动化命令代替手工操作
    • 减少出错的可能
    • 减少重复劳动
    • 提高工作效率
    • CI => Continuous Integration => 持续集成
    • CD => Continuous Delivery => 持续交付

测试名词

  • 手工测试 => 最 low 的测试方式
  • 单元测试 => 快速检出一个类的功能 => 测试一个类或方法是否符合预期
  • 集成测试 => 检查整个系统的功能
    • 启动测试环境
    • 保证测试环境的隔离
    • 使用各类自动化工具模拟外界输入
  • 回归测试 => 检查新的代码有没有破坏旧的功能
  • 冒烟测试 => 快速检查代码有没有大问题
  • UAT => User Accepted Test => 用户或甲方是否接受
  • 黑盒测试 => 将整个系统看成一个黑盒进行测试
  • 白盒测试 => 根据系统的内部细节设计专用的测试
  • 压力测试 => 给系统施加一定的压力,确保系统的稳定性

Java 中的测试形态

  • TestNG
  • JUnit
    • JUnit 4
    • JUnit 5 => 推荐

JUnit

  • @Test
  • @BeforeAll => 在所有测试用例之前运行且只运行一次
  • @BeforeEach => 每个测试用例之前都会运行

测试的生命周期

  • Maven 约定 => 放在 src/test 下的都是测试代码
  • Maven 生命周期
    • test
    • integration-test
  • 测试的时候到底发生了什么?
    1. 新的 JVM => mvn test => mvn 命令就是拼接一个 Java 命令 => 开启 JVM,运行 Maven 生命周期 => 当运行到 test 生命周期的时候,会启动一个新的JVM,test 可能是破坏性的,隔离环境,从而不会影响之前的 JVM,另:test 可以 fork 多个 JVM
    2. 每个测试用例新建一个测试类的实例

Java 自动化构建工具 - Maven

优点

  • 定义了简单而高效的约定与流程
  • 插件数量庞大而稳定
  • 用户数量庞大

缺点

  • XML 冗长啰嗦,较死板
  • 发展几乎停滞

pom.xml 解析

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <!-- 自身信息 -->
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.77_preview_01</version>

    <packaging>jar</packaging>
    <name>fastjson</name>
    <description>Fastjson is a JSON processor (JSON parser + JSON generator) written in Java</description>

    <url>https://github.com/alibaba/fastjson</url>
    <inceptionYear>2012</inceptionYear>

    <!-- 属性,可以在其他地方被替换 -->
    <version>${jdk.version}</version>
    <properties>
        <junit.version>4.13.1</junit.version>
        <gpg.skip>true</gpg.skip>
        <javadoc.skip>true</javadoc.skip>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <jdk.version>1.5</jdk.version>
    </properties>

    <!-- source control management => 源代码管理系统 -->
    <scm>
        <url>https://github.com/alibaba/fastjson</url>
        <connection>scm:git:https://git@github.com/alibaba/fastjson.git</connection>
    </scm>

    <organization>
        <name>Alibaba Group</name>
        <url>https://github.com/alibaba</url>
    </organization>

    <!-- 开发者 -->
    <developers>
        <developer>
            <id>wenshao</id>
            <name>wenshao</name>
            <email>szujobs@hotmail.com</email>
        </developer>
    </developers>

    <!-- 开源协议 -->
    <licenses>
        <license>
            <name>Apache 2</name>
            <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
            <distribution>repo</distribution>
            <comments>A business-friendly OSS license</comments>
        </license>
    </licenses>

    <!-- 模块 -->
    <modules>
        <module>math-game</module>
        <module>common</module>
    </modules>

    <!-- 用户档案 => 在不同的场景使用不同的方式 -->
    <properties>
        <revision>3.5.4</revision>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.target>1.6</maven.compiler.target>
        <maven.compiler.source>1.6</maven.compiler.source>
        <spring-boot.version>2.3.1.RELEASE</spring-boot.version>
        <maven-invoker-plugin.version>3.0.0</maven-invoker-plugin.version>
        <jacoco.skip>${skipTests}</jacoco.skip>
        <project.build.outputTimestamp>2020-09-27T15:10:43Z</project.build.outputTimestamp>
        <lifecycle-mapping.version>1.0.0</lifecycle-mapping.version>
        <netty.version>4.1.59.Final</netty.version>
    </properties>

    <!-- 指明插件 => 插件是 Maven 的灵魂 -->
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.8.0</version>
                <configuration>
                    <encoding>UTF-8</encoding>
                    <source>${jdk.version}</source>
                    <target>${jdk.version}</target>
                </configuration>
                <dependencies>
                    <dependency>
                        <groupId>org.codehaus.plexus</groupId>
                        <artifactId>plexus-compiler-javac</artifactId>
                        <version>2.7</version>
                    </dependency>
                </dependencies>
            </plugin>
        </plugins>
    </build>

    <!-- 指明依赖从哪个仓库下载,默认是 Maven 中央仓库 -->
    <repositories>
        <repository>
            <id>alimaven</id>
            <name>aliyun maven</name>
            <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
        </repository>
    </repositories>

    <!-- 指明从父 pom 继承一些已有的依赖 -->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.2.2.RELEASE</version>
    </parent>

    <!-- dependencyManagement 依赖指定的版本在子项目中引用时可以不使用 <version> => 优点 => 所有子项目使用同一版本号 -->
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>com.alibaba</groupId>
                <artifactId>bytekit-core</artifactId>
                <version>0.0.7</version>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <!-- 依赖 -->
    <dependencies>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>3.1.0</version>
            <scope>provided</scope>
            <optional>true</optional>
        </dependency>
    </dependencies>

    <profiles>
        <profile>
            <id>github_actions</id>
            <activation>
                <property>
                    <name>env.GITHUB_ACTIONS</name>
                    <value>true</value>
                </property>
            </activation>
            <build>
                <plugins>
                    <plugin>
                        <!-- for codecov.io -->
                        <!-- config example: https://github.com/codecov/example-java -->
                        <!-- plugin docs: http://eclemma.org/jacoco/trunk/doc/ -->
                        <groupId>org.jacoco</groupId>
                        <artifactId>jacoco-maven-plugin</artifactId>
                        <version>0.8.7</version>
                        <executions>
                            <execution>
                                <goals>
                                    <goal>prepare-agent</goal>
                                </goals>
                            </execution>
                            <execution>
                                <id>report</id>
                                <phase>test</phase>
                                <goals>
                                    <goal>report</goal>
                                </goals>
                            </execution>
                        </executions>
                    </plugin>
                </plugins>
            </build>
        </profile>

    </profiles>
</project>

仓库系统

  1. 所有的依赖先在本地查找 => ~/.m2 => m2 == maven2

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
    </dependency>
    
    本地仓库
  2. 本地仓库没找到 => 远程仓库 => 默认 Maven 中央仓库 => https://repo.maven.apache.org/maven2/org/springframework/boot/spring-boot-starter-test/

Life Cycle

Maven Default Lifecycle
  • Maven 生命周期 compile Phase 调用 javac 命令将 *.java 变为 *.class
  • 扩展 Maven 的功能 => 使用已经写好的插件 => 直接运行插件目标 | 绑定到特定阶段

打包 & 部署

  • jar => 发布给别的项目使用
  • mvn install
  • mvn package
  • mvn deploy

Maven 与其他系统的集成

  • 在特定的周期绑定一个脚本 =>
  • 自行编写插件 => LOC 插件 => // TODO

Maven 多模块构建

  • 多模块 => 软件工程的最佳实践,降低模块之间的耦合性 => 降低耦合性 + 提高性能 => 高内聚低耦合
  • 多模块发布时需要先 mvn install => 将项目间的依赖先安装的本地仓库中
  • mvn install => 约定 => 把当前的项目安装到本地仓库里面,方便进行集成测试。mvn install 将项目安装成 jar 包,使得其他的项目可以直接在自己的 pom.xml 里面通过标签引用

Java 自动化构建工具 - Gradle

很多很多的任务组成的一组松散地集合,任务之间可以进行相互的依赖

优点

  • 自由、功能强大
  • 省代码
  • 发展迅速、较新

缺点

  • 较为复杂
  • 过于自由
  • API 发展太快,社区跟不上

Lifecycle

  • initialization => 加载构建的模块信息
  • configuration => 扫描本次构建中所有的信息
  • execution => 执行命令行传入的任务

Task

  • 基本地执行单元,可以相互依赖
  • Task 在 configuration 阶段创建和配置,在 execution 阶段执行

Plugin

  • 一些逻辑的打包,方便复用
  • 可以调用 Gradle 的 API,动态创建任务

知识点

  1. Mockito => Java Mock Framework
  2. 跳过 Test,Maven 命令添加 mvn test -DskipTests
  3. 服务起在多个服务器上
    • 避免单点故障
    • 更新的时候服务不中断
    • 负载均衡
  4. Maven 依赖包 scope => compile | test | provided | optional
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容