热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

团队项目(2+3):自动测试平台--需求文档

0.项目背景在软件工程课程中,个人项目的测试一直是一个难以自动化的问题。不同的学校的项目题目不同,测试代码也不一样,每一届助教都需要手动测试或费时费力写一个自动批处理测试的程序。但在助教们使

0. 项目背景

  在软件工程课程中,个人项目的测试一直是一个难以自动化的问题。不同的学校的项目题目不同,测试代码也不一样,每一届助教都需要手动测试或费时费力写一个自动批处理测试的程序。但在助教们使用的过程中发现,实际上大部分测试的大部分步骤都是可以固定下来的,比如说爬取Github仓库,命令行批处理运行等。希望能开发一个软工OJ,它的扩展性比较强,可以稍微定制化。比如能处理数独、能处理四则运算、地铁线路规划这样的题目作业的自动判定测试。它不仅能支持软工题目自动评分、还能支持代码查重、代码规范评分等,同时其定制化的成本不要太大,最好能够支持助教使用不同的语言来利用平台。

1. 项目用户分析

角色:学生、老师、管理员

1.1 管理员:

  1. 建立课程
  2. 赋予教师课程操作权限
  3. 处理一些特殊情况 ... ... .

1.2 学生:

  1. 提交代码
  2. 查看结果

1.3 教师:

  1. 项目发布:输入项目名称、项目详细描述、项目功能测试文件、是否允许学生自行评测。
  2. 项目浏览:查看发布的项目、删除项目、选择项目进行评测。项目信息包括项目名称、详细描述和选择该项目学生的列表。其中项目评测自动爬取学生提交在github上的项目源代码,并进行评测。
  3. 项目评测结果:显示项目中每个学生的评测情况。包括每个学生提交项目的代码规范程度、测试样例通过比例。同时包括项目总体报告。项目总体包括项目每个测试点通过的学生数量

2. 项目功能分析

2.1 主要角色的需求 (分角色描述)

学生:

  • 选题
  • 查看本次项目评测的结果
  • 查看全班得分排行

教师:

  • 项目发布:输入项目名称、项目详细描述、项目功能测试文件、是否允许学生自行评测。
  • 项目浏览:查看发布的项目、删除项目、选择项目进行评测。项目信息包括项目名称、详细描述和选择该项目学生的列表。其中项目评测自动爬取学生提交在github上的项目源代码,并进行评测。
  • 项目评测结果:显示项目中每个学生的评测情况。包括每个学生提交项目的代码规范程度、测试样例通过比例。同时包括项目总体报告。项目总体包括项目每个测试点通过的学生数量

2.2 核心功能

  1. 对用户提交的程序进行判题
  2. 对用户的基本管理功能
  3. 对题库的基本管理功能
  4. 可以建立作业、测验、考试
  5. 可以生成作业、测验、考试的结果表格

2.3 亮点功能

  1. 加入从GitHub爬取项目仓库的功能
  2. 代码正确性评测给出具体错误提示
  3. 对代码评分的指标:
    1. 运行测试数据的正确率;[运行测试脚本]
    2. 代码是否满足题目要求;[题目设定的检查点]
    3. 代码的规范性 [利用代码审查技术实现];
    4. 代码内聚、耦合、规模等指标 [利用代码度量技术实现]
  4. 测试数据生成方式多来源、多方式。
    1. 自动生成:可以由工具生成(Evosuite、Randoop)
    2. 老师手动生成
  5. 测试脚本的生成方式也是多来源、多方式
    1. 全自动生成测试脚本:处理一些相对简单的、test Oracle相对明确的、或者蜕变关系明确的(蜕变测试)
    2. 半自动生成测试脚本框架:类似与 IDE 自动生成测试框架
    3. 老师手动生成:处理相对复杂的场景

2.4 其他功能

  1. 项目库(即题库)的管理:
    • 题目(项目)要求描述。尽量模板化、规范化;
    • 测试用例、测试脚本。尽量提供模版或一些撰写指南。
  2. 班级管理
    • 学生班级分组;
    • 老师和学生(班级)建立关联
  3. 排行榜管理
    • 每个学生得分:
    • 程序测试得分
    • 开发过程得分
    • 文档质量得分
  4. 其他一些统计分析功能
    • 学生提交项目(commit)分布;
    • 项目规模与提交时间关联分析;
    • ... ...

3. 性能需求分析

  • 学生在线分析的实时性需求:最好做到实时反馈测试结果;代码审查的结果;
  • 一次处理学生提交的项目数量、规模需求;[需要细化]

4. 对现有软件的分析

1、GitHub: 提交代码,代码迭代管理ok,但缺乏对测试数据的自动检测
2、oj平台: 提交代码,缺乏个性化测试,深层分析和管理

用户需求:
教师:自动评分和反馈

学生:实时反馈代码质量,


推荐阅读
  • CentOS 7 磁盘与文件系统管理指南
    本文详细介绍了磁盘的基本结构、接口类型、分区管理以及文件系统格式化等内容,并提供了实际操作步骤,帮助读者更好地理解和掌握 CentOS 7 中的磁盘与文件系统管理。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • andr ... [详细]
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • 本文详细分析了JSP(JavaServer Pages)技术的主要优点和缺点,帮助开发者更好地理解其适用场景及潜在挑战。JSP作为一种服务器端技术,广泛应用于Web开发中。 ... [详细]
  • 本文详细记录了在基于Debian的Deepin 20操作系统上安装MySQL 5.7的具体步骤,包括软件包的选择、依赖项的处理及远程访问权限的配置。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文介绍了如何通过扩展 UnityGUI 创建自定义和复合控件,以满足特定的用户界面需求。内容涵盖简单和静态复合控件的实现,并展示了如何创建复杂的 RGB 滑块。 ... [详细]
author-avatar
手机用户2602915825_387
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有