首页 > 其他分享 >ISAD1000/5004 Software Engineering

ISAD1000/5004 Software Engineering

时间:2024-10-20 19:09:57浏览次数:1  
标签:use code ISAD1000 will Engineering test maze your Software

Introduction to Software Engineering (ISAD1000/5004)Semester 2, 2024

Due: Friday 18 October, 23:59 GMT+8Weight: 50% of the unit markNoteThis document is subject to clarifications and minor changes that remove ambiguity oraddressfrequently asked questions. It is strongly recommended that you monitorannouncements for any additional information.

1 Introduction

This is the final assessment for Introduction to Software Engineering (ISAD1000/5004). It willassess your competency in designing modular software, using versioncontrol to develop yoursoftware, design test cases, and implement those test cases for your software. As part of eachof these tasks, you will document your work clearly enough that others would be able tofollow along and be able to maintain your work.You will have three weeks to complete this assessment. It is strongly recommended that youplan your time accordingly and begin work as soon as possible.

2 The Scenario

Your task will be to process output from a maze-generating program in order to create asmoother, more appealing output for terminal display. The maze-generating program hasalready been created for you; your task is solely to modify the output.Currently, the programgenerates a simple maze and displays the maze in a format made up only of ‘+’, ‘-‘ and ‘|’characters. While this is suitable for simple display, it is not the most intuitive to read for ahuman and your task is to improve on this using Box-Drawing Characters (which are discussedin more detail in section 2.1).As an example, here is the kind of input you can expect (on the left) and how your programshould output the maze (on the right):Note that the primary display for this will be on the terminal. You may find that due todifferences in font spacing, word processors may display the output incorrectly. Editors

dedicated to coding, such as vim or VS Code, will likely display the characters correctly.

2.1 Maze StructureThe final output for the maze will be drawn using entirely box-drawing characters. The full list

of box-drawing characters may be found in the Wikipedia article, but you will only need asmall subset of characters for this assessment. A maze may be made up of the followingcharacters (and their associated codes):If you happen to be familiar with mazes, this might not seem like a complete set, as the linesare ever only being drawn up and right. However, the algorithm for creating the maze willnever generate a case where other characters (such as ╋ or ┳) would be used.Only thecharacters listed above will be used.The maze is structured as a 2D array, where each ‘cell’ is either linked or not linked to one ofits neighbours. As an example, if the program were to generate a “maze” where each cell waslinked to every neighbour it would generate (and your expected outputwould be):… if no cell were linked, the following maze would be generated (and your expected outputwould be):In order to determine which is the appropriate character, you will need to inspect a cell in this2D array and look at each of its neighbours.A full horizontal line can be determined in the following case, because the corner character

(‘+’) has walls (‘-‘) on the left and right, but not up or down:NoteHINT: It is suggested that you read from the source maze and write to an output maze:do not overwrite the source maze, as you will lose/overwrite information that may bevaluable for both earlier and later cells.2.2 Maze Generating ProgramAs part of this assessment, you will be provided with a simple program that generates outputas outlined above. You are encouraged to use this program to become familiar with theoutput and to use cases generated by this program to assist in testing (but theyare NOTsufficient for your testing - you must construct test cases that are GOODtest cases, not justrandom tests). The program is in a language called Ruby. You do not need to learn thislanguage to use the program. There are four source code files included with this:■ binary_tree_demo.rb■ binary_tree.rb

■ grid.rb■ cell.rbTo run the program, you use the following command on either the lab machines or VMWareHorizon:ruby -I. binary_tree_demo.rb

The program will output the maze to the terminal and exit. You may wish to save the output to

a file, which can be done with I/O redirection with the following command:ruby -I. binary_tree_demo.rb > maze_output.txt(Any name can be specified instead of maze_output.txt)3 The TasksFor this assignment, you will create documentation for, and be assessed on, these tasks:■ Version Control

■ Modularity Design

■ Modularity Implementation

■ Test Design■ Test Implementation

■ Summary of Work

