Online Exam System - Project Report
Online Exam System - Project Report
Online Exam System - Project Report
Acknowledgement
I am thankful to Mr. Jayaram Bhatt , CEO , Dream Solutions for giving me the opportunity to work in Dream Solutions which helped me gain knowledge and experience in Software development field. I appreciate all the personal and professional advice given by Mr. Amol Soman during my working tenure. I take this opportunity to express a deep sense of gratitude to Mr. Devashish Pradhan, for his exemplary guidance, monitoring and constant encouragement throughout which helped me in completing this task through various stages. I am obliged to my colleagues of (Dream Solutions), for the valuable information provided by them in their respective fields. I am grateful for their cooperation during the period of my assignment. Thanking you, Madhura Pradhan.
1|Page
Table of Contents
Introduction ......................................................................................................................................4 1.1 Purpose ............................................................................................................................................... 5 Software Development and Methodology ..........................................................................................6 2.1 System Development Life-Cycle.......................................................................................................... 6 Preliminary Analysis: ............................................................................................................................. 7 Systems analysis, requirements definition: .......................................................................................... 7 Systems design: ..................................................................................................................................... 7 Development......................................................................................................................................... 7 Integration and testing: ........................................................................................................................ 7 Planning & Analysis............................................................................................................................8 3.1 Project Planning .................................................................................................................................. 8 3.2 Feasibility Study .................................................................................................................................. 9 Requirement analysis and specification ............................................................................................ 11 4.1 User Characteristics .......................................................................................................................... 11 4.2 Features: ........................................................................................................................................... 12 4.3 Constraints: ....................................................................................................................................... 14 4.4 Benefits: ............................................................................................................................................ 14 4.5 External Interface Requirements: ..................................................................................................... 14 System Design ................................................................................................................................. 16 5.1 Design Strategy ................................................................................................................................. 16 Three-tier architecture........................................................................................................................ 16 Presentation tier ................................................................................................................................. 17 Application tier (business logic, logic tier, data access tier, or middle tier) ....................................... 17 Data tier .............................................................................................................................................. 17 5.2 Data-flow Diagram ............................................................................................................................ 18 1st Level DFD ........................................................................................................................................ 18 2nd Level DFD ....................................................................................................................................... 19 3rd Level DFD ....................................................................................................................................... 20 5.3 Entity Relationship Diagram........................................................................................................... 21 Coding ............................................................................................................................................. 22 6.1 Introduction to MySql ...................................................................................................................... 22 PHP + MySql ........................................................................................................................................ 22 2|Page
Queries ................................................................................................................................................ 22 Open a Connection to the MySQL Server ........................................................................................... 22 Syntax: ................................................................................................................................................. 22 6.2 Database Design................................................................................................................................ 23 Tables in MySql: .................................................................................................................................. 23 Testing............................................................................................................................................. 27 UNIT TESTING .......................................................................................................................................... 28 MODULE LEVEL TESTING ......................................................................................................................... 28 INTEGRATION & SYSTEM TESTING .......................................................................................................... 28 REGRESSION TESTING ............................................................................................................................. 28 Screen Shots .................................................................................................................................... 29 Project Links .................................................................................................................................... 38 Conclusion ....................................................................................................................................... 39 References....................................................................................................................................... 39
3|Page
Introduction
Online Exam System is a full-fledged system which is beneficial for both teachers and students. With this site, Administrator can allow authorized entry of users which includes faculties and students. Faculties are the one who register on the site and conduct timed exams in their respective courses. They can add questions in the test by selecting the available settings. The tests added by faculties are available to students who can attempt the test and get score then and there. Thus the purpose of the site is to provide a system that saves the efforts and time of both the teachers and the students. Online Exam System is a web application that establishes a network between the faculties and the students. Faculties enter on the site the questions they want in the exam. These questions are displayed as a test to the eligible students. The answers enter by the students are then evaluated and their score is calculated and saved. This score then can be accessed by the faculties and administrator to evaluate their performance. Online Exam System provides the platform but does not directly participate in, nor is it involved in any tests conducted. Questions are posted not by the site, but users of the site. The administrator keeps an eye on the overall functioning of the system which includes how many users are using the site, how many tests are added by which faculty, how many students have given those tests and view the score of any student. The system entitled Online Exams System is application software, which aims at providing services to the institutes and providing them with an option of selecting the eligible students by themselves.
4|Page
1.1 Purpose The purpose of on-line test system is to take online test in an efficient manner and no time wasting for checking the paper. It provides online facility to Institutes to conduct online exams and to Students to give online exams. Institutes (i.e the faculties in institute) can enter and edit the questions in test. Students can login and give their respective exams and view their score then and there. The main objective of on-line test simulator is to efficiently evaluate the candidate thoroughly through a fully automated system that not only saves lot of time but also gives fast results
1.2 Scope This website provides facility to institutes to conduct online exams and maintaining the records of users by providing authorized entry. Users can register as Faculty / Student and wait for the admin to send a notification email. User can then login with the valid username and password and can carry out their respective tasks. Maintaining records of users(Faculties and Students) Admin can add/ delete a particular user who registers on site and can view the activities of users i.e. how many tests are added by a particular faculty, how many tests are given by particular student and view their respective scores. Add test in particular course (Faculty) Faculty can add time limited tests in a particular course by adding questions in the same, can view which student has attempted the tests and view their respective scores. Attempt test ( Student) Student can attempt test added by faculty and get their score then and there. They can also get the test review i.e. answer explanation of each question in test.
5|Page
6|Page
Preliminary Analysis:
The objective of phase 1 is to conduct a preliminary analysis, propose alternative solutions, describe costs and benefits and submit a preliminary plan with recommendations. Conduct the preliminary analysis: in this step, you need to find out the organization's objectives and the nature and scope of the problem under study. Even if a problem refers only to a small segment of the organization itself then you need to find out what the objectives of the organization itself are. Then you need to see how the problem being studied fits in with them. Propose alternative solutions: In digging into the organization's objectives and specific problems, you may have already covered some solutions. Alternate proposals may come from interviewing employees, clients, suppliers, and/or consultants. You can also study what competitors are doing. With this data, you will have three choices: leave the system as is, improve it, or develop a new system. Describe the costs and benefits.
Defines project goals into defined functions and operation of the intended application and analyzes end-user information needs.
Systems design:
Describes desired features and operations in detail, including screen layouts, business rules, process diagrams, pseudo-code and other documentation.
Development: The real code is written here.
Brings all the pieces together into a special testing environment, then checks for errors, bugs and inter-operability.
7|Page
8|Page
Technical Feasibility:-
The technical feasibility assessment is focused on gaining an understanding of the present technical resources of the organization and their applicability to the expected needs of the proposed system. It is an evaluation of the hardware and software and how it meets the need of the proposed system This project on Online Exam System will be platform independent since it is being coded in PHP scripting language. HTML is used to create web pages. MySql database will be used for storing data. Hardware requirements used are compatible with all O.S. Only authorized person would be able to use the website so it would be secure. Time-schedule Feasibility:-
A project will fail if it takes too long to be completed before it is useful. Typically this means estimating how long the system will take to develop, and if it can be completed in a given time period using some methods like payback period. Schedule feasibility is a measure of how reasonable the project timetable 9|Page
is. Given our technical expertise, are the project deadlines reasonable? Some projects are initiated with specific deadlines. You need to determine whether the deadlines are mandatory or desirable. The scheduled time for online exam system was about 3 to 4 months and the project is completed in 4 months.
Operational Feasibility:-
Operational feasibility is a measure of how well a proposed system solves the problems, and takes advantage of the opportunities identified during scope definition and how it satisfies the requirements [4] identified in the requirements analysis phase of system development. The operational feasibility assessment focuses on the degree to which the proposed development projects fits in with the existing business environment and objectives with regard to development schedule, delivery date, corporate culture, and existing business processes
Economic Feasibility:-
The purpose of the economic feasibility assessment is to determine the positive economic benefits to the organization that the proposed system will provide. It includes quantification and identification of all the benefits expected. This assessment typically involves a cost/ benefits analysis.
Economic analysis is the most frequently used evaluating the effectiveness of proposed system, more commonly known as Benefit analysis. The Benefit analysis is to determine benefits and savings which are expected from candidate system and compare them with cost. If the benefits are more than the cost, then decision is made to design and implement the system.
10 | P a g e
11 | P a g e
4.2 Features:
The website will allow access only to authorized users with specific roles (Administratormaintains the website, Faculty -Register to conduct the exams, Students-Give the exams online) A summary of the major functions that the website will perform: Register/Login: Admin can directly login on site with the username and password provided by the developer which can be changed later. Admin can view the number of users who register on site and looking at the details of that user can add/delete the user. Faculty and Students should register on site first and wait for the authorization of admin. After receiving notification email from the admin, they can login with their respective username and password. They can change their personal details and login information any time after being authorized by the admin. Institute Information: Admin can add/edit the details about the institute at any given time and it can be seen by the authorized users. Events: Admin can add/delete a event related to institute such as.. The upcoming events added by admin can be viewed by the users Courses: Admin can add the courses which are provided by the institute and add description for the same if necessary. The courses added by admin can be seen by all the faculties and students. Faculty can add the particular courses to My Courses allotted to them from the list added by admin and add tests in that particular course. Student can view the list of courses and attempt test from a particular course at any given time. Test: i. ii. iii. iv. v. Faculty can add test in their course and provide the settings of the same ie. Test Name Test Instructions Total number of questions in the test. Marks of individual questions in the test. Timer for test.
After saving the settings of test, faculty can add questions in the test. They can add and save as many questions as necessary and then select which questions should be displayed to the student among the list of questions added. The number of questions selected should match the number added in the settings of test. After the questions are selected , the faculty should click on save test so that student can view the test.
12 | P a g e
Student can view all the test added by any faculty in any of the course listed by the admin and attempt the same. Student can attempt a particular test only once except due to some unavoidable reasons (like power-cut) the answers get saved in database and the student can resume the test where left. Type of questions: Faculty can add/delete questions in test which can be Multiple-Choice Questions or True-False type Questions. Total number of questions can vary from test to test. Questions: Faculty can add/ edit questions in test by selecting the following details: i. Question Type the question in this field. ii. Question Type Select the type of question (Multiple choice Question or True- False Question ) iii. Options Provide the multiple options and choose the correct answer. iv. Answer Explanation Add the explanation for the correct answer among the given choices. The software calculates the total marks of test based on the details provided by the user after the user(faculty) clicks on save test which can be then attempted by the student. Get Score Student can attempt the test added by faculty and get score then and there. Only one question is displayed at a time and the student has to choose the correct answer and click next. At the end of last question , complete summary of test is displayed i.e which questions are answered/unanswered. The student can go back and change the answer from this page within the time limit of test and then click on submit test to view the score. If the time exceeds , result is calculated on the number of questions attempted by the student. On clicking on submit test student can view the following information: i. Total Marks ii. Correct iii. Incorrect iv. Answered v. Unanswered Admin can view the test attempted by student and even check the marks scored by student in particular test in any of the courses. Faculty can view the test attempted by student in only the test added by that faculty and even check the marks scored by student.
Review Test
13 | P a g e
After getting the score , student can click on review test to get the answer explanation of each question and check which questions were correct/incorrect. Admin can add/delete/make user active/inactive at any given time.
4.3 Constraints:
There are some constrains on the features of web-site listed above. Admin cannot delete course if tests are added by faculty in that particular course. Admin cannot delete a faculty if any student has given the test added by that faculty. The courses added by admin can be added by faculty provided no other faculty has added the same course. That is one course can have only single faculty assigned to it. Faculty cannot delete a particular question in test after the test is saved.
4.4 Benefits:
This website reduces the manual work, maintaining accuracy, increasing efficiency and saving time. Also institutes need not go to develop a new software each time, instead they just register and conduct a test. For students, it saves time of going to far away centers and also they can view their result then and there.
xvii.
Software Interfaces i. ii. iii. iv. v. vi. Operating System : Windows Browser : Google Chrome / Firefox Database Layer : MySql Web Server : APACHE 5.0 Server Side Scripting : PHP Client Side Scripting : JAVA SCRIPT
15 | P a g e
System Design
Three-tier architecture
Three-tier architecture is a clientserver architecture in which the user interface, functional process logic ("business rules"), computer data storage and data access are developed and maintained as independent modules, most often on separate platforms. The three-tier model is a software architecture pattern. Apart from the usual advantages of modular software with well-defined interfaces, the threetier architecture is intended to allow any of the three tiers to be upgraded or replaced
16 | P a g e
independently in response to changes in requirements or technology. For example, a change of operating system in the presentation tier would only affect the user interface code. Typically, the user interface runs on a desktop PC or workstation and uses a standard graphical user interface, functional process logic that may consist of one or more separate modules running on a workstation or application server, and an RDBMS on a database server or mainframe that contains the computer data storage logic. The middle tier may be multi-tiered itself (in which case the overall architecture is called an "n-tier architecture"). By introducing the middle layer, the client is only handling presentation logic. This means that only little communication is needed between the client and the middle tier making the client thin or thinner. An example of a thin client is an Internet browser that allows you to see and provide information fast and almost with no delay.
This is the topmost level of the application. The presentation tier displays information related to such services as browsing merchandise, purchasing and shopping cart contents. It communicates with other tiers by outputting results to the browser/client tier and all other tiers in the network. (In simple terms it's a layer which users can access directly such as a web page, or an operating systems GUI)
Application tier (business logic, logic tier, data access tier, or middle tier)
The logical tier is pulled out from the presentation tier and, as its own layer, it controls an applications functionality by performing detailed processing.
Data tier
This tier consists of database servers. Here information is stored and retrieved. This tier keeps data neutral and independent from application servers or business logic. Giving data its own tier also improves scalability and performance. As more users access the system a three-tier solution is more scalable than the other solutions because you can add as many middle tiers (running on each own server) as needed to ensure good performance (N-tier or multiple-tier).Security is also the best in the three-tier architecture because the middle layer protects the database tier. There is one major drawback to the N-tier architecture and that is that the additional tiers increase the complexity and cost of the installation.
17 | P a g e
User
Admin
Faculty
Student
Login
Register
Login
Register
18 | P a g e
Student
Faculty
Admin
Register
Login
Register
Login
Login
Select test
Select course
Add Course
Start test
Add test
Save Course
Get Score
Add Questions
List Of Courses
Save test
List Of Tests
19 | P a g e
Users
Student
Faculty
Admin
Edit Profile
Edit Profile
Score
20 | P a g e
Diagram:
21 | P a g e
Coding
6.1 Introduction to MySql
Many of the applications that a Web developer wants to use can be made easier by the use of a standardized database to store, organize, and access information. MySQL is an Open Source (GPL) Standard Query Language (SQL) Relational Database Management System (RDBMS) database that is fast, reliable, easy to use, and suitable for applications of any size. SQL is the ANSI-standard database query language used by most databases. SQL is the most popular language for adding, accessing and managing content in a database. It is most noted for its quick processing, proven reliability, ease and flexibility of use. MySQL is an essential part of almost every open source PHP application.
PHP + MySql PHP combined with MySQL are cross-platform (you can develop in Windows and serve on a Unix platform) The main reason for using a scripting language like PHP is because of the interaction with databases it can offer. The things needed to run PHP scripts which access MySQL databases. 1. Webserver - This can either be on a computer of your own or on a web host. Any web server software should work with PHP and MySQL but the best to use is Apache, which is free 2. Installation - PHP also needs to be installed on the server. If it is not already installed you can install it (or ask your web host to install it). It can be downloaded from PHP.net and is also free. 3. MySQL This is actual database software
Queries A query is a question or a request. We can query a database for specific information and have a recordset returned.
Open a Connection to the MySQL Server Before we can access data in a database, we must open a connection to the MySQL server. In PHP, this is done with the mysql_connect() function. Syntax: mysql_connect(host,username,password,dbname);
22 | P a g e
Description Optional. Either a host name or an IP address Optional. The MySQL user name Optional. The password to log in with Optional. The default database to be used when performing queries
Online exam System uses the following database structure for storing user data , test data ,questions data etc. Tables in MySql: 23 | P a g e
1. User Field Id Username Password Security Question Answer Category Approved First Name Last Name Email Address DOB Country City Zip Contact Number Active Gender Type Int Varchar Varchar Varchar Varchar Varchar Int Varchar Varchar Varchar Varchar Varchar Varchar Varchar Varchar Int Varchar Constraints Primary Key
This table stores the information of user (admin, faculty and student) that is personal as well as login information and primary key id which auto-increments every-time a new user registers. Personal information includes First Name, Last Name, Email Address, Contact info etc. Login Information includes username, password, Security Question etc. One column named Category is introduced to recognize whether the user is Admin, faculty or student. And another special column named Approved is used for authorized entry of users. i.e. this column is set when admin adds the respective user.
2. Schoolprofile Field Id School Name School Address School Email Country City Zip Contact Number Type Int Varchar Varchar Varchar Varchar Varchar Varchar Varchar Constraints Primary Key
This table stores the details of the institute which includes institute name, address, contact information, email address, country, city etc. 24 | P a g e
3. Courses Field PID Course Name Course Description id Type Int Varchar Varchar int Constraints Primary Key
Foreign Key
This table stores the courses added by admin i.e Course Name and Course Description and one primary key PID which auto-increments every-time a new course is added. There is additional Foreign key id which states which user(faculty) has added that course. 4. Events Field eid Event Name Event Description Type Int Varchar Varchar Constraints Primary Key
This table stores the events added by admin i.e Event Name and Event Description and one primary key eid which auto-increments every-time a new event is added. 5. Test Field tid Test Name Test Instruction TotalQ MperQ Timer Total Id PID Type Int Varchar Varchar Double Double Varchar Double Int Int Constraints Primary Key
This table stores the details of tests added by any faculty which includes Test Name , Test Instruction , Total Questions , Marks per question , Timer. There is one primary key tid which auto-increments every-time a new test is added by any faculty. There are two foreign keys id and PID which states which user(faculty) has added test in which course.
25 | P a g e
6. Questions Field qid Question Type Question Option1 Option2 Option3 Option4 CA Answer Explanation Marks Qnum Columnnum tid Type Int Varchar Varchar Varchar Varchar Varchar Varchar Varchar Varchar Double Double Int int Constraints Primary Key
Foreign Key
This table stores the details of questions added in test which includes serial number ,Question , Type of Question , options , Correct Answer , Answer Explanation. There is one primary key qid which auto-increments every-time a new question is added in any test. There is foreign key tid which states which question is added in which test. 7. Checkquestion
Type Int Int Int Int Varchar Varchar Varchar Double Double
This table stores the answer choices of user and whether the student has answered/not answered the particular question in a test.
26 | P a g e
Testing
System testing is a critical aspect of Software Quality Assurance and represents the ultimate review of specification, design and coding. Testing is a process of executing a program with the intent of finding an error. A good test is one that has a probability of finding an as yet undiscovered error. The purpose of testing is to identify and correct bugs in the developed system. Nothing is complete without testing. Testing is the vital to the success of the system. In the code testing the logic of the developed system is tested. For this every module of the program is executed to find an error. To perform specification test, the examination of the specifications stating what the program should do and how it should perform under various conditions. Unit testing focuses first on the modules in the proposed system to locate errors. This enables to detect errors in the coding and logic that are contained within that module alone. Those resulting from the interaction between modules are initially avoided. In unit testing step each module has to be checked separately. System testing does not test the software as a whole, but rather than integration of each module in the system. The primary concern is the compatibility of individual modules. One has to find areas where modules have been designed with different specifications of data lengths, type and data element name. Testing and validation are the most important steps after the implementation of the developed system. The system testing is performed to ensure that there are no errors in the implemented system. The software must be executed several times in order to find out the errors in the different modules of the system. Validation refers to the process of using the new software for the developed system in a live environment i.e., new software inside the organization, in order to find out the errors. The validation phase reveals the failures and the bugs in the developed system. It will be come to know about the practical difficulties the system faces when operated in the true environment. By testing the code of the implemented software, the logic of the program can be examined. A specification test is conducted to check whether the specifications stating the program are performing under various conditions. Testing may be done at 4 levels Unit Level Module Level Integration & System Regression
27 | P a g e
UNIT TESTING
A Unit corresponds to a screen /form in the package. Unit testing focuses on verification of the corresponding class or Screen. This testing includes testing of control paths, interfaces, local data structures, logical decisions, boundary conditions, and error handling. Unit testing may use Test Drivers, which are control programs to co-ordinate test case inputs and outputs, and Test stubs, which replace low-level modules. A stub is a dummy subprogram.
REGRESSION TESTING
Each modification in software impacts unmodified areas, which results serious injuries to that software. So the process of re-testing for rectification of errors due to modification is known as regression testing.
28 | P a g e
2.
Registration Screen
29 | P a g e
30 | P a g e
6.
31 | P a g e
32 | P a g e
33 | P a g e
34 | P a g e
2. Test Screen
35 | P a g e
4. Score Screen
36 | P a g e
37 | P a g e
Project Links
Subdomain Name : madhura.6te.net FTP Information:
Host : 6te.net Username : madhura.6te.net Password: ********* Link: http://6te.freewebhostingarea.com/ftp/.
Database Information:
Link: http://6te.freewebhostingarea.com/pma/. Database name: 691242 Username: 691242 Password: *********
38 | P a g e
Conclusion
The project report entitled ONLINE EXAMINATION has come to its final stage. The system has been developed with much care that it is free of errors and at the same time it is efficient and less time consuming. The important thing is that the system is robust. Also provision is provided for future developments in the system. The entire system is secured. This online system will be approved and implemented soon.
39 | P a g e