Newer
Older
\documentclass[12pt]{article}
\usepackage{amsmath}
\usepackage{latexsym}
\usepackage{amsfonts}
\usepackage{amssymb}
\usepackage{graphicx}
\usepackage{txfonts}
\usepackage{wasysym}
\usepackage{adjustbox}
\usepackage{ragged2e}
\usepackage{tabularx}
\usepackage{hhline}
\usepackage{float}
\usepackage{multirow}
\usepackage{makecell}
\usepackage{fancyhdr}
\usepackage[utf8]{inputenc}
\usepackage[T1]{fontenc}
\usepackage[a4paper,bindingoffset=0.2in,headsep=0.5cm,left=1in,right=1in,bottom=3cm,top=2cm,headheight=2cm]{geometry}
\usepackage{hyperref}
\usepackage{color}
\definecolor{pblue}{rgb}{0.13,0.13,1}
\definecolor{pgreen}{rgb}{0,0.5,0}
\definecolor{pred}{rgb}{0.9,0,0}
\definecolor{pgrey}{rgb}{0.46,0.45,0.48}
\everymath{\displaystyle}
\pagestyle{fancy}
\fancyhf{}
\rfoot{Page \thepage}
\lstset{language=C,basicstyle=\footnotesize,keywordstyle=\color{red}\bfseries, commentstyle=\color{blue}\textit,stringstyle=\color{green}\ttfamily, showspaces=false,showstringspaces=false}
\begin{document}
\sloppy
\begin{center}
\Large Telecom ParisTech \\
\Large COMELEC Department \\
\vspace{20 pt}
\underline{\Huge Development Infrastructure for TTool}
\end{center}
\begin{table}[H]
\large
\centering
\begin{adjustbox}{width=\textwidth}
\begin{tabular}{ |p{1.6cm}|p{6.0cm}|p{4.4cm}|p{4.2cm}| }
\hhline{----}
& \textbf{Document Manager} & \textbf{Contributors} & \textbf{Checked by} \\
\hhline{----}
\textbf{Name} & Dominique BLOUIN & Ludovic APVRILLE &
\multirow{2}{*}{Ludovic APVRILLE} \\
\textbf{Contact} & dominique.blouin@telecom-paristech.fr & \multirow{2}{*}{Arthur VUAGNIAUX} & \\
\textbf{Date} & \today & Matteo BERTOLINO & \\
\hline
\end{tabular}
\end{adjustbox}
\end{table}
\begin{figure}[!h]
\centering
\includegraphics[width=0.4\textwidth]{images/image1.png}
\end{figure}
\newpage
\tableofcontents
% \newpage
% \listoffigures
\newpage
\section{Preface}
\subsection{Table of Versions}
\begin{table}[H]
\large
\centering
\begin{adjustbox}{width=\textwidth}
\begin{tabular}{ |p{1.5cm}|p{2.5cm}|p{9.0cm}|p{3.0cm}| }
\hhline{----}
\textbf{Version} & \textbf{Date} & \textbf{Description $ \& $ Rationale of
Modifications} & \textbf{Sections Modified} \\
\hhline{----}
1.0 & 17/10/2016 & First draft & \\
1.1 & 10/02/2017 & Added Eclipse IDE development + tests & All \\
1.2 & 11/02/2017 & Added more info on tests & Tests \\