ALL these tasks will primarily be assessed through your documentation. All code that youcreate will, however, need to also be submitted to verify your work has been done.

3.1 Version Control

As part of this assignment, you are to apply version control to keep track of your work.■ Create a short plan, identify what branches you will need, why you need them, andwhen the branches will be merged.

■ Create a Git local repository for use throughout this assessment. The repository nameshould be in the format of __ISE_Repo

▸ e.g. Brower_Arlen12345678_ISE_Repo■ Commit all code and documents you create in the assessment▸ You are expected to use meaningful commits; while there is no hard rule about

what each commit should contain, you are expected to show your代 写ISAD1000/5004  Software Engineering   ability to useversion control meaningfully. Marks are not awarded for number of commits.■ Include evidence of your use of version control, such as an image of the log

Any other discussion or explanation on your use of version control should also be included in

the documentation.

Warning

Do not use GitHub, BitBucket, or any other similar online repositories. Doing so runs therisk of potential collusion investigations. Similarly, do not upload your code to onlinerepositories even after the assignment due date; other students may have extensions or

deferred assessments.

3.2 Modularity Design

With the given scenario, you are to identify the most suitable modules you will need for yoursoftware to achieve the required functionality, considering the goodmodularity principles

discussed in lectures/worksheets. You are to:■ Write down module descriptions for each module you decide to implement.Descriptions should include:

▸ A meaningful name

▸ A clear and detailed explanation on the intended task of the module

▸ Imports, if any

▸ Export, if any

■ Explain your design decisions and how they conform to good modularity principles

NoteIt’s rare that you will get the design 100% ideal from the very start. Design is ofteniterative. This is actually a very good, interesting thing to include in your documentationfor this assessment. If you find it necessary to change or modify your design at somepoint in this assessment, make note and document those changes. Similarly, if you run

into issues or find your design could be made better somehow, include that discussion aswell – you might not have time to make the perfect assignment, but selfreflection about

what could be improved is a vital skill.

3.3 Modularity ImplementationYou are to implement the software using your designs, review the code you have written, andrefactor it. As part of this task, you should:

■ Implement the modules designed in the previous section

▸ You may use Java or Python for your implementation

▸ Your code must run on the lab machines or VMWare Horizon

■ Create a short review checklist to determine if you have followed good modularityrinciples. You are expected to cover all basic guidelines covered in lecture 7.

■ Review your code using the prepared checklist, identifying any issues. You must use theformat suggested in worksheet 7 to record your results. Each module must be

reviewed.■ If you have identified any issues, refactor your code to address such issues.

▸ If you refactor your code, explain how it is improved;▸ If you do not refactor your code, justify your decision

■ After refactoring, revise your preliminary descriptions of your modules.

■ At every stage, you should be making changes and committing those changes to therepo whenever you have made a step you are satisfied with. Don’t commit it all in oneblob, but also don’t commit just every little change.

3.4 Test Design

You are to design tests using both black box and white box methodologies.

■ Black box test design:

▸ For each module, according to module descriptions, design suitable test cases.

▸ Describe how you decide upon your test values for each test case

▸ Test cases should each also describe their expected output or behaviour

■ White box test design:

▸ Identify at least two modules where white-box testing will be beneficial

▸ Design test cases to cover functionality of the selected modules using white boxtesting▸ You must test at least two different types of control flow constructs

▸ Describe how you decide upon your test values for each test case

▸ Again, be comitting these test cases to the repo as you write and are satisfiedwith them

3.5 Test ImplementationImplement your test designs in either Python or Java. You may use test fixtures to organiseyour test code. Using a unit test framework is optional.Your documentation should:

■ Identify the actual results for each test case

■ Identify any failures, and attempt to improve your code

▸ Be sure to document this process, as it again makes for useful discussion for thisassessment3.6 Summary of WorkYou are to produce a table clearly showing your overall module design and the final status ofeach module. This is to primarily assist your marker in determining how complete your work

■ Each module should have one row

■ For each module, you should identify if the following work has been done:

▸ Whether or not the module is complete;

▸ Whether or not the module’s tests have been designed;

▸ Whether or not the module’s tests have been implemented;

▸ Whether or not the module’s tests are successful

Additionally, your submission must include a short video roughly two minutes in lengthdemonstrating that your code is working. More information on this video included in section

5 of this document.4 DocumentationAs noted, your work will primarily be assessed through your documentation. All informationutlined above must be included in your documentation and yourdocumentation must besubmitted to Turnitin as a .pdf file. In addition to the tasks outlined above, your

documentation must also include:

■ A cover page; include the assessment name, your name in Blackboard, your student ID,

and your practical date/time.

■ An introduction; briefly describe and overview of your work

■ Discussion; reflect on your own work, including a summary of what you have achieved,

challenges you have faced, limitations, and ways to improve your work with otherfeatures you have not considered.

▸ You may include other information if you feel it would be useful to clarifyanything about your submission

Additionally, marks are allocated for a neat and professional document.

5 Video DemonstrationYour submission must include a short, two minute video that demonstrates your codeworking. As part of this video state your name and student number first and then give anoverview of your code. You do not need to go into the source code and explain any decisions,it is sufficient to show that your code is working. This is helpful in assisting your markertroubleshoot issues if any are encountered.

NoteYou may be asked after the submission to attend a short demonstration via MicrosoftTeams in order to ensure academic integrity. Please keep an eye on your emailandannouncements to this effect. If you do have a request to attend a demonstration in thisway, you must attend. A request to demonstrate is not an allegation of misconduct, but ispart of the process to ensure academic integrity in the unit.

6 Assessment Submission

You are to submit your assessment in three locations on Blackboard:

■ Declaration of Originality submission point

■ A Turnitin submission point

■ A general submission point

6.1 Declaration of Originality submission pointAs part of this submission, you will submit a Declaration of Originality stating that this work isyour own, has not copied anyone else, and any sources are appropriately referenced. Thismay be a .pdf, .odt, or .docx file and must be signed and dated.If you forget to submit your Declaration of Originality, do not resubmit to any other

submission point; only submit your Declaration of Originality to this location. A declaration oforiginality can be submitted after the due date if a mistake is made, however, you cannotreceive a mark for this submission until a declaration has been received.

6.2 Turnitin submissionYour Turnitin submission will only include the Documentation .pdf as outlined above. No

source code files are to be included in this submission; no .zip files will be accepted. You mustbe the one to submit your .pdf through Turnitin, at which point it isregistered.6.3 General submission point

The general submission point should include all files created throughout the assessment(including the .pdf submitted to Turnitin). This should include:

■ Your documentation .pdf file

■ A .zip (not .rar, not .7z, etc.) file containing your Git repository (including the hidden.git folder) and all associated source files, test inputs, etc.▸ Note that your Git repository is NOT just your working directory (source files), it isinside the hidden .git folder. Do NOT miss including this in the .zip file.

■ A single README file; a short text indicating how to use your program

■ Your short 2 minute video demonstrating how to run the system and test cases

7 MarkingThe allocation of marks for this assessment are as follows:

■ Test Design

[7 marks]In summary, this is an assessable task. If you use someone else’s work or assistance to helpcomplete part of the assignment, where it’s intended that you complete it yourself, you willhave compromised the assessment. You will not receive marks for any parts of yoursubmission that are not your own original work. Further, if you do not reference any externalsources that you use, you are committing plagiarism and/or collusion, and penalties for

misconduct may apply.Curtin also provides general advice on academic integrity at academicintegrity.curtin.edu.au.The unit coordinator may require you to provide anoral justification of, or to answerquestions about, any piece of written work submitted in this unit. Your response(s) may bereferred to as evidence in an academic misconduct inquiry.

标签:use,code,ISAD1000,will,Engineering,test,maze,your,Software
From: https://www.cnblogs.com/goodlunn/p/18487035

