软件验收报告_第1页
软件验收报告_第2页
软件验收报告_第3页
已阅读5页,还剩33页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

学生管理系统软件验收报告目录第一章项目概述 .41.1项目背景.51.2相关文档.51.3参考资料.61.4部分系统截图.61.5系统结构图 .7第二章验收定义 .82.1验收策略.82.2验收依据.82.3验收环境.92.4验收标准.92.4.1 项目验收原则.92.4.2 验收流程 .92.4.3 系统功能标准.102.5验收范围.112.6验收人员.11第三章项目验收内容.123.1实施工作验收.123.2软件平台验收单.12-可编辑修改 -3.3功能模块验收单.133.4项目文档验收单.133.5运行结果验收.14第四章验收结论 .14第五章交付物清单.14文档提交清单.14源码提交清单.15附件 : .37程序流程图 .37第一章项目概述学生信息管理系统( studentinformationmanagementsystem ),以下简称 sims ,是针对学校人事处的大量业务处理工作而开发的管理软件,是典型的管理信息系统( managementinformationsystem )。它是一个教育单位不可缺少的部分 ,它的内容对于学校的决策者和管理者来说都至关重要,它能够为用户提供充足的信息和快捷的查询手段。能有效的帮助学校和老师掌握学生的情况,为学生提供成绩跟课程方面的查询。在传统模式下利用人工进行学生信息管理,存在着较多的缺点,如:效率底,保密性差,时间一长将产生大量的文件和数据,更不便于查找,更新,维护等。诸如这些情况, 令学校管理者对学生的信息管理带来了很大困难, 严重影响了教育工作者的工作效率。 随着科学技术的不断提高 ,计算机科学日渐成熟 , 使用日趋成熟的计算机技术来代替传统的人工模式,来实现学生信息的现代化管理,其强大的功能已为人们深刻认识,它已进入人类社会的各个领域并发挥着越来越 重要的作用。作为计算机应用的一部分,使用计算机对学生信息进行管理,具有着手工管理所无法比拟的优点。这些优点能够极大地提高学生信息管理的效率,也是学校的科学化、 正规化管理的重要条件。 用计算机制作的学校信息管理系统还可以通过功能强大的互联网及时的向学生的家长传递该生在校的最新成绩,有助于学校与家长的信息互动, 为更好地把握学校的教育方针一定的促进作用。因此, 开发这样一套管理软件成为很有必要的事情。1.1 项目背景随着信息技术在管理上越来越深入而广泛的应用, 管理信息系统的实施在技术上已逐步成熟。 管理信息系统是一个不断发展的新型学科, 任何一个单位要生存要发展, 要高效率地把内部活动有机地组织起来, 就必须建立与自身特点相适应的管理信息系统。目前信息处理技术的飞速发展,基于计算机网络的信息处理已成为人们日 常工作 ,学习和生活必备系统?在internet飞速发展的今天 ,互联网已成为人们快速获取 , 发布和传递信息的重要渠道,它已成为社会生活的一部分?学生信息处理的电脑化 ?网络化,是实现学校管理现代化和信息化的重要内容,也是方便用户快捷查询相关充足信息的重要工具?与传统学生信息处理模式相比, 基于网络的学生管理系统具有无可比拟的优越性?因此开发一套有关学校的信息管理系统不仅能大大提高工作效率而且还能给师生的工作学习带来极大的便利。1.2 相关文档1学生管理系统软件测试方案2学生管理系统软件测试用例1.3 参考资料软件测试从入门到精通软测之魂:核心测试设计精解软件测试与测试技术1.4 部分系统截图1.5 系统结构图学生管理系统学生相关分数相关学科相关密码相关退出系统添编搜加辑索学学学生生生显编添编修示辑-可编辑修加改 -辑改分分科科密数数目目码学生部分添加姓名添加学号添加性别添加专业学科部分添加学科添加学时添加专业第二章验收定义2.1 验收策略由开发方提供被验收内容、验收文档,由监理公司与用户进行评审,在评审无误的情况下,确认通过验收。2.2 验收依据软件测试验收准则-可编辑修改 -2.3 验收环境学生管理系统软件实际运行的生产环境为验收环境。硬件平台计算机软件平台window 操作系统: window xp 、window7 、window82.4 验收标准2.4.1 项目验收原则1、 审查提供验收的各类文档的正确性、完整性和统一性,审查文档是否齐全、合理;2、 审查项目功能是否达到了合同规定的要求;3、 审查项目有关服务指标是否达到了合同的要求;4、 审查项目投资以及实施进度的情况;对项目的技术水平做出评价,并得出项目的验收结论。2.4.2 验收流程本项目的验收采取项目验收流程的方式进行验收。具体流程如下图所示。开发方与监理公司制定验收流程验收流程用户确认用户确认是否通过?开发方提供验收内容列表、验收文档监理公司、客户对验收内容、验收文档进行确认验收内容、验收文档能否通过?项目验收、结束项目验收流程2.4.3 系统功能标准严重程度描述a 学生信息管理系统由于出现问题不能继续运转(崩溃) 学生信息管理系统的数据出现错误。b 某项业务无法进行。学生信息管理系统产生数据错误。c 学生信息管理系统中某一操作不能继续运转或错误,但不影响业务的进行。(有替代办法)学生信息管理系统打印的凭证或流水不符合需求所提出的标准。d 其他学生信息管理系统在某种状态下产生的错误,不影响正常功能。如果各模块验收测试结果如下表所述则视为验收合格,否则将进行修改, 以进行再次验收评审。严重程度关系发生个数a=0b =102.5 验收范围用户以及监理方进行验收确认。验收确认包括以下两方面确认内容:1. 参照验收标准确认合同所涉及的功能以及项目组的实施工作是否完成;2. 抽取客户端进行测试,确定系统能够稳定运行。2.6 验收人员单位人员职责/任务联系方式 /email备注哈师大学生张紫娜组长第三章项目验收内容3.1 实施工作验收工作阶段工作内容工作是否完成通过与用户的沟通,根据项目实际情需求调研况编写提交需求说明书 、概要设完成未完成计、详细设计。根据概要设计内容,完成详细设计并根据详细设计开发系统系统开发完成未完成和测试。每周提交项目进度及情况报告、测试报告。系统安装安装产品,对系统进行部署。完成未完成编写用户使用手册,对用户进行使用用户培训完成未完成培训。跟踪监控系统运行。对使用中发现的问题进行记录和评估,在不影响系统系统运行完成未完成结构的情况下对发现的问题进行修正。3.2 软件平台验收单验收人:张紫娜验收时间:序号软件类型软件名称验收结果备注1系统软件学生管理系统完成3.3 功能模块验收单序功能模块验收内容合同要求验收结果号1登录验证能否正常登陆必须实现合格2密码模块能否修改密码必须实现合格3学生模块正常实现添加修改功可以有差错合格能正常实现添加修改功4课程模块必须实现合格能正常实现添加修改功5成绩模块必须实现合格能6退出模块正常退出系统必须实现合格3.4 项目文档验收单序文档名称用途验收结果备注3.5运行结果验收系统运行内容是否符合要求a. 软件登录符合b. 软件测试符合c软件查询符合d. 软件修改符合e. 软件退出符合号1软件需求分析分析软件的需求,为后续的工作合格2软件测试用例对以实现的软件进行测试合格第四章验收结论经过严格的测试本软件达到要求标准,符合验收要求。第五章交付物清单文档提交清单1学生管理系统软件测试方案2学生管理系统软件测试用例源码提交清单源程序清单(仅给出核心代码部分)typedef char bool;#define filepathc:stuinfo.dat#define infopathc:test.txt#define maxspacecount10/系统所记录的最大冗余块数#define maxsubcount20/系统所允许存储的最多科目数#define randstucount100/系统将自动产生的学生个数#define randsubcount20/ 系统将自动产生的科目个数#define bufsize20/字符缓冲区大小#define showmax6/屏幕最大显示的科目数#define true1#define false0#define read0x81#define write0x82#define search_schid0x83/通过学生的学号进行搜索#define search_name0x85/通过学生的姓名进行搜索#define search_sub0x86/通过学科的名称进行搜索#define show_priv0x87/显示单个学生的个人信息#define show_permark0x89/显示单个学生的个人成绩#define show_allmark 0x90/ 显示所有学生的某科成绩#define sort_decline0x92/以降序排列#define sort_incline0x93/以升序排列#define alphaword0x94/ 以字母构成的字符串(用于随机产生学生的姓名#define numberword0x95/以数字构成的字符串(用于随机产生学号#define addsub0x96/科目编辑模式为添加#define editsub0x97/科目编辑模式为修改#define bignumber0x0ffffff/ 系统延迟采用的循环中的大数#define longsizesizeof(long)#define intsizesizeof(int)#define linksizesizeof(link)#define stuinfosizesizeof(stuinfo)#define subinfosizesizeof(subinfo)#define tchinfosizesizeof(tchinfo)#define submarksizesizeof(submark)#define fileinfosizesizeof(fileinfo)#define mystusizesizeof(mystu)#define dataseek(fileinfosize+longsize)#define datatrans(stuinfosize+longsize)#define seterr(s)printf(s);return false;/ 显示出错信息并返回#define new(i)(i*)malloc(sizeof(i)/ 开辟新的内存空间typedef struct _submarkinfobool flag;/flag=0表该块无效intsub_id;/ 科目的 id 号doublesub_mark;/ 该科目的成绩submark,*psubmark;/ 科目成绩信息typedef struct _stucharstu_name20;/ 学生姓名charintstu_schid20;stu_sex;/ 学生学号/ 学生性别0=man 1=womancharstu_major20;/ 学生专业和班级(电子 0606)mystu,*pmystu;/ 学生个人信息typedef struct _stuinfobool flag;/flag=0表该生作废intstu_sysid;/ 学生 id 号/系统将为每个学生产生唯一的id 号mystustu_privacy;/ 学生个人信息longstu_seek;/在文件中的地址intstu_markcount;/ 已有的成绩数doublestu_avemark;/ 学生加权平均分submark stu_markmaxsubcount;/学生成绩数组stuinfo,*pstuinfo;/ 学生信息 (包括个人信息和系统信息)typedef struct _subinfoboolflag;/flag=0表该块无效intsub_id;/ 科目的 id 号intsub_term;/ 科目开课的学期doublesub_rate;/ 科目所占的学分charsub_name20;/ 科目名称subinfo,*psubinfo;/ 科目信息typedef struct _fileinfointstucount;/ 已注册的学生人数intintcountmax;spacecount;/ 最大学生数 ,用于产生id/ 文件冗余块数longseekmaxspacecount;/文件冗余块在文件中的地址intsubcount;/ 已注册的科目的个数subinfo submaxsubcount;/科目信息数组fileinfo,*pfileinfo;/ 学生信息文件头typedef struct _linkdouble mark; long stuseek; struct _link* next;link,*plink;/ 该结构体用于产生链表/ 链表用于对成绩排序之用核心功能函数:/本函数设置系统错误,并终止程序void seterr(char*err)memset(void*)myerr,0,errnosize); int n=strlen(err);if(nerrnosize-1)n=errnosize; memcpy(myerr,err,n); printf(nn%snn,err); exit(0);/*本函数用于清理所有全局变量 包括文件指针和全局结构体指针*/ void freeparam()if(fp)fclose(fp);fp=null; if(myfileinfo)free(myfileinfo); myfileinfo=null; if(mystuinfo)free(mystuinfo); mystuinfo=null;/本函数用于对文件进行操作,将常用的文件操作集于一身void fcntl(long seek,int cntlmode,void *pdata,int size)if(!fp)fp=fopen(filepath,rb+); if(!fp)initfile();rewind(fp); fseek(fp,seek,seek_set); if(!pdata)return;if(!size)seterr(fcntl:parameter not matched); switch(cntlmode)case read:fread(pdata,size,1,fp); break;case write:fwrite(pdata,size,1,fp); break;default:seterr(fcntl:cntlmode invalid);/初始化数据库void initfile()if(!fp)fp=fopen(filepath,wb+);if(!myfileinfo) myfileinfo=new(fileinfo); memset(myfileinfo,0,fileinfosize); myfileinfo-seek0=dataseek;int i=0; for(;isubi.sub_id=i+1; fcntl(0,write,myfileinfo,fileinfosize);/添加学生的核心函数void addstu(pmystu newstuinfo)if(!newstuinfo) seterr(addstu:newstuinfo null);if(search(newstuinfo-stu_schid,search_schid)seterr(addstu:database schid collision); if(!myfileinfo)myfileinfo=new(fileinfo);fcntl(0,read,myfileinfo,fileinfosize);int spacecount=myfileinfo-spacecount; if(spacecount=maxspacecount) seterr(addstu:parameter invalid);long seek=myfileinfo-seekspacecount; if(spacecount)myfileinfo-seekspacecount=0; myfileinfo-spacecount-;else myfileinfo-seekspacecount+=datatrans; if(!mystuinfo)mystuinfo=new(stuinfo); memset(mystuinfo,0,stuinfosize);memcpy(&(mystuinfo-stu_privacy),newstuinfo,mystusize); mystuinfo-stu_seek=seek;mystuinfo-flag=1;int i;mystuinfo-stu_sysid=myfileinfo-countmax+1; for(i=0;istu_marki.sub_id=i+1;fcntl(seek,write,mystuinfo,stuinfosize); myfileinfo-stucount+;myfileinfo-countmax+; fcntl(0,write,myfileinfo,fileinfosize);/删除学生的核心函数 void delstu(long delstuseek)if(!delstuseek)seterr(delstu:parameter zero); if(!myfileinfo)myfileinfo=new(fileinfo); fcntl(0,read,myfileinfo,fileinfosize);if(!mystuinfo)mystuinfo=new(stuinfo); memset(mystuinfo,0,stuinfosize); fcntl(delstuseek,read,mystuinfo,stuinfosize); if(!mystuinfo-flag)seterr(delstu:parameter invalid); mystuinfo-flag=0; fcntl(delstuseek,write,mystuinfo,stuinfosize); myfileinfo-stucount-;myfileinfo-spacecount+;int count=myfileinfo-spacecount; if(countseekcount=delstuseek; else myfileinfo-spacecount-;fcntl(0,write,myfileinfo,fileinfosize);/编辑一个已存在学生的核心函数void editstu(long editstuseek,pmystu tempstu)if(!tempstu)seterr(editstu:parameter null); if(!mystuinfo)mystuinfo=new(stuinfo); memset(mystuinfo,0,stuinfosize); fcntl(editstuseek,read,mystuinfo,stuinfosize); if(!mystuinfo-flag)seterr(editstu:editstu invalid);plink linkhead=search(tempstu-stu_schid,search_schid); if(linkhead&linkhead-data-editstuseek)seterr(editstu:database schid collision); memcpy(&mystuinfo-stu_privacy,tempstu,mystusize);fcntl(editstuseek,write,mystuinfo,stuinfosize);/添加新的学科的核心函数 void addsub(psubinfo newsub)if(!newsub)seterr(addsub:parameter null); if(newsub-sub_termsub_term8)seterr(addsub:parameter invalid); if(newsub-sub_ratesub_rate6)seterr(addsub:parameter invalid);if(search(newsub-sub_name,search_sub) seterr(addsub:database sub collision);if(!myfileinfo)myfileinfo=new(fileinfo); fcntl(0,read,myfileinfo,fileinfosize);int subcount=myfileinfo-subcount; if(subcount=maxsubcount)seterr(addsub:subject full); psubinfo psubtemp=myfileinfo-sub; newsub-flag=1;int i;for(i=0;iflag)newsub-sub_id=psubtemp-sub_id; memcpy(psubtemp,newsub,subinfosize); break; if(i=maxsubcount)seterr(addsub:subject all in use);myfileinfo-subcount+; fcntl(0,write,myfileinfo,fileinfosize);/删除一个已经存在学科的核心函数void delsub(int subid)if(subidmaxsubcount)seterr(delsub:subid invalid); if(!myfileinfo)myfileinfo=new(fileinfo); fcntl(0,read,myfileinfo,fileinfosize);if(myfileinfo-subcountsub+subid-1; if(!subtemp-flag)seterr(delsub:flag invalid); subtemp-flag=0;myfileinfo-subcount-; fcntl(0,write,myfileinfo,fileinfosize); if(!mystuinfo)mystuinfo=new(stuinfo);long seek=dataseek;int i;psubmark marktemp=null; for(i=0;istucount;i+,seek+=datatrans)fcntl(seek,read,mystuinfo,stuinfosize); if(!mystuinfo-flag)i-;continue; marktemp=mystuinfo-stu_mark+subid-1; if(marktemp-flag)memset(marktemp,0,submarksize);mystuinfo-stu_markcount-;else continue; fcntl(seek,write,mystuinfo,stuinfosize); makeavemark(seek);/编辑一个已经存在的学科的核心函数void editsub(psubinfo newsub)if(!newsub)seterr(editsub:newsub null); if(!newsub-flag)seterr(editsub:newsub invalid);int subid=newsub-sub_id; if(subidmaxsubcount)seterr(editsub:subid invalid);int term=newsub-sub_term; if(term8)seterr(editsub:subterm invalid); double rate=newsub-sub_rate; if(rate6)seterr(editsub:subrate invalid); int size=strlen(newsub-sub_name);if(size=20)newsub-sub_name19=0; if(!myfileinfo)myfileinfo=new(fileinfo); fcntl(0,read,myfileinfo,fileinfosize);plink linkhead=search(newsub-sub_name,search_sub); if(linkhead&linkhead-next)seterr(editsub:search invalid); if(linkhead&linkhead-data-subid)seterr(editsub:database sub collision); newsub-flag=1;psubinfo subtemp=myfileinfo-sub+subid-1;memcpy(subtemp,newsub,subinfosize); fcntl(0,write,myfileinfo,fileinfosize); if(!mystuinfo)mystuinfo=new(stuinfo);int count=myfileinfo-stucount;int i;long seek=dataseek; for(i=0;iflag)i-;continue; makeavemark(seek);/编辑某学生某科目的核心函数void editmark(psubmark newmark,long stuseek)if(!newmark|!stuseek) seterr(addmark:parameter null);int subid=newmark-sub_id;if(subidmaxsubcount|!subid) seterr(editmark:subid invalid);double mark=newmark-sub_mark;if(mark100) seterr(editmark:submark invalid);if(!mystuinfo)mystuinfo=new(stuinfo);memset(mystuinfo,0,stuinfosize); fcntl(stuseek,read,mystuinfo,stuinfosize);if(!mystuinfo-flag) seterr(editmark:student invalid);psubmark marktemp=mystuinfo-stu_mark+subid-1; int flag1=marktemp-flag,flag2=newmark-flag; if(!flag1&!flag2)seterr(editmark:markflag invalid); memcpy(marktemp,newmark,submarksize); if(!flag1&flag2)mystuinfo-stu_markcount+; if(flag1&!flag2)mystuinfo-stu_markcount-; fcntl(stuseek,write,mystuinfo,stuinfosize); makeavemark(stuseek);/计算某学生的加权分数的核心函数void makeavemark(long stuseek)if(!stuseek)seterr(makeavemark:parameter null); if(!mystuinfo)mystuinfo=new(stuinfo); memset(mystuinfo,0,stuinfosize); fcntl(stuseek,read,mystuinfo,stuinfosize);if(!mystuinfo-flag)seterr(makeavemark:parameter invalid); if(!myfileinfo)myfileinfo=new(fileinfo); fcntl(0,read,myfileinfo,fileinfosize);int subcount=myfileinfo-subcount; if(!subcount|!mystuinfo-stu_markcount)mystuinfo-stu_avemark=0;fcntl(mystuinf

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论