Arthur Vuagniaux
committed
1.3 & 02/10/2018 & Update and added GUI development & All\\
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
\hline
\end{tabular}
\end{adjustbox}
\end{table}
\subsection{Table of References and Applicable Documents}
\begin{table}[H]
\large
\centering
\begin{adjustbox}{width=\textwidth}
\begin{tabular}{ |p{2.66in}|p{2.66in}|p{0.95in}|p{0.43in}| }
\hhline{----}
\textbf{Reference} & \textbf{Title $ \& $ Edition} & \textbf{Author or
Editor} & \textbf{Year}
\\
\hhline{----}
& & & \\
\hline
\end{tabular}
\end{adjustbox}
\end{table}
\subsection{Acronyms and glossary}
\begin{table}[H]
\large
\centering
\begin{adjustbox}{width=\textwidth}
\begin{tabular}{ |p{1.24in}|p{5.45in}| }
\hhline{--}
\textbf{Term} & \textbf{Description} \\
\hhline{--}
& \\
\hline
\end{tabular}
\end{adjustbox}
\end{table}
\subsection{Executive Summary}
This document describes the development infrastructure that has been setup for
the development of TTool. It describes sources configuration management, the
development process with basic editor and command lines, with the Eclipse IDE,
as well as the testing, building and installation procedures.
\newpage
\section{Source Configuration Management}
\subsection{Gitlab Server}
TTool sources are hosted on the Gitlab server of \textbf{Telecom ParisTech} under the
group \textbf{\textit{mbe}\textit{-tools}} and project \textbf{\textit{TTool}}. The Gitlab project
can be accessed via \url{https://gitlab.telecom-paristech.fr/users/sign_in}.
Login must be performed using Shibboleth as shown in
figure~\ref{fig:image1}, using the credentials from your institution if it is a
member of the Federation Education Recherche (\url{https://services.renater.fr/federation/participants/idp}). Otherwise, please ask us for an account.
\begin{figure}[H]
\begin{center}
\includegraphics[width=\textwidth]{images/image2.png}
\end{center}
\caption{}
\label{fig:image1}
\end{figure}
\subsection{Basic Sources Management}
The address to access the sources is \url{https://gitlab.telecom-paristech.fr/mbe-tools/TTool}.
For the time being and until further notice, we will keep using a centralized development process, like it was the case for Subversion. In this process, each developer first obtains a clone of the master remote repository. For this, go to the directory where the sources are to be downloaded and issue the following command: \\
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
\begin{verbatim}
git clone git@gitlab.enst.fr:mbe-tools/TTool.git
\end{verbatim}
Once modifications are made, they can be committed using command:
\begin{verbatim}
git commit -m "Commit message"
\end{verbatim}
This will only commit the changes in your local repository. In order to move them to the remote repository, use:
\begin{verbatim}
git push origin master
\end{verbatim}
More information on the use of Git can be found here: \\
\url{http://rogerdudler.github.io/git-guide/}. \\
By default, Git will ask credentials for each operation. In order to avoid this,
it is possible to upload a public SSH key at: \\
\url{https://gitlab.telecom-paristech.fr/profile/keys}.
\subsection{Bug Tracking}
The Gitlab server provides an issues tracking system to record bugs, evolutions
or support demands from users and developers. Issues can be seen at: \\
\url{https://gitlab.telecom-paristech.fr/mbe-tools/TTool/issues} \\
It is suggested to create an issue for every modification that is made to the
code, providing with the issue detailed information on the problem including
screen shots, log traces and test cases if required. This information is
important so that other developers can understand why the changes were made.
Ideally, the issue number should be mentioned within the modified code and
commit messages. \\
\section{Development with Text Editor (emacs, vim) and Make}
The text editor of your choice can be used to edit the files of TTool. Yet, you must be sure that the correct indentation is respected. Use \textbf{4 spaces for each indentation level} and refer yourself to the \textbf{Coding Instruction} (\ref{sec:code_info}) .\\
Also, don't forget to insert your name at the top of the file in the authors list.\\
The main Makefile can be used to compile the source files of TTool, and to generate the jar libraries in bin/.
To compile TTool, do as follows, from the top directory of TTool:
\begin{verbatim}
42sh$ make ttool
\end{verbatim}
Other compilation targets can be obtained with:
\begin{verbatim}
\end{verbatim}
In particular, compiling the sources of all subprojects can be done with the
\textit{all} target:
\begin{verbatim}
\newpage
\section{Development with Eclipse}
Eclipse is a well-known Integrated Development Environment (IDE) providing many advanced functionalities to support developers and improve code quality by the application of built-in on the fly code analyses. One advantage of Eclipse is that it is a \textbf{multi-platform application} so it can be used on Linux, Windows and macOS. The procedures described in this section are valid for all platforms although some elements such as C++ projects need to be different due to different platform-specific compilation tool chains to be used. More information on this is provided on the concerned subsections.
\subsection{Installing and Configuring Eclipse}
Download Eclipse IDE for Java developers here: \\
\url{http://www.eclipse.org/downloads/packages/release/photon/r/eclipse-ide-java-developers}
Unzip the package and launch the eclipse executable. For developing C++
applications such as the DIPLODOCUS simulator, add the C Development Tools
(CDT). For this, select menu ``\textbf{Help >> Install New Software}''.
From the dialog box that opens, select the ``\textbf{Photon}'' update site, unfold the
``\textbf{Programming Languages}'' category and check the elements as shown in
figure~\ref{fig:image2}. Follow the wizard instructions to complete the
installation.
\begin{figure}[H]
\begin{center}
\includegraphics[width=0.9\textwidth, height=0.5\textheight]{images/image3.png}
\caption{}
\label{fig:image2}
\end{center}
\end{figure}
\subsection{Online Help}
The first place to look for help is in via menu ``\textbf{Help >> Help Content}'' from
Eclipse. A dialog box will show a tree with branches for each integrated plugin
or application. Help is provided for the 3 plugins that are used to develop
TTool; EGit, Java Development Tools and C/C++ Development Tools.
\subsection{Source Configuration Management with EGit}
The downloaded Eclipse IDE already includes a plugin named EGit for source
configuration management using Git.
\subsubsection{Cloning the TTool Repository}
First, switch to the Git perspective by clicking menu
``\textbf{Window >> Perspective >> Open Perspective >> Other}''. Then select the Git
perspective as illustrated in figure~\ref{fig:image3}.
\begin{figure}[H]
\begin{center}
\includegraphics[width=0.6\textwidth]{images/image4.png}
\end{center}
\caption{}
\label{fig:image3}
\end{figure}
Then clone the TTool Git repository by clicking the appropriate button as shown
in figure~\ref{fig:image4}. Specify the \textbf{TTool Git repository URI}
(git@gitlab.enst.fr:mbe-tools/TTool.git) and follow the wizard by also setting
the local Git repository path.
\begin{figure}[H]
\begin{center}
\includegraphics[width=0.6\textwidth]{images/image5.png}
\end{center}
\caption{}
\label{fig:image4}
\end{figure}
The content of the cloned repository can be seen from the Git Repository view by
unfolding the ``\textbf{Working Tree}'' folder (figure~\ref{fig:image5}).
\begin{figure}[H]
\begin{center}
\includegraphics[width=0.6\textwidth]{images/image6.png}
\end{center}
\caption{}
\label{fig:image5}
\end{figure}
\subsubsection{Importing the Required Projects into the Workspace}
\label{sec:import}
Two Eclipse Java projects are needed to develop TTool: the \textit{bin} project
that contains the required libraries (jars) and the \textit{src} project that
contains the source code. Install these two projects in the workspace by
right-clicking the ``\textbf{Working Tree}'' it in the Git repository view and
selecting ``\textbf{Import Projects}\ldots'' as shown in figure~\ref{fig:image5}.
Then select ``\textbf{Import existing Eclipse projects}'' as shown in
figure~\ref{fig:image6} and follow the steps of the wizard.
\subsubsection{Committing, Pulling and Pushing Changes}
Committing the changes of a file or a directory or a project is performed by
selecting this element in the project navigator view then selecting
``\textbf{Team >> Commit}''. This will open the Git Staging view for where the changed
files are listed. Double clicking a file in the unstaged changes view will open
an editor allowing visualizing the changes (figure~\ref{fig:image7}). Right click and select
``\textbf{Add to Index}'', then enter a commit message and click the ''\textbf{Commit}'' button to
commit the changes. Pushing and pulling can be performed by selecting the repository from
the Git repository view or the elements from the project view.
\begin{figure}[H]
\begin{center}
\includegraphics[width=0.6\textwidth]{images/image7.png}
\end{center}
\caption{}
\label{fig:image6}
\end{figure}
\begin{figure}[H]
\begin{center}
\includegraphics[width=\textwidth]{images/image8.png}
\end{center}
\caption{}
\label{fig:image7}
\end{figure}
\subsection{Java Development}
\subsubsection{Coding and Compiling}
Switch to the Java perspective to develop TTool with JDT (select menu
``\textbf{Windows >> Perspective}\ldots'' or select the appropriate perspective button from
the upper right corner of Eclipse). By default Eclipse will automatically
compile all files in the project. However the provided projects have already
been configured so that only the required classes are compiled and also to use
the required library files from the \textbf{\textit{bin}} project.
JDT provides several advanced functionalities such as automatically navigating
from a variable to its declaration, finding its use throughout all the classes,
including refactoring capabilities, syntactic coloration, code completion, etc.
\subsubsection{Launching TTool}
\label{sec:launch}
A default launch configuration is provided with the TTool \textbf{\textit{src}} project.
It allows for launching TTool from the compiled code. This configuration can be
edited by opening the \textbf{\textit{Run Configurations}} dialog box as show in figure~\ref{fig:image8}.
\begin{figure}[H]
\begin{center}
\includegraphics[width=0.9\textwidth]{images/image9.png}
\end{center}
\caption{}
\label{fig:image8}
\end{figure}
The TTool launch configuration is displayed in figure~\ref{fig:image9}. It
specifies the main class to execute as well as the program arguments, working directory and
optionally additional environment variables to be added to the default system
environment. Click \textbf{\textit{Run}} to launch TTool. The output from TTool will be
displayed in the console view. Once TTool has been launched once, simply
clicking the button to open the launch dialog box will directly launch TTool so
that it is not necessary to open the launch dialog box every time.
\begin{figure}[H]
\begin{center}
\includegraphics[width=\textwidth]{images/image10.png}
\end{center}
\caption{}
\label{fig:image9}
\end{figure}
\subsubsection{Using the Debugger}
In addition, JDT provides an enhanced debugger allowing executing the program
step by step with sophisticated breakpoints to control the execution and to
examine variable contents etc. However to use the debugger, the proper launch
configurations must be used by clicking the \textbf{\textit{debug}}
button just left of the launch configuration button of figure~\ref{fig:image8}.
\subsection{C++ Development}
One advantage of IDEs is that once a user has learned how to use a first tool,
other integrated tools are faster to learn because the tools share so much
functionality.
\subsubsection{Coding and Compiling}
Like for JDT, CDT also has its own perspective and the first thing to do is to
switch to this perspective as shown in figure~\ref{fig:image10}.
\begin{figure}[H]
\begin{center}
\includegraphics[width=0.45\textwidth]{images/image11.png}
\end{center}
\caption{}
\label{fig:image10}
\end{figure}
For developing the TTool C++ applications with CDT, the predefined CDT projects
must first be imported into the workspace as explained in
section~\ref{sec:import}. Note that for CDT, the projects are platform dependent
due to the different compilation toolchains (Cygwin is used for Windows) so there is one project per
platform. For instance, for developing the DIPLODOCUS simulator on Linux, import
the \textbf{\textit{c++2} project}. For windows, import the
\textbf{\textit{c++2 $ \_ $ windows} project} (TODO to be provided later). CDT
provides the ability to define several build configurations. For the
\textbf{\textit{c++2} project}, two configurations are provided as shown in
figure~\ref{fig:image11}.
\begin{figure}[H]
\begin{center}
\includegraphics[width=0.9\textwidth, height=0.38\textheight]{images/image12.png}
\end{center}
\caption{}
\label{fig:image11}
\end{figure}
The \textbf{\textit{TTool} configuration} will compile the code using the provided make
file as if the simulator were compiled from TTool. The \textbf{\textit{Debug}
configuration} allows for compiling TTool such that it can be executed in debug
mode. The selected button in figure~\ref{fig:image11} allows changing the configuration being
used. The hammer button on the right hand side of it allows compiling and
linking the code.
The settings for these build configurations can be edited by selecting the
\textit{c++2} project in the project navigator and clicking
``\textbf{Properties}''. For the \textbf{\textit{Debug} configuration}, the CDT internal builder
is used. This means that the compilation and linking options can be changed via
the form editor shown in figure~\ref{fig:image12}.
\begin{figure}[H]
\begin{center}
\includegraphics[width=0.9\textwidth]{images/image13.png}
\end{center}
\caption{}
\label{fig:image12}
\end{figure}
Note that the code provided by default in the \textbf{\textit{c++2} project}
from the Git repository does not compile by itself. TTool must first be executed
to generate the classes specific to the system being simulated. Once this is
done, the simulator can be compiled and executed from CDT for the desired build
configuration.
\subsubsection{Launching the Simulator}
Like for JDT, the launch of C++ applications can be specified using the launch
configurations dialog as introduced in section~\ref{sec:launch}. One launch
configuration is provided for each build configuration and named
\textbf{\textit{c++2 TTool}} and \textbf{\textit{c++2 Debug}}.
\subsubsection{Using the Debugger}
The CDT debugger is very similar to the JDT debugger. However to be able to use
it only the \textbf{\textit{c++2 Debug} launch configuration} should be used and
triggered from the \textbf{\textit{Debug As} button}. By default, the program execution
will automatically stop at the first instruction of the program. This behavior
can be changed by editing the debug launch configuration.
\newpage
IntelliJ IDEA is another Integrated Development Environment popular especially
among Java developers. It can be used to work on TTool and provides
functionalities globally similar to Eclipse.
\subsection{Installing and configuring IntelliJ}
Download IntelliJ IDEA here: \url{https://www.jetbrains.com/idea/}.
Unzip IntelliJ folder where you want to keep the executable. Launch it by using
the \textbf{\texttt{idea.sh}} script under the \textbf{\texttt{bin}} folder. Click on \textbf{\emph{Open}}
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
and navigate to the root of the TTool git repository.
\subsection{The IDE window layout}
A quick presentation of the user interface is given here:
\url{https://www.jetbrains.com/help/idea/guided-tour-around-the-user-interface.html}.
IntelliJ consists of an editor window and multiple tool windows. Some of the
important tool windows are:
\begin{itemize}
\item \textbf{Project}. Show the structure of the project. In the case of
TTool it displays the different sub-projects and the source folders
(code, test, resource, etc.) for each sub-project. It can be used in
addition to the navigation bar to navigate between files.
\item \textbf{TODO}. List TODOs in the project files.
\item \textbf{Structure}. Show the structure of a class (methods, fields,
etc.).
\item \textbf{Version control}. Show information related to the versioning
system used (git in our case). This enables to see the commits that have
modified the current file, the state of the various branches, the files
that have been modified since the last commit or to directly make a
commit.
\item \textbf{Terminal}. This opens a pseudo-terminal window that can be
used directly from IntelliJ.
\end{itemize}
Note that these tool windows are movable from the different panes and that the
toolbar that enables to select which tool window to display can be shown/hidden
by clicking on the icon on the lower-left side of the IntelliJ window.
\subsection{Debugging TTool}
IntelliJ integrates a debugger that is helpful to find some bugs. You can either
launch TTool in debug mode by clicking on the bug icon in the right part of the
navigation bar when the \textbf{\emph{TTool} configuration} is selected, or debug a
specific test by selecting \textbf{\emph{debug}} in the drop-down menu that appears when
clicking on the arrow for this test.
You can add breakpoints by clicking in the editor's left margin. You can the
right click on the breakpoint to modify it (log something, do not interrupt, add
a condition to the breakpoint, etc.). During debugging, when a breakpoint is
reached or the program was paused, you can see the current value of the
variables, see the stack frames, see the existing threads, add a watch point to
see how an expression evaluates, resume the program, execute step-by-step, etc.
\subsection{Configuring new sub-projects}
\label{sec:intellij:subprojects}
As described in section \ref{sec:code_orga}, TTool is composed of multiple
sub-projects. In IntelliJ, this is achieved by using \textbf{\emph{modules}}. You can see
the existing modules in the \textbf{\emph{File -> Project structure...}} menu. On the
left pane, click on \textbf{\emph{Modules}}. In particular, the \textbf{\texttt{shared} module }
consists of all the code used by other modules and the \textbf{\texttt{ttool} module} is
the main TTool application.
For each of these modules, you can add \textbf{\emph{content roots}} (path that will
contain sub-folders for sources, tests, resources and test resources). Then you
can select a sub-folder for a content root and mark it either as a source, test,
resource or test resource folder.
On the second tab, it is possible to modify the compile path. Note that if you
had a module then it must be compiled with gradle without requiring IntelliJ.
This is why you will need to update the compile path in order to generate the
output into the sub-project's build directory.
Finally, you can add dependencies in the third tab. This is useful in particular
if a sub-project requires an external library.
In the project structure window, on the left pane, you can select
\textbf{\emph{Artifacts}} to see the final results that can be built from the application
(the \texttt{ttool.jar} file for instance). As of today (February 2018), these
artifacts are:
\begin{itemize}
\item some files needed by TTool during its execution
\item the external libraries that TTool depends on
\item the \texttt{ttool.jar} archive
\end{itemize}
\subsection{Configuration of code inspection and indentation rules}
IntelliJ enables to improve coding practice by providing warnings (e.g., unused
variable) that are
visible in the editor and by enabling to automatically correct them. These
warnings have different levels (error, warning, weak warning, etc.) and they are
fully configurable. In order to configure them, you can click on the icon at the
extreme right of the status bar and click on \textbf{\emph{configure inspections}}. You
can choose which inspection should be enabled and which warning level should be
raised when code does not follow these inspections. In order to provide a
common coding standard among TTool developers, the configuration of these
inspections is stored in a profile that is versioned by Git. You should thus not
modify this profile without asking other developers.
Similarly to these warnings, IntelliJ enables to harmonize code style by
defining a profile that is shared between all developers. To see the code style
options, go to \textbf{\emph{File -> Settings}} and navigate to
\textbf{\emph{Editor -> CodeStyle}}.
As for warnings, do not modify this shared profile except if you know
what you are doing.
Finally, IntelliJ enables to correct code style issues and some warnings
automatically. To do that, right click on the file in the project tool window
and select \emph{Reformat code}.
\subsection{Tips and tricks}
Note that there is a vim plugin available in IntelliJ that supports some of vim
commands.
\newpage
\section{Coding Information}
Here are gathered all tricks on how TTool source codes are organized, and what function is coded where, and also how to extend TTool, e.g. adding a new diagram.
\label{sec:code_info}
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
\subsubsection{Best practices}
TTool is a constantly evolving project with more or less experimental parts. As
such, some leniency is expected from TTool developers and---while comments and
advice are always welcome---a perfect knowledge of best software engineering
practices should not be expected from every developers.
Nonetheless, we advise any developer to make her/his best to follow these best
practices. Indeed, the purpose of these principles is to enable the development
of easily understandable, extendable and reusable code. A good place to start if
you are not familiar with these principles is to have a look at the
\href{https://en.wikipedia.org/wiki/SOLID_(object-oriented_design)}{SOLID}
acronym.
In particular, developers should try to:
\begin{itemize}
\item \textbf{Avoid public attributes}. Use getters and setters instead.
This way, if the internal representation of the class changes, only the
getters/setters would need to be modified.
\item \textbf{Implement all of the methods of the superclass}.
If some of the methods of the superclass are not relevant for the
subclass, then it should probably not inherit from it. Indeed, other
classes that uses the superclass logically assume that all of the
subclasses implement the functionalities of the superclass.
\item \textbf{Use abstractions instead of concrete
classes when possible}. For instance, if an object A of package
\textit{avatartranslator} must use an object B of package \textit{ui},
create an interface in package \textit{avatartranslator} that is
implemented by B and use it in A. This would make the low-level package
\textit{ui} depend on the high-level package \textit{avatartranslator}
instead of the opposite (which enables to use A in a CLI application for
instance). This principle is also valid when the abstract class and its
implementation are in the same package: for instance, prefer using
\textit{List} objects in function arguments instead of the
\textit{LinkedList} or \textit{ArrayList} concrete classes so that the
caller can choose which subtype to instantiate.
\end{itemize}
\begin{itemize}
\item Indentations should use 4 spaces for each indentation level.
\item Opening brackets should be at the end of the line it relates to with one
space before the bracket.
\item There should be 1 space between an \texttt{if}, \texttt{for},
\texttt{switch}, etc. and the following opening parentheses, but none
between a function name and the following parentheses.
Here is an example code with correct formatting : \\
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
\begin{lstlisting}[showspaces=true, language=java, commentstyle=\color{pgreen},
keywordstyle=\color{pblue}, stringstyle=\color{pred}, basicstyle=\ttfamily]
public class Foo {
public int[] X = new int[]{1, 3, 5, 7, 9, 11};
public void foo(boolean a, int x, int y, int z) {
for (int i = 0; i < 5; i++) {
try {
if (x > 0) {
int someVariable = a ? x : y;
int anotherVariable = a ? x : y;
} else {
for (int i = 0; i < 5; i++) doSomething(i);
}
switch (a) {
case 0:
doCase0();
break;
default:
doDefault();
}
} catch (Exception e) {
processException(e.getMessage(), x + y, z, a);
}
}
}
}
\end{lstlisting}
Do ensure your file is correctly indented before committing/pushing it.
Preferably, configure your code editor so that these guidelines are
automatically enforced.
\subsubsection{How to output debug information}
Do as follows:
\begin{lstlisting}
TraceManager.addDev("blah blah blah");
\end{lstlisting}
Then, start TTool with the
\begin{verbatim}
-debug
\end{verbatim}
option.
Thus, to print information, never use:
\begin{lstlisting}
System.out.println("blah blah blah");
\end{lstlisting}
or similar ways of doing.
TTool is compiled with the following \textit{Xlint} warning flags:
\begin{itemize}
\item unchecked
\item deprecation
\item cast
\item divzero
\item empty
\item finally
\item fallthrough
\end{itemize}
Before committing your changes, make sure that your code does not generate any
warning.
\subsubsection{Documentation}
Whenever it is possible, add a javadoc comment before any function, class or
field declaration. This helps future developers to quickly understand the
purpose of the related code. Note that to be valid, javadoc comments must be
placed right before the declaration and should be correctly formatted. To check
that it really is, generate the javadoc:
\begin{verbatim}
make documentation
\end{verbatim}
and make sure no warning is printed.
\label{sec:code_orga}
The TTool repository actually hosts the source code of different standalone
projects. Here is a description of these sub-projects:
\begin{itemize}
\item \textbf{ttool}. This is the main project: the TTool application with a
graphical user interface.
\item \textbf{graphminimize}. Command line application for minimizing graphs.
\item \textbf{graphshow}. Command line application for displaying graphs.

Arthur Vuagniaux
committed
\item \textbf{launcher}. TODO
\item \textbf{rundse}. Application that run the \textbf{DSE} (\textit{Design Space Exploration}) of the current project. In \texttt{TTool/DIPLODOCUS}, the DSE evaluates the performance of a mapping solution by simulating the workload of computations and data-transfers
\item \textbf{simulationcontrol}. Application that allow to simulate a remote control between an \texttt{host} and a \texttt{port}
\item \textbf{tiftranslator}. This is the application for translating \textit{TIFT} to other languages (\texttt{LOTOS}, \texttt{RT-LOTOS}, \texttt{UPPAAL} or \texttt{JAVA}). The imput file should be in \textit{XML/TIF} format and be readable.
\item \textbf{tmltranslator}. The application in order to tranlate \textit{TML} to other languages (\texttt{LOTOS}, \texttt{UPPAAL}, \texttt{SystemC}, \texttt{SystemC2} or \texttt{TML}). The imput file must be in \textit{TML} format and be readable
\item \textbf{webcrawler}. Implement of a WebCrawler for \textbf{CVEs} (\textit{Common Vulnerabilities and Exposures}
\item \textbf{client}. Client part of the WebCrawler
\item \textbf{server}. Server part of the WebCrawler
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
\end{itemize}
\item \textbf{jttool}. TODO \textit{(Development of this project has been
dropped)}
\end{itemize}
For each of these sub-projects, there exists a folder in the TTool repository
that contains the sources, tests, resources and runtime dependencies associated
with it. Each of the sub-projects conforms to the
\href{https://maven.apache.org/guides/introduction/introduction-to-the-standard-directory-layout.html}
{Maven Directory Layout} and the root directory itself contains an \texttt{src}
folder which contains the source code shared by multiple sub-projects and
follow the same directory layout. This means that for instance, source code
specific to the \textit{ttool} sub-project should be located under
\texttt{ttool/src/main/java}, test classes related to the \textit{rundse}
sub-projects would be under \texttt{rundse/src/test/java} and resources (such as
images) needed by shared source code would be under \texttt{src/main/resources}.
Preferably, source code that would only be needed by a particular sub-project
should not be under \texttt{src/main/java} but under
\texttt{<project>/src/main/java}. In particular, \texttt{main} methods should
not appear in the shared source code directory (\texttt{src/main/java}).
If we focus on the shared sources, we see different packages. Basically, all
graphical-related elements are put in "ui". All other subdirectories of
\texttt{src/main/java}
are used to code generic functions (\texttt{myutil}") or non graphical languages and
model transformation. For example, in \texttt{avatartranslator/} you find all classes
related to the internal avatar language, and all transformations from the
internal avatar to other languages (e.g. to UPPAAL) are in subdirectories like
\texttt{avatartranslator/touppaal}. \textbf{Note}: please strive to provide
autonomous packages that depend on as few other packages as possible. This
enables to reuse code without including unrelated classes. In particular,
non-\texttt{ui} packages should not import \texttt{ui} classes so that a CLI
application that uses features provided by the package need not import the
graphical \texttt{ui} package.
\subsubsection{User Interface directories}
Main classes are located directly in "src/ui". Subdirectories of "ui/" are mostly used for diagrams (one diagram per subdirectory, e.g. avatarbd for the Avatar Block Diagram). Other subdirectories are explained in the following table.
\begin{tabular}{l|c}
subdirectory&Explanation\\
\hline
file&Contains the definition of file extensions used by TTool\\
graph&AUT graph definition, and how to display an AUT graph\\
interactivesimulation&Graphical part of Diplodocus model simulation\\
tree&tree located in the upper left part of the main TTool Window.\\
window&Sub-windows: dialogs, frames, etc.
\end{tabular}
\subsection{Structure of the User Interface}
Actions of the main user interface are defined in "TGUIActions.java". The corresponding method which is called when an action occurs is defined in "ActionPerformer.java".
\subsection{Structure of a diagram}
\subsection{Error management}
The tree on the left contains a part dedicated to errors and warnings. The list of errors/warnings that is displayed by the tree is handled in GTURTLEModeling.java with:
\begin{lstlisting}
private List<CheckingError> checkingErrors;
private List<CheckingError> warnings;
\end{lstlisting}
\section{Testing}
It is planned to develop more and more tests for TTool in order to improve the
product quality. Test architectures are defined for each languages used to
develop TTool; Java and C++.
The testing code of TTool is located under the \textit{tests} directory of the TTool
repository and under \texttt{src/test/java} in any sub-project directory. A structure where a subdirectory is created for each
component of TTool to be tested (e.g.: Avatar, Diplodocus, shared utility
functions, etc.) is recommended. Each subdirectory can be further subdivided for
the different subcomponents of the component. For example, the Diplodocus component can be
further divided into its simulator and GUI components, which are not tested
under the same test environment and framework due to the different languages
A recommended practice consists of naming the folders containing the classes
with the same name of root package of the provided classes such as
$fr.tpt.ttool.tests.component\_name$, where $component\_name$ is the name of the
component of TTool being tested.
The TTool Java code is tested using JUnit (\url{http://junit.org/}), which is a
unit test framework allowing to write, execute and display the results of
repeatable tests.
JUnit builds on a set of assertions for evaluating test results
and a set of annotations for qualifying test classes and methods. A test unit in
JUnit consists of a Java class grouping a set of test cases implemented as
methods of the class and identified with the $@Test$ annotation.
Other methods of the class to be executed only once before or after the
execution of all test cases of the class can be identified from the annotations
$@BeforeClass$ and $@AfterClass$. Methods to be executed before or after each
test case is executed can be identified from the annotations $@Before$ and
$@After$.
When using the Eclipse IDE, test classes can be automatically generated for a
given class to be tested and will include annotated methods for the selected
With IntelliJ, when you are editing a Java class, you can jump to the corresponding test class
by right-clicking on the editor window (on a specific method or anywhere in the
class), and select \emph{Go To -> Test}.
IntelliJ will look for a corresponding test class and will propose to create a
new one. If you decide to create a new test class, select \emph{JUnit4} as the
testing library and pick the methods for which you want to add tests.
See folder $test/fr.tpt.ttool.tests.util$ of the TTool source code repository
for an example test class $TestRshClient$ providing test cases for the TTool
utility class $RshClient$ used for client-server remote communications.
A JUnit test class can be executed automatically by passing
it to a JUnit test runner service that will take care of calling the appropriate
methods in the appropriate order to execute the tests, and return a test result
object that can be inspected to determine the success or failure of the test
cases and provide more details in case of failure. An example code snippet is
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
\begin{verbatim}
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
import fr.tpt.ttool.tests.util.remote.TestRshClient;
public class TToolUtilTestsRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestRshClient.class);
for ( final Failure failure : result.getFailures() ) {
System.err.println( "Test failed : " + failure.toString() );
}
if ( result.wasSuccessful() ) {
System.out.println( "All tests passed." );
}
else {
System.err.println( "Some of the tests failed!" );
}
System.exit( 0 );
}
}
\end{verbatim}
It is also possible to let gradle run the tests by invoking it:
\begin{verbatim}
gradle test
\end{verbatim}
or
\begin{verbatim}
gradle :ttool:test
\end{verbatim}
for a specific sub-project.
A report is then generated under
\texttt{<project>/build/reports/tests/test/index.html}.
\textbf{\emph{Within the Eclipse IDE}}
Like for C++ and Java applications, JUnit launch configurations can be defined
in Eclipse as shown in figure~\ref{fig:image13}. This configuration will execute all unit tests
for class \textit{RSHClient} and display within the IDE a view of the status of
the tests (passed of failed) as shown in figure~\ref{fig:image14}.
\begin{figure}[H]
\begin{center}
\includegraphics[width=\textwidth]{images/image14.png}
\end{center}
\caption{}
\label{fig:image13}
\end{figure}
\begin{figure}[H]
\begin{center}
\includegraphics[width=\textwidth]{images/image15.png}
\end{center}
\caption{}
\label{fig:image14}
\end{figure}
\textbf{\emph{Within the IntelliJ IDE}}
Once the
test is written, you will have a green arrow in the left margin of the editor
next to each test method. You can either click on the arrow corresponding to a
specific method to run the corresponding test, or click on the arrow next to the
class name to run all the tests in this class.
In some cases, the tests need to use resources. You need to add these resources
to the \emph{test resources} root folder (see section
\ref{sec:intellij:subprojects} to see how this root folder is configured) and
to ensure that the test is running from the correct directory. To do this, run
the test once. You will see in the right section of the navigation bar a
shortcut to run the previous test. Expand the configuration selection list and
click on \emph{Edit Configurations...}. You can see all the available
configurations and modify options for each of them. In particular, you can
change the \emph{Working directory} (which should probably be
\texttt{ttool/build}) or require actions to do before running this
configuration (at the bottom of the window). You can share your configurations
so that other can use them but be careful not to share something with absolute
paths.
\subsection{C++}
TODO
\section{Building}
First obtain the TTool repository from the Gitlab server as explained in section
\ref{sec:scm}. From a Linux shell, CD to the root TTool directory and execute
\emph{make all} to compile the code. If the compilation fails with the following error:
``unmappable character for encoding ASCII'', you need to do:
\emph{export JAVA\_TOOL\_OPTIONS=-Dfile.encoding=UTF8} \\
For generating a release, execute \emph{make release}.
\subsection{Gradle}
The TTool project has been configured so that it can be built with the
\href{https://gradle.org/}{Gradle Build Tool}. To this end, a
\texttt{build.gradle} file
is present in the root folder and each sub-project directory. Each
\texttt{build.gradle} file describes how to compile and package the related
sub-project and the \texttt{build.gradle} in the root folder describes shared
configuration. They should be modified when the compilation for a project
changes. In particular:
\begin{itemize}
\item If a .jar library should be added to the classpath
\item If a source folder should be added to the sourcepath
\item If a javac flag should be added or removed
\end{itemize}
There is another gradle configuration file in the root folder of TTool: