第04组 Alpha事后诸葛亮
一、组长博客:地址
二、Postmortem模板
设想和目标
1、我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述?
我们要解决的问题是让大学生可以通过福鱼网站将暂时无用的商品,如看过的教科书、购买后没怎么穿过的衣服、离校后无法带走的电动车等,将它们卖给有需求的人,使这些物品的价值得到充分的利用,让买家卖家都得到好处。
典型用户场景:福大大四毕业生小林即将去外省工作,但是无法将电动车带走,于是使用福鱼网站上架自己的电动车,而大一新生小张刚好需要,于是两人通过福鱼协商,并交易成功。
2、我们达到目标了么(原计划的功能做到了几个? 按照原计划交付时间交付了么? 原计划达到的用户数量达到了么?)?
达到了一部分的目标并按照计划时间交付,尚未上市,暂时没有用户。
3、用户量, 用户对重要功能的接受程度和我们事先的预想一致么? 我们离目标更近了么?
暂时没有用户量
4、有什么经验教训? 如果历史重来一遍, 我们会做什么改进?
经验教训:错误估计自身的空余时间及学习能力,促使成果不尽如人意。
如果历史重来一遍,我们将会将目标定的低一些。
计划
1.我们是否有充足的时间来做计划?
由于都没有什么经验,对于计划一开始显得有点手足无措,所以花很多了时间来做计划。
2.团队在计划阶段怎么解决同事们对于计划的不同意见?
在这个阶段中,我们进行了讨论,提出自己的看法,有的人提出应该实现什么功能,在这个过程中是否会出现什么问题等等,对于不同的意见,使用少数服从多数的方式来解决分歧。
3.你原计划的工作是否最后都做完了?如果没有为什么?
没有完成,网页功能未实现,因为没有接触过,一开始学也不知道知道是学什么,所以没有完成。
4.有没有发现你做了一些事后看起来没必要活没有多大的事?
有啊,因为第一次学,不知道首先学什么,往往学了一个中途又要去学另一个。
5.是否每一项任务都有清楚的定义和交付件?
部分有,因为成员没有开发经验,所以比较混乱吧。
6.是否项目的整个过程都按计划进行,项目出了什么意外?有没有什么风险当时没有估计到?
大家都没有经验,需要学习html,css等新的知识,有的花费了较多时间。事先没有这样的经验,大家开始都忙无头绪,从最容易的入手,有些情况没有事先考虑只能进行百度或者询问大佬。事先没有考虑分开做的原因,遇见的问题也各种各样,在运行时出现bug,没有考虑系统兼容性,修改了很多次。因为大家都没有开发经验,在进行编写时也遇见新问题,再一次进行百度和询问大佬。
7.在计划中有没有留下缓冲区,有什么作用?
没有。
8.将来的计划会做什么修改?
留下缓冲区,加班熬夜完成应该的任务。
9.我们学到了什么?如果重来一遍,我们会做什么改进?
相信这次经历给我们的成员带来了挺多东西,过程虽然真的很艰难,如果还有下一次,我们应当在讨论时更加深入一点,这样成果可以更好
资源
1、我们有足够的资源来完成各项任务么?
时间资源:课程安排,作业安排,考试安排太多,没有足够的时间资源;人力资源:足够,但没有大佬;软件/硬件资源:通过自身努力和借鉴别人优秀的模板,以及全体成员出资,基本足够。
2、各项任务所需的时间和其他资源是如何估计的,精度如何?
时间依据分配人力以及完成时限动态安排,其余资源根据成员个人专业度和熟练度安排分配。
3、测试的时间,人力和软件/硬件资源是否足够? 对于那些不需要编程的资源 (美工设计/文案)是否低估难度?
软硬件,人力基本足够,时间资源略有不足。关于美工设计与文案确实有所低估,所需资源分配不够充足。
4、你有没有感到你做的事情可以让别人来做(更有效率)?
前端安排的人不少,可以安排更多的后端人员。
5、有什么经验教训? 如果历史重来一遍, 我们会做什么改进?
经验就是看视频教程得开倍速,要边实践,多记笔记多百度。如果历史重来,我们会在具体安排上更精确,设计更精确的各项目完成时间及要求以便作维护修改。
变更管理
-
1.每个相关的员工都及时知道了变更的消息?
是的。 -
2.我们采用了什么办法决定“推迟”和“必须实现”的功能?
我们采用了可视性,关键性为重的评判标准,即决定了实现过程更清晰,作用更关键的功能作为“必须实现”的功能(比如前端的页面设计),其次尽量选择简单易上手的功能,而其他暂时难以实现的功能则作为“推迟”的功能。 -
3.项目的出口条件(Exit Criteria – 什么叫“做好了”)有清晰的定义么?
我们对出口条件的定义是:项目经过多次测试与完善,运行过程中没有明显的bug,能够保证users用户正常使用。 -
4.对于可能的变更是否能制定应急计划?
暂时没有制定应急计划,对于(未来)可能出现的变更,我们会对相关成员进行积极的沟通。 -
5.员工是否能够有效地处理意料之外的工作请求?
鉴于我们组会议时分工明确,且基本没有负担太多的工作,意料之外的工作请求比较少,因此对于突发情况还是能够接受的。 -
6.我们学到了什么? 如果历史重来一遍, 我们会做什么改进?
我们学到了:实现功能时应从简单的功能入手,循序渐进;对成员分工时,应该有大致的方向和目标,根据每个成员擅长的方向分配适当的任务;有意外变更时,应当积极与相关成员沟通,努力解决。
改进:组内成员需要更多的沟通,需要更多的提速,以便更早完成任务,及时对接。
设计/实现
1、设计工作在什么时候,由谁来完成的?是合适的时间,合适的人么?
设计工作在上周,由组长林涛完成,是合适的时间和合适的人。
2、设计工作有没有碰到模棱两可的情况,团队是如何解决的?
在设计过程中,对于如何安排功能板块、如何实现网站功能等,由于大家都是新手,不知道要如何去完成。通过参考别的网站的模块设计和功能,学习各种教程,最后做出自己的网站设计。
3、团队是否运用单元测试(unit test),测试驱动的开发(TDD)、UML, 或者其他工具来帮助设计和实现?这些工具有效么?
使用了ProcessOn的uml工具,它很好的帮助将需求和系统的体系架构转化成代码和可视化。
4、比较项目开始的 UML 文档和现在的状态有什么区别?这些区别如何产生的?是否要更新 UML 文档?
没有什么区别,无更新。
5、什么功能产生的Bug最多,为什么?在发布之后发现了什么重要的bug? 为什么我们在设计/开发的时候没有想到这些情况?
首页的商品秒杀倒计时,由于要自动计时,过时间之后会继续计数,尚未完成下一步的操作。在开发时由于并未做过类似的倒计时商品,对于如何设置倒计时没有概念,所以把握不好。
6、代码复审(Code Review)是如何进行的,是否严格执行了代码规范?
采用结对编程的方法,由另一位同学去审查代码寻找问题,严格执行了代码规范。
7、我们学到了什么? 如果历史重来一遍, 我们会做什么改进?
学习到了如何将构想实现出来,包括网页模块设计、功能实现,以及如何运用uml工具等辅助。如果重来一遍,会在前期考虑的更加细致一点,比如所需要的功能、商品的分类等,提高网页的可操作性。
测试/发布
-
团队是否有一个测试计划?是否进行了正式的验收测试?
有测试计划。未进行正式验收测试。 -
团队是否有测试工具来帮助测试?
因为是Web开发,所以前端可以直接使用Chrome的开发者工具或者FireFox的开发者工具、FireBug插件进行调试。性能测试工具有LoadRunner、JMeter等。后端数据库测试工具有sql server profiler等。 -
团队是如何测量并跟踪软件的效能的?从软件实际运行的结果来看,这些测试工作有用么?应该有哪些改进?
查看各个函数耗时、内存占用、CPU占用率等,找出性能瓶颈;以及在实际访问页面时页面排版、页面跳转是否出现Bug。在数据库测试中,测试查找最占用时间、最占用系统资源的查询语句,检测是否存在死锁等。测试过程中找到的大部分问题已经进行改善优化。 -
在发布的过程中发现了哪些意外问题?
产品暂时还没有发布,先进行本地的测试。以后发布计划租用云服务器,搭建Web服务器,能够进行线上访问。 -
我们学到了什么? 如果历史重来一遍, 我们会做什么改进?
学到了HTML、JS、CSS等Web前端开发的必备知识;数据库的设计和实现,数据库软件的使用;以及前后端的交互过程,网页的运作过程,对整个Web开发的流程有了更加深入的了解。如果历史重来一遍,会更加合理安排时间,安排计划,加强队员之间的交流。
团队的角色,管理,合作
1.团队的每个角色是如何确定的?是不是人尽其才?
因为团队主要成员大多数都为无经验的新手,我们角色的确定是先按经验分,再按兴趣分,是不是人尽其才我们不敢确定,但是我们团队尽量做到不强迫组员
原则,以致于影响团队积极性。
2.团队成员之间有互相帮助么?
这是肯定有的,总有学得快的或是之前有小部分经验的人存在,互相询问和互相讨论也是我们团队学习技术的方式之一。
3.当出现项目管理、合作方面的问题时,团队成员如何解决问题?
出现这一类问题时,我们会先线上讨论,如若无果,会召开线下会议,按照多数人的意愿来解决问题,就算在客观角度里是效率更低的方法,我们比起效率会
先注重团队协调性。
4、个人感谢部分。
每个成员明确公开地表示对成员帮助的感谢 :
我感谢王德钊同学对我的帮助, 因为在我忙于校选课论文时,他帮我整合评分表。
5、我们学到了什么? 如果历史重来一遍, 我们会做什么改进?
如果重来一遍,我会一开始就确定分工,分前端、后端两个小组,各再分配一负责人;找时间让大家出来一起写代码、赶项目。
总结:
1.你觉得团队目前的状态属于CMM/CMMI中的哪个阶段?
我认为我们的团队处于第二个阶段,即管理级,我们只是遵守了当时项目成立时的计划,按计划分工,没有系统的管理措施,大多数问题靠投票解决。
2.你觉得团队目前处于 萌芽/磨合/规范/创造 阶段的哪个阶段?
我认为我们团队目前处于磨合阶段,毕竟当时组队时临时拼凑的,大家不能说上人尽其才,因为都不了解,但是分工没有什么异议,所以我认为处于磨合阶段。
3.你觉得团队在这个里程碑相比前一个里程碑有什么改进?
更加团结了。
4.你觉得目前最需要改进的一个方面是什么?
我认为是管理方面的,因为我们不能说是一个系统规范的团队。大家只是组队,重要部分拿捏靠组长和投票,不算一个规范的管理方法。
按照敏捷开发原则,我们小组做的最好的应该是激励项目人员,大家都是从零开始,对于犯错误的包容度较大,事例说不上具体,因为大家在代码错误出BUG的时候都是互相检查鼓励的。
三、答辩总结
1.贡献比例
组员 | 分工 | 贡献比例 |
---|---|---|
林涛(组长) | 规划项目进程、找资源、页面制作、分配任务、审查文档、写博客 | 20% |
童圣滔 | 页面制作、部分文档编写 | 9% |
林红莲 | 页面制作、ppt制作 | 15% |
潘雨佳 | 页面制作、ppt制作 | 10% |
于瀚翔 | 数据库构建、演讲、展示 | 9% |
袁正闻 | 数据库构建、部分文档编写 | 4% |
吕瑞峰 | 页面制作、部分文档编写 | 8% |
蒋梦迪 | 部分文档编写、美术素材收集 | 4% |
王德钊 | 部分文档编写 | 4% |
吴友昆 | 页面制作、部分文档编写 | 8% |
覃鸿浩 | 美术素材收集、设计评审表、评分 | 9% |
2.现场答辩得分
- 平均得分:89.5
- 总分(乘以60%):53.7
3.提问回答
-
Q:功能如何实现?
A:买云服务器,搭建web服务器,实现数据库与前端相接。 -
Q:如何推广?
A:线上空间转载。 -
Q:如何盈利?
A:广告。
4.PSP与学习进度条
个人PSP
PSP2.1 | Personal Software Process Stages | 预估耗时(分钟) | 实际耗时(分钟) |
---|---|---|---|
Planning | 计划 | 30 | 20 |
Estimate | 估计这个任务需要多少时间 | 20 | 10 |
Development | 开发 | 30 | 30 |
Analysis | 需求分析 (包括学习新技术) | 30 | 20 |
Design Spec | 生成设计文档 | 10 | 10 |
Design Review | 设计复审 | 10 | 10 |
Coding Standard | 代码规范 (为目前的开发制定合适的规范) | 20 | 20 |
Design | 具体设计 | 30 | 30 |
Coding | 具体编码 | 80 | 60 |
Code Review | 代码复审 | 30 | 30 |
Test | 测试(自我测试,修改代码,提交修改) | 30 | 30 |
Reporting | 报告 | 10 | 10 |
Test Repor | 测试报告 | 20 | 20 |
Size Measurement | 计算工作量 | 10 | 10 |
Postmortem & Process Improvement Plan | 事后总结, 并提出过程改进计划 | 20 | 20 |
合计 | 370 | 330 |
个人学习进度条
第N周 | 新增代码(行) | 累计代码(行) | 本周学习耗时(小时) | 累计学习耗时(小时) | 重要成长 |
---|---|---|---|---|---|
1 | 0 | 0 | 14 | 14 | 学习了Axure Rp9 |
2 | 400 | 400 | 20 | 34 | 学习了HTML、CSS |
3 | 1000 | 1400 | 30 | 64 | 学习了Javascript |
4 | 200 | 1600 | 10 | 74 | 继续学习web前端 |
5 | 400 | 2000 | 4 | 78 | 远程操控数据库 |
6 | 100 | 2100 | 2 | 80 | 学习JS |
7 | 200 | 2300 | 0 | 80 | 无 |