相关文章

  • Get Things Done with Prompt Engineering and LangChain: 构建强大的AI应用
    探索AI应用开发的新境界在人工智能快速发展的今天,如何高效地利用大型语言模型(LLMs)构建实用的AI应用,已经成为许多开发者关注的焦点。GitHub上一个名为'GetThingsDonewithPromptEngineeringandLangChain'的开源项目,为我们提供了一个绝佳的学习资源。这个项目不仅包含了......
  • com.microsoft.sqlserver.jdbc.SQLServerException: Software caused connection abor
    报错原因今天新安装的SQLSERVER2012,于是ruoyi框架就测试多数据源,结果发现无法连接。奇怪的是navicat可以连接,SQLServerManagementStudio也可以正常连接。我们都知道SQLSERVER默认的端口是1433,结果我用1433连接不上。于是查询了端口,发现只有1434端口开着,这个端口一看就是......
  • FIT2107 - Software Quality and Testing
    FIT2107-SoftwareQualityandTestingASSIGNMENT2[40%]WhiteboxtestingandcodeanalysisOverviewForthisassignment,yourtaskistodesignanddocumentappropriatetestsforasoftwaresystemusingwhiteboxtechniques,buildaCI/CDpipelinetor......
  • Heavy Duty Truck Diagnostic Scanner and Software
     Intheworldofheavy-dutytrucks,ensuringoptimalperformanceandquicktroubleshootingisofutmostimportance.Astechnologyadvances,thetoolsavailablefordiagnosticsandmaintenancehavebecomeincreasinglysophisticated.Thisarticlewilldelv......
  • 【有啥问啥】逆向工程(Reverse Engineering,RE):深度解析与技术方法
    逆向工程(ReverseEngineering,RE):深度解析与技术方法引言逆向工程(ReverseEngineering,简称RE),作为现代科技领域中的一项重要技术,其影响力已远远超越了传统的硬件拆解范畴。在软件安全、产品设计优化、知识产权保护,以及教育与研究等多个领域,逆向工程都展现出了其独特的价值和......
  • Software Engineering软件工程复习笔记
    program中包含了instructions和datastructures,记法:idd  记法:qu去cd,减少cd,加快输出 ......
  • Cisco Firepower 9300 Series FTD Software 7.6.0 & ASA Software 9.22.1
    CiscoFirepower9300SeriesFTDSoftware7.6.0&ASASoftware9.22.1FirepowerThreatDefense(FTD)Software-思科防火墙系统软件请访问原文链接:https://sysin.org/blog/cisco-firepower-9300/,查看最新版。原创作品,转载请保留出处。作者主页:sysin.orgCiscoSecure防......
  • Cisco Firepower 4100 Series FTD Software 7.6.0 & ASA Software 9.22.1
    CiscoFirepower4100SeriesFTDSoftware7.6.0&ASASoftware9.22.1FirepowerThreatDefense(FTD)Software-思科防火墙系统软件请访问原文链接:https://sysin.org/blog/cisco-firepower-4100/,查看最新版。原创作品,转载请保留出处。作者主页:sysin.orgCiscoSecure防......
  • Cisco Firepower 1000 Series FTD Software 7.6.0 & ASA Software 9.22.1
    CiscoFirepower1000SeriesFTDSoftware7.6.0&ASASoftware9.22.1FirepowerThreatDefense(FTD)Software-思科防火墙系统软件请访问原文链接:https://sysin.org/blog/cisco-firepower-1000/,查看最新版。原创作品,转载请保留出处。作者主页:sysin.org面向小型办公室......
  • Cisco Secure Firewall 3100 Series FTD Software 7.6.0 & ASA Software 9.22.1
    CiscoSecureFirewall3100SeriesFTDSoftware7.6.0&ASASoftware9.22.1FirepowerThreatDefense(FTD)Software-思科防火墙系统软件请访问原文链接:https://sysin.org/blog/cisco-firepower-3100/,查看最新版。原创作品,转载请保留出处。作者主页:sysin.orgCiscoSec......