Event Management Project Report
Event Management Project Report
Event Management Project Report
INTRODUCTION
Event management is a process of organizing a professional and focused event, for a particular
target audience. It involves visualizing concepts, planning, budgeting, organizing and executing
events such as wedding, musical concerts, corporate seminars, exhibitions, birthday celebrations,
theme parties, etc. Event Management is a multi-million dollar industry, growing rapidly, with
events hosted regularly. Surprisingly, there is no formalized research conducted to access the
growth of this industry. The industry includes fields such as the MICE (Meetings, Incentives and
Events), exhibitions, conferences and seminars as well as live music and sporting events. On the
profession side, event management is a glamorous and exciting profession that demands a lot of
hard work and dynamism. The logistics side of the industry is paid less than the
sales/sponsorship side, though some may say that these are two different industries.
Event management is the application of project management to the creation and development of
large scale events. The process of planning and coordinating the event is usually referred to
as event planning and which can include budgeting, scheduling, site selection, acquiring
necessary permits, coordinating transportation and parking, arranging for speakers or
entertainers, arranging decor, event security, catering, coordinating with third party vendors, and
emergency plans. The events industry now includes events of all sizes from the Olympics down
to business breakfast meetings. Many industries, charitable organizations, and interest groups
hold events in order to market themselves, build business relationships, raise money, or celebrate
achievement.An event refers to a social gathering or activity, such as a festival,( for example a
musical festival), a ceremony( for example a marriage ) and a party(for example a birthday
party).There are mainly 3 types of event management:
The Event Manager is the person who plans and executes the event. Event managers and their
teams are often behind-the-scenes running the event. Event managers may also be involved in
more than just the planning and execution of the event, but also brand building, marketing and
communication strategy. The event manager is an expert at the creative, technical and logistical
elements that help an event succeed. This includes event design, audiovisual production,
scriptwriting, logistics, budgeting, negotiation and, of course, client service. It is a
multidimensional profession.
There are 2 stages of event management process namely, Event planning and Event control.
Event Planning: To plan an event we must consider the following areas of an event,
viz, feasibility, promotion, site choice/design, staging, shutdown, site map, event
proposal.
Event Control: To control an event we must look on the following areas logistics,
negotiations, costing & cash flow, event manual, I.T, decision making and change,
risk management.
The objective of this application is to develop a system that effectively manages all the data
related to the various events that take place in an organization. The purpose is to maintain a
centralized database of all event related information. The goal is to support various functions and
processes necessary to manage the data efficiently.
This existing system is not providing secure registration and profile management of all the users
properly. This system is not providing on-line help. This system doesn’t provide
tracking of users activities and their progress. This manual system gives us very less security for
saving data and some data may be lost due to mismanagement. This system is not providing
event management through internet. This system is not providing proper events information. The
system is giving manual information through the event management executer.
Operational feasibility is the 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 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.To ensure success,
desired operational outcomes must be imparted during design and development. These include
such design-dependent parameters as reliability, maintainability, supportability, usability,
producibility, disposability, sustainability, affordability and others. These parameters are
required to be considered at the early stages of design if desired operational behaviours are to be
realised. A system design and development requires appropriate and timely application of
engineering and management efforts to meet the previously mentioned parameters. A system
may serve its intended purpose most effectively when its technical and operating characteristics
are engineered into the design. Therefore, operational feasibility is a critical aspect of systems
engineering that needs to be an integral part of the early design phases.
This involves questions such as whether the technology needed for the system exists, how
difficult it will be to build, and whether the firm has enough experience using that
technology.The assessment is based on outline design of system requirements in terms of
input,processes,output,fields,programs and procedures.This can be qualified in terms of
volume of data,trends,frequency of updating inorder to give an introduction to the technical
system.The application is the fact that it has been developed on windows XP platform and a
high configuration of 1GB RAM on Intel Pentium Dual core processor.This is technically
feasible .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.
Establishing the cost-effectiveness of the proposed system i.e. if the benefits do not outweigh
the costs then it is not worth going ahead. In the fast paced world today there is a great need of
online social networking facilities. Thus the benefits of this project in the current scenario
make it economically feasible. 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.
CHAPTER 2
REQUIREMENT ANALYSIS
PROPOSED SYSTEM
Event Management System is an online event management software project that serves the
functionality of an event manager. The system allows only registered users to login and new
users are allowed to register on the application. This is a web application but desktop application
of the same application is also available. The project provides most of the basic functionality
required for an event. It allows the user to select from a list of event types. Once the user enters
an event type eg(Marriage, Stage Show etc), the system then allows the user to select the date
and time of event, place and the event equipment’s. All this data is logged in the database and the
user is setting up his username and password while registering. The data is then sent to the
administrator (website owner) and they may interact with the client as per his requirements and
his contact data stored in the database.
3.1 ADVANTAGES
The system is useful as it calculates an exact cost for all the resources required during the
event.
The user gets all the resources at a single place instead of wandering around for these.
This system is effective and saves time and cost of the users.
CHAPTER 4
4.1 DESIGN
Design is the first step in development phase for any techniques and principles for the purpose of
defining a device , a process or system in sufficient detail to permit its physical realization.Once
the software requirement have been analyzed and specified the software design involves three
technical activities-Design,Coding,Implementation,Testing that are required to build and verify
the software.The design activities are of main importance in this phase,because in this activities
decisions ultimately affecting the success of the software implementation and its ease of
maintenance are made.These decision has the final bearing upon reliability and maintainability
of the asystem.Design is only way to accurately transfer the customers requirements into finished
software or system .Design is the place where quality is fostered in development.Software design
is the process through which requirements are translated into a representation of
software.Software requirement is conducted in two steps.Preliminary design is concerned with
the transformation of requirements into data.
The system after careful analysis has been identified to be presented with the following modules.
4.3ARCHITECTURE
An Entity Relationship Diagram (ERD) is a graphical tool to express the overall structure of a
database. It is based on a perception of a real world which consists of a set of basic objects. An
entity is a person, place, thong or event of interest to the organization and about which data are
captured, stored or processed. The attributes are various kinds of data that describes an entity. An
association of several entities in an Entity-Relationship model is called relationship.
CHAPTER 5
5.1.1.PHP
PHP is a server-side scripting language designed primarily for web development but also used as
a general-purpose programming language. Originally created by Rasmus Lerdorf in 1994, the
PHP reference implementation is now produced by The PHP Development Team. PHP originally
stood for personal home page but it now stands for the recursive acronym PHP: Hypertext
Preprocessor.
PHP code may be embedded into HTML or HTML5 code, or it can be used in combination with
various web template systems, web content management systems and web frameworks. PHP
code is usually processed by a PHP interpreter implemented as a module in the web server or as
a Common Gateway Interface (CGI) executable. The web server combines the results of the
interpreted and executed PHP code, which may be any type of data, including images, with the
generated web page. PHP code may also be executed with a command-line interface (CLI) and
can be used to implement standalone graphical applications.
The standard PHP interpreter, powered by the Zend Engine, is free software released under
the PHP License. PHP has been widely ported and can be deployed on most web servers on
almost every operating system and platform, free of charge.
The PHP language evolved without a written formal specification or standard until 2014, leaving
the canonical PHP interpreter as a de facto standard. Since 2014 work has gone on to create a
formal PHP specification.PHP development began in 1995 when Rasmus Lerdorf wrote
several Common Gateway Interface (CGI) programs in C, which he used to maintain
his personal homepage. He extended them to work with web forms and to communicate
with databases, and called this implementation "Personal Home Page/Forms Interpreter" or
PHP/FI.
PHP/FI could help to build simple, dynamic web applications. To accelerate bug reporting and to
improve the code, Lerdorf initially announced the release of PHP/FI as "Personal Home Page
Tools(PHPTools)version1.0"onthe Usenet discussiongroup comp.infosystems.www.authoring.cg
i on June 8, 1995. This release already had the basic functionality that PHP has as of 2013. This
included Perl-like variables, form handling, and the ability to embed HTML.
The syntax resembled that of Perl but was simpler, more limited and less consistent.
Lerdorf did not intend the early PHP to become a new programming language, but it grew
organically, with Lerdorf noting in retrospect. A development team began to form and, after
months of work and beta testing, officially released PHP/FI 2 in November 1997.
The fact that PHP lacked an original overall design but instead developed organically has led to
inconsistent naming of functions and inconsistent ordering of their parameters. In some cases,
the function names were chosen to match the lower-level libraries which PHP was
"wrapping",while in some very early versions of PHP the length of the function names was used
internally as a hash function, so names were chosen to improve the distribution of hash values.
PHP 3 and 4
Zeev Suraski and Andi Gutmans rewrote the parser in 1997 and formed the base of PHP 3,
changing the language's name to the recursive acronym PHP:Hypertext Preprocessor.
Afterwards, public testing of PHP 3 began, and the official launch came in June 1998. Suraski
and Gutmans then started a new rewrite of PHP's core, producing the Zend Engine in 1999. They
also founded Zend Technologies in Ramat Gan, Israel. On May 22, 2000, PHP 4, powered by the
Zend Engine 1.0, was released. As of August 2008 this branch reached version 4.4.9. PHP 4 is
no longer under development nor will any security updates be released.
PHP 5
On July 13, 2004, PHP 5 was released, powered by the new Zend Engine II. PHP 5 included new
features such as improved support for object-oriented programming, the PHP Data Objects
(PDO) extension (which defines a lightweight and consistent interface for accessing databases),
and numerous performance enhancements. In 2008 PHP 5 became the only stable version under
development. Late static binding had been missing from PHP and was added in version 5.3.
Many high-profile open-source projects ceased to support PHP 4 in new code as of February 5,
2008, because of the GoPHP5 initiative, provided by a consortium of PHP developers promoting
the transition from PHP 4 to PHP 5. Over time, PHP interpreters became available on most
existing 32-bit and 64-bit operating systems, either by building them from the PHP source code,
or by using pre-built binaries. For the PHP versions 5.3 and 5.4, the only available Microsoft
Windows binary distributions were 32-bit x86 builds, requiring Windows 32-bit compatibility
mode while using Internet Information Services (IIS) on a 64-bit Windows platform. PHP
version 5.5 made the 64-bit x86-64 builds available for Microsoft Windows.
PHP has received criticism due to lacking native Unicode support at the core language level,
instead only supporting byte strings. In 2005, a project headed by Andrei Zmievski was initiated
to bring native Unicode support throughout PHP, by embedding the International Components
for Unicode (ICU) library, and representing text strings as UTF-16 internally. Since this would
cause major changes both to the internals of the language and to user code, it was planned to
release this as version 6.0 of the language, along with other major features then in development.
However, a shortage of developers who understood the necessary changes, and performance
problems arising from conversion to and from UTF-16, which is rarely used in a web context, led
to delays in the project. As a result, a PHP 5.3 release was created in 2009, with many non-
Unicode features back-ported from PHP 6, notably namespaces. In March 2010, the project in its
current form was officially abandoned, and a PHP 5.4 release was prepared containing most
remaining non-Unicode features from PHP 6, such as traits and closure re-binding. Initial hopes
were that a new plan would be formed for Unicode integration, but as of 2014 none have been
adopted.
PHP 7
During 2014 and 2015, a new major PHP version was developed, which was numbered PHP 7.
The numbering of this version involved some debate. While the PHP 6 Unicode experiment had
never been released, several articles and book titles referenced the PHP 6 name, which might
have caused confusion if a new release were to reuse the name. After a vote, the name PHP 7
was chosen.The foundation of PHP 7 is a PHP branch that was originally dubbed PHP next
generation (phpng). It was authored by Dmitry Stogov, Xinchen Hui and Nikita Popov, and
aimed to optimize PHP performance by refactoring the Zend Engine to use more compact data
structures with improved cache locality while retaining near-complete language compatibility.
As of 14 July 2014, WordPress-based benchmarks, which served as the main benchmark suite
for the phpng project, showed an almost 100% increase in performance. Changes from phpng are
also expected to make it easier to improve performance in the future, as more compact data
structures and other changes are seen as better suited for a successful migration to a just-in-
time (JIT) compiler. Because of the significant changes, the reworked Zend Engine is
called Zend Engine 3, succeeding Zend Engine 2 used in PHP 5. Because of major internal
changes in phpng, it must receive a new major version number of PHP, rather than a minor PHP
5 release, according to PHP's release process. Major versions of PHP are allowed to break
backward-compatibility of code and therefore PHP 7 presented an opportunity for other
improvements beyond phpng that require backward-compatibility breaks, including wider use
of exceptions, reworking variable syntax to be more consistent and complete, and the
deprecation or removal of various legacy features. PHP 7 also introduced new language features,
including return type declarations for functions,which complement the existing parameter type
declarations, and support for the scalar types (integer, float, string, and boolean) in parameter and
return type declarations.
Data Types
value; NULL is the only allowed value for this data type.
Variables of the "resource" type represent references to resources from external sources. These
are typically created by functions from a particular extension, and can only be processed by
functions from the same extension; examples include file, image, and database resources.
Arrays can contain elements of any type that PHP can handle, including resources, objects, and
other arrays. Order is preserved in lists of values and in hashes with both keys and values, and
the two can be intermingled. PHP also supports strings, which can be used with single quotes,
double quotes, nowdoc or heredoc syntax. The Standard PHP Library (SPL) attempts to solve
standard problems and implements efficient data access interfaces and classes.
Functions
PHP defines a large array of functions in the core language and many are also available in
various extensions,these functions are well documented in the online PHP
documentation. However, the built-in library has a wide variety of naming conventions and
associated inconsistencies, as described under history above.
In lieu of function pointers, functions in PHP can be referenced by a string containing their
name. In this manner, normal PHP functions can be used, for example, as callbacks or
within function tables. User-defined functions may be created at any time without
being prototyped. Functions may be defined inside code blocks, permitting a run-time
Until PHP 5.3, support for anonymous functions and closures did not exist in PHP.
While create_function() exists since PHP 4.0.1, it is merely a thin wrapper around eval() that
allows normal PHP functions to be created during program execution. PHP 5.3 added syntax to
define an anonymous function or "closure"which can capture variables from the surrounding
scope. In the example above, getAdder() function creates a closure using passed
argument $x (the keyword use imports a variable from the lexical context), which takes an
additional argument $y , and returns the created closure to the caller. Such a function is a first-
class object, meaning that it can be stored in a variable, passed as a parameter to other functions,
etc.
Unusually for a dynamically typed language, PHP supports type declarations on function
parameters, which are enforced at runtime. This has been supported for classes and interfaces
since PHP 5.0, for arrays since PHP 5.1, for "callables" since PHP 5.4, and scalar (integer, float,
string and boolean) types since PHP 7.0. PHP 7.0 also has type declarations for function return
types, expressed by placing the type name after the list of parameters, preceded by a colon.For
example, the getAdder function from the earlier example could be annotated with types like so
in PHP 7.
5.1.2 Html
Hypertext Markup Language (HTML) is the standard markup language for creating web
pages and web applications. With Cascading Style Sheets (CSS) and JavaScript it forms a triad
of cornerstone technologies for the World Wide Web. Web browsers receive HTML documents
from a web server or from local storage and render them into multimedia web pages. HTML
describes the structure of a web page semantically and originally included cues for the
appearance of the document.HTML elements are the building blocks of HTML pages. With
HTML constructs, images and other objects, such as interactive forms, may be embedded into
the rendered page. It provides a means to create structured documents by denoting
structural semantics for text such as headings, paragraphs, lists, links, quotes and other items.
HTML elements are delineated by tags, written using angle brackets. Tags such
as <img /> and <input /> introduce content into the page directly. Others such
as <p>...</p> surround and provide information about document text and may include other tags
as sub-elements. Browsers do not display the HTML tags, but use them to interpret the content of
the page.HTML can embed programs written in a scripting language such as JavaScript which
affect the behavior and content of web pages. Inclusion of CSS defines the look and layout of
content. The World Wide Web Consortium (W3C), maintainer of both the HTML and the CSS
standards, has encouraged the use of CSS over explicit presentational HTML.
5.1.3 MySQL
For proprietary use, several paid editions are available, and offer additional functionality.MySQL
is a central component of the LAMP open-source web application software stack (and other
"AMP" stacks). LAMP is an acronym for "Linux, Apache, MySQL, Perl/PHP/Python".
Applications that use the MySQL database
include: TYPO3, MODx, Joomla, WordPress, phpBB, MyBB, and Drupal. MySQL is also used
in many high-profile, large-scale websites, including Google (though not for
searches), Facebook, Twitter, Flickr, and YouTube.
Coding
<?php
session_start();
error_reporting(0);
include('includes/dbconnection.php');
if(isset($_POST['login']))
{
$username=$_POST['username'];
$password=md5($_POST['password']);
$sql ="SELECT * FROM tbladmin WHERE UserName=:username and
Password=:password";
$query=$dbh->prepare($sql);
$query-> bindParam(':username', $username, PDO::PARAM_STR);
$query-> bindParam(':password', $password, PDO::PARAM_STR);
$query-> execute();
$results=$query->fetchAll(PDO::FETCH_OBJ);
if($query->rowCount() > 0)
{
foreach ($results as $result)
{
$_SESSION['odmsaid']=$result->ID;
$_SESSION['login']=$result->username;
$_SESSION['permission']=$result->AdminName;
$get=$result->Status;
}
$aa= $_SESSION['odmsaid'];
$sql="SELECT * from tbladmin where ID=:aa";
$query = $dbh -> prepare($sql);
$query->bindParam(':aa',$aa,PDO::PARAM_STR);
$query->execute();
$results=$query->fetchAll(PDO::FETCH_OBJ);
$cnt=1;
if($query->rowCount() > 0)
{
foreach($results as $row)
{
if($row->Status=="1")
{
echo "<script type='text/javascript'> document.location ='dashboard.php'; </script>";
} else
{
echo "<script>
alert('Your account was disabled Approach Admin');document.location ='index.php';
</script>";
}
}
}
} else{
echo "<script>alert('Invalid Details');</script>";
}
}
?>
<!DOCTYPE html>
<html lang="en">
<?php @include("includes/head.php");?>
<body>
<div class="container-scroller">
<div class="container-fluid page-body-wrapper full-page-wrapper">
<div class="content-wrapper d-flex align-items-center auth p-0">
<div class="row flex-grow">
<div class="col-md-4 p-0">
<div class="auth-form-light text-left p-5">
<div class="brand-logo" align="center">
<img class="img-avatar mb-3" src="assets/img/companyimages/logo.jpg"
alt=""><br>
<h4 class="text-muted mt-4">
Welcome Administrator !
</h4>
</div>
<form role="form" id="" method="post" enctype="multipart/form-data"
class="">
<div class="form-group first">
<input type="text" class="form-control form-control-lg"
name="username" id="exampleInputEmail1" placeholder="Username" required>
</div>
<div class="form-group last">
<input type="password" name="password" class="form-control form-
control-lg" id="exampleInputPassword1" placeholder="Password" required>
</div>
<div class="mt-3">
<button name="login" class="btn btn-block btn-info btn-lg font-weight-
medium auth-form-btn">SIGN IN</button>
</div>
<div class="text-center mt-4 font-weight-light">
<a href="forgot_password.php" class="text-secondary">
Forgot Password
</a>
</div>
</form>
</div>
</div>
<div class="col-md-8 p-0">
<div id="carouselExampleControls" class="carousel slide" data-ride="carousel">
<div class="carousel-inner">
<div class="carousel-item active">
<img class="d-block w-100" src="assets\images\event1.jfif" alt="First slide"
>
</div>
<div class="carousel-item">
<img class="d-block w-100" src="assets\images\event2.jpg" alt="Second
slide">
</div>
</div>
<a class="carousel-control-prev" href="#carouselExampleControls"
role="button" data-slide="prev">
<span class="carousel-control-prev-icon" aria-hidden="true"></span>
<span class="sr-only">Previous</span>
</a>
<a class="carousel-control-next" href="#carouselExampleControls"
role="button" data-slide="next">
<span class="carousel-control-next-icon" aria-hidden="true"></span>
<span class="sr-only">Next</span>
</a>
</div>
</div>
</div>
</div>
</div>
</div>
</body>
</html>
<?php
include('includes/checklogin.php');
check_login();
?>
<!DOCTYPE html>
<html lang="en">
<?php @include("includes/head.php");?>
<body>
<div class="container-scroller">
<?php @include("includes/header.php");?>
<div class="main-panel">
<div class="content-wrapper">
<div class="row">
<div class="col-lg-12 grid-margin stretch-card">
<div class="card">
<div class="modal-header">
<h5 class="modal-title" style="float: left;">Between Dates Reports</h5>
</div>
<div class="col-md-12 mt-4">
<form class="forms-sample" method="post" enctype="multipart/form-data"
class="form-horizontal">
<div class="row ">
<div class="form-group col-md-6 ">
<label for="exampleInputPassword1">From Date</label>
<input type="date" id="fromdate" name="fromdate" value="" class="form-control"
required="">
</div>
<div class="form-group col-md-6">
<label for="exampleInputName1">To Date </label>
<input type="date" id="todate" name="todate" value="" class="form-control"
required="">
</div>
</div>
</div>
</div>
</div>
<?php
if(isset($_POST['search']) & !empty($_POST['fromdate']))
{
?>
<div class="table-responsive p-3">
<?php
$fdate=$_POST['fromdate'];
$tdate=$_POST['todate'];
?>
<h5 align="center" style="color:blue">Report from <?php echo $fdate?> to <?php echo
$tdate?></h5>
<hr />
<table class="table align-items-center table-flush table-hover table-bordered"
id="dataTableHover">
<thead>
<tr>
<th class="text-center"></th>
<th>Booking ID</th>
<th class="d-none d-sm-table-cell">Cutomer Name</th>
<th class="d-none d-sm-table-cell">Mobile Number</th>
<th class="d-none d-sm-table-cell">Email</th>
<th class="d-none d-sm-table-cell">Booking Date</th>
<th class="d-none d-sm-table-cell">Status</th>
<th class=" Text-center" style="width: 15%;">Action</th>
</tr>
</thead>
<tbody>
<?php
$sql="SELECT * from tblbooking where date( BookingDate) between '$fdate' and
'$tdate'";
$query = $dbh -> prepare($sql);
$query->execute();
$results=$query->fetchAll(PDO::FETCH_OBJ);
$cnt=1;
if($query->rowCount() > 0)
{
foreach($results as $row)
{ ?>
<tr>
<td class="text-center"><?php echo htmlentities($cnt);?></td>
<td class="font-w600"><?php echo htmlentities($row->BookingID);?></td>
<td class="font-w600"><?php echo htmlentities($row->Name);?></td>
<td class="font-w600"><?php echo htmlentities($row->MobileNumber);?></td>
<td class="font-w600"><?php echo htmlentities($row->Email);?></td>
<td class="font-w600">
<span class="badge badge-primary"><?php echo htmlentities($row-
>BookingDate);?></span>
</td>
<?php if($row->Status=="")
{
?>
<td class="font-w600"><?php echo "Not Updated Yet"; ?></td>
<?php
} else { ?>
<td class="d-none d-sm-table-cell">
<span class="badge badge-info"><?php echo
htmlentities($row->Status);?></span>
</td>
<?php
} ?>
<td class=" text-center"><a href="#" class=" edit_data4" id="<?php echo ($row-
>ID); ?>" title="click to edit"><i class="mdi mdi-eye" aria-hidden="true"></i></a>
<a href="invoice_generating.php?invid=<?php echo htmlentities ($row->ID);?
>"><i class="mdi mdi-printer" aria-hidden="true"></i></a>
</td>
</tr>
<?php
$cnt=$cnt+1;
}
} ?>
</tbody>
</table>
</div>
<?php
}else{
?>
<div class="table-responsive p-3">
<table class="table align-items-center table-flush table-hover table-bordered"
id="dataTableHover">
<thead>
<tr>
<th class="text-center"></th>
<th>Booking ID</th>
<th class="d-none d-sm-table-cell">Cutomer Name</th>
<th class="d-none d-sm-table-cell">Mobile Number</th>
<th class="d-none d-sm-table-cell">Email</th>
<th class="d-none d-sm-table-cell">Booking Date</th>
<th class="d-none d-sm-table-cell">Status</th>
<th class=" Text-center" style="width: 15%;">Action</th>
</tr>
</thead>
<tbody>
<?php
$sql="SELECT * from tblbooking ORDER BY ID DESC";
$query = $dbh -> prepare($sql);
$query->execute();
$results=$query->fetchAll(PDO::FETCH_OBJ);
$cnt=1;
if($query->rowCount() > 0)
{
foreach($results as $row)
{ ?>
<tr>
<td class="text-center"><?php echo htmlentities($cnt);?></td>
<td class="font-w600"><?php echo htmlentities($row->BookingID);?></td>
<td class="font-w600"><?php echo htmlentities($row->Name);?></td>
<td class="font-w600"><?php echo htmlentities($row->MobileNumber);?></td>
<td class="font-w600"><?php echo htmlentities($row->Email);?></td>
<td class="font-w600">
<span class="badge badge-primary"><?php echo htmlentities($row-
>BookingDate);?></span>
</td>
<?php if($row->Status=="")
{
?>
<td class="font-w600"><?php echo "Not Updated Yet"; ?></td>
<?php
} else { ?>
<td class="d-none d-sm-table-cell">
<span class="badge badge-primary"><?php echo htmlentities($row->Status);?
></span>
</td>
<?php
} ?>
<td class=" text-center"><a href="#" class=" edit_data4 btn btn-info rounded"
id="<?php echo ($row->ID); ?>" title="click to edit"><i class="mdi mdi-eye" aria-
hidden="true"></i></a>
<a href="invoice_generating.php?invid=<?php echo htmlentities ($row->ID);?
>" class="btn btn-primary rounded" ><i class="mdi mdi-printer" aria-hidden="true"></i></a>
</td>
</tr>
<?php
$cnt=$cnt+1;
}
} ?>
</tbody>
</table>
</div>
<?php
} ?>
</div>
</div>
</div>
</div>
<?php @include("includes/footer.php");?>
</div>
</div>
</div>
<?php @include("includes/foot.php");?>
<script type="text/javascript">
$(document).ready(function(){
$(document).on('click','.edit_data4',function(){
var edit_id4=$(this).attr('id');
$.ajax({
url:"view_newbookings.php",
type:"post",
data:{edit_id4:edit_id4},
success:function(data){
$("#info_update4").html(data);
$("#editData4").modal('show');
}
});
});
});
</script>
</body>
</html>
OUTPUT SCREEN
CHAPTER 6
The term implementation has different meanings ranging from the conversation of a basic
application to a complete replacement of a computer system. The procedures however, are
virtually the same. Implementation includes all those activities that take place to convert from
old system to new. The new system may be totally new replacing an existing manual or
automated system or it may be major modification to an existing system. The method of
implementation and time scale to be adopted is found out initially. Proper implementation is
essential to provide a reliable system to meet organization requirement.
In computer programming, unit testing is a software testing method by which individual units
of source code, sets of one or more computer program modules together with associated control
data, usage procedures, and operating procedures, are tested to determine whether they are fit for
use. Intuitively, one can view a unit as the smallest testable part of an application. In procedural
programming, a unit could be an entire module, but it is more commonly an individual function
or procedure. In object-oriented programming, a unit is often an entire interface, such as a class,
but could be an individual method. Unit tests are short code fragmentscreated by programmers or
occasionally by white box testers during the development process. It forms the basis for
component testing. Ideally, each test case is independent from the others. Substitutes such
as method stubs, mock objects, fakes, and test harnesses can be used to assist testing a module in
isolation. Unit tests are typically written and run by software developers to ensure that code
meets its design and behaves as intended.
6.1.1.1 Benefits
The goal of unit testing is to isolate each part of the program and show that the individual parts
are correct. A unit test provides a strict, written contract that the piece of code must satisfy. As a
result, it affords several benefits.
Facilitates Change
Unit testing allows the programmer to refactor code or upgrade system libraries at a later
date, and make sure the module still works correctly (e.g., in regression testing). The
procedure is to write test cases for all functions and methods so that whenever a change
causes a fault, it can be quickly identified. Unit tests detect changes which may break
a design contract.
Simplifies Integration
Unit testing may reduce uncertainty in the units themselves and can be used in a bottom-
up testing style approach. By testing the parts of a program first and then testing the sum
of its parts, integration testing becomes much easier.
Documentation
Unit testing provides a sort of living documentation of the system. Developers looking to
learn what functionality is provided by a unit, and how to use it, can look at the unit tests
to gain a basic understanding of the unit's interface (API).Unit test cases embody
characteristics that are critical to the success of the unit. These characteristics can indicate
appropriate/inappropriate use of a unit as well as negative behaviors that are to be trapped
by the unit. A unit test case, in and of itself, documents these critical characteristics,
although many software development environments do not rely solely upon code to
document the product in development.
Integration testing (sometimes called integration and testing, abbreviated I&T) is the phase
in software testing in which individual software modules are combined and tested as a group. It
occurs after unit testing and before validation testing. Integration testing takes as its
input modules that have been unit tested, groups them in larger aggregates, applies tests defined
in an integration test plan to those aggregates, and delivers as its output the integrated system
ready for system testing.
Purpose
Big Bang
In the big-bang approach, most of the developed modules are coupled together to form a
complete software system or major part of the system and then used for integration
testing. This method is very effective for saving time in the integration testing process.
However, if the test cases and their results are not recorded properly, the entire
integration process will be more complicated and may prevent the testing team from
achieving the goal of integration testing. A type of big-bang integration testing is called
"usage model testing" which can be used in both software and hardware integration
testing. The basis behind this type of integration testing is to run user-like workloads in
integrated user-like environments. In doing the testing in this manner, the environment is
proofed, while the individual components are proofed indirectly through their use. Usage
Model testing takes an optimistic approach to testing, because it expects to have few
problems with the individual components. The strategy relies heavily on the component
developers to do the isolated unit testing for their product. The goal of the strategy is to
avoid redoing the testing done by the developers, and instead flesh-out problems caused
by the interaction of the components in the environment. For integration testing, Usage
Model testing can be more efficient and provides better test coverage than traditional
focused functional integration testing. To be more efficient and accurate, care must be
used in defining the user-like workloads for creating realistic scenarios in exercising the
environment. This gives confidence that the integrated environment will work as
expected for the target customers.
Bottom-up testing is an approach to integrated testing where the lowest level components
are tested first, then used to facilitate the testing of higher level components. The process
is repeated until the component at the top of the hierarchy is tested.All the bottom or low-
level modules, procedures or functions are integrated and then tested. After the
integration testing of lower level integrated modules, the next level of modules will be
formed and can be used for integration testing. This approach is helpful only when all or
most of the modules of the same development level are ready. This method also helps to
determine the levels of software developed and makes it easier to report testing progress
in the form of a percentage.Top-down testing is an approach to integrated testing where
the top integrated modules are tested and the branch of the module is tested step by step
until the end of the related module.Sandwich testing is an approach to combine top down
testing with bottom up testing.
In software project management, software testing, and software engineering, verification and
validation (V&V) is the process of checking that a software system meets specifications and that
it fulfills its intended purpose. It may also be referred to as software quality control. It is
normally the responsibility of software testers as part of the software development lifecycle.
Validation checks that the product design satisfies or fits the intended use (high-level checking),
i.e., the software meets the user requirements.This is done through dynamic testing and other
forms of review.Verification and validation are not the same thing, although they are often
confused. Boehm succinctly expressed the difference between
In other words, software verification is ensuring that the product has been built according to the
requirements and design specifications, while software validation ensures that the product meets
the user's needs, and that the specifications were correct in the first place. Software verification
ensures that "you built it right". Software validation ensures that "you built the right thing".
Software validation confirms that the product, as provided, will fulfill its intended use.
Both verification and validation are related to the concepts of quality and of software quality
assurance. By themselves, verification and validation do not guarantee software quality;
planning, traceability, configuration management and other aspects of software engineering are
required.Within the modeling and simulation (M&S) community, the definitions of verification,
validation and accreditation are similar:
Classification of Methods
In mission-critical software systems, where flawless performance is absolutely
necessary, formal methods may be used to ensure the correct operation of a system.
However, often for non-mission-critical software systems, formal methods prove to be
very costly and an alternative method of software V&V must be sought out. In such
cases, syntactic methods are often used.
Test Cases
A test case is a tool used in the process. Test cases may be prepared for software
verification and software validation to determine if the product was built according to the
requirements of the user. Other methods, such as reviews, may be used early in the life
cycle to provide for software validation.
Test Procedures
Specific knowledge of the application's code/internal structure and programming
knowledge in general is not required. The tester is aware of what the software is supposed
to do but is not aware of how it does it. For instance, the tester is aware that a particular
input returns a certain, invariable output but is not aware of how the software produces
the output in the first place.
Test Cases
Test cases are built around specifications and requirements, i.e., what the application is
supposed to do. Test cases are generally derived from external descriptions of the
software, including specifications, requirements and design parameters. Although the
tests used are primarily functional in nature, non-functional tests may also be used. The
test designer selects both valid and invalid inputs and determines the correct output, often
with the help of an oracle or a previous result that is known to be good, without any
knowledge of the test object's internal structure.
Test Design Techniques
Typical black-box test design techniques include:
White-box testing (also known as clear box testing, glass box testing, transparent box testing,
and structural testing) is a method of testing software that tests internal structures or workings of
an application, as opposed to its functionality (i.e. black-box testing). In white-box testing an
internal perspective of the system, as well as programming skills, are used to design test cases.
The tester chooses inputs to exercise paths through the code and determine the appropriate
outputs. This is analogous to testing nodes in a circuit, e.g. in-circuit testing (ICT). White-box
testing can be applied at the unit, integration and system levels of the software testing process.
Although traditional testers tended to think of white-box testing as being done at the unit level, it
is used for integration and system testing more frequently today. It can test paths within a unit,
paths between units during integration, and between subsystems during a system–level test.
Though this method of test design can uncover many errors or problems, it has the potential to
miss unimplemented parts of the specification or missing requirements.
White-box test design techniques include the following code coverage criteria:
White-box testing is a method of testing the application at the level of the source code.
These test cases are derived through the use of the design techniques mentioned
above: control flow testing, data flow testing, branch testing, path testing, statement
coverage and decision coverage as well as modified condition/decision coverage. White-
box testing is the use of these techniques as guidelines to create an error free environment
by examining any fragile code. These White-box testing techniques are the building
blocks of white-box testing, whose essence is the careful testing of the application at the
source code level to prevent any hidden errors later on.[1] These different techniques
exercise every visible path of the source code to minimize errors and create an error-free
environment. The whole point of white-box testing is the ability to know which line of
the code is being executed and being able to identify what the correct output should be.
6.1.5.1 Levels
1. Unit testing. White-box testing is done during unit testing to ensure that the code is
working as intended, before any integration happens with previously tested code. White-
box testing during unit testing catches any defects early on and aids in any defects that
happen later on after the code is integrated with the rest of the application and therefore
prevents any type of errors later on.
2. Integration testing. White-box testing at this level are written to test the interactions of
each interface with each other. The Unit level testing made sure that each code was
tested and working accordingly in an isolated environment and integration examines the
correctness of the behaviour in an open environment through the use of white-box testing
for any interactions of interfaces that are known to the programmer.
3. Regression testing. White-box testing during regression testing is the use of recycled
white-box test cases at the unit and integration testing levels.
White-box testing's basic procedures involves the tester having a deep level of understanding of
the source code being tested. The programmer must have a deep understanding of the application
to know what kinds of test cases to create so that every visible path is exercised for testing. Once
the source code is understood then the source code can be analyzed for test cases to be created.
These are the three basic steps that white-box testing takes in order to create test cases:
6.1.5.3 Advantages
White-box testing is one of the two biggest testing methodologies used today. It has several
major advantages:
1. Side effects of having the knowledge of the source code is beneficial to thorough testing.
2. Optimization of code by revealing hidden errors and being able to remove these possible
defects.
3. Gives the programmer introspection because developers carefully describe any new
implementation.
4. Provides traceability of tests from the source, allowing future changes to the software to
be easily captured in changes to the tests.
5. White box tests are easy to automate.
6. White box testing give clear, engineering-based, rules for when to stop testing.
6.1.5.4 Disadvantages
Although white-box testing has great advantages, it is not perfect and contains some
disadvantages:
1. White-box testing brings complexity to testing because the tester must have knowledge of
the program, including being a programmer. White-box testing requires a programmer
with a high level of knowledge due to the complexity of the level of testing that needs to
be done.
2. On some occasions, it is not realistic to be able to test every single existing condition of
the application and some conditions will be untested.
3. The tests focus on the software as it exists, and missing functionality may not be
discovered.
CHAPTER 7
CONCLUSION
BIBLIOGRAPHY
The following books were referred during the analysis and execution phase of the project
WEBSITES:
www.google.com
www.w3schools.com
www.tutorialspoint.php
http://stackoverflow.com