wip
This commit is contained in:
		@@ -40,9 +40,8 @@ citecolor = black]{hyperref}%
 | 
				
			|||||||
\pagestyle{scrheadings}		% switch on head and foot line
 | 
					\pagestyle{scrheadings}		% switch on head and foot line
 | 
				
			||||||
\newpage
 | 
					\newpage
 | 
				
			||||||
\tableofcontents
 | 
					\tableofcontents
 | 
				
			||||||
\newpage
 | 
					 | 
				
			||||||
\listoffigures
 | 
					\listoffigures
 | 
				
			||||||
\newpage
 | 
					\listoftables
 | 
				
			||||||
\lstlistoflistings
 | 
					\lstlistoflistings
 | 
				
			||||||
\input{config/headfoot.tex}
 | 
					\input{config/headfoot.tex}
 | 
				
			||||||
\newpage
 | 
					\newpage
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										72
									
								
								content.tex
									
									
									
									
									
								
							
							
						
						
									
										72
									
								
								content.tex
									
									
									
									
									
								
							@@ -1,4 +1,5 @@
 | 
				
			|||||||
\section{Gitlab workflow} \label{sec:glw}
 | 
					\section{Gitlab workflow} \label{sec:glw}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\begin{figure}
 | 
					\begin{figure}
 | 
				
			||||||
	\begin{center}
 | 
						\begin{center}
 | 
				
			||||||
		\input{img_gitlab.tex}
 | 
							\input{img_gitlab.tex}
 | 
				
			||||||
@@ -6,35 +7,49 @@
 | 
				
			|||||||
		\label{fig:gitlab_workflow}
 | 
							\label{fig:gitlab_workflow}
 | 
				
			||||||
	\end{center}
 | 
						\end{center}
 | 
				
			||||||
\end{figure}
 | 
					\end{figure}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Figure \ref{fig:gitlab_workflow} gives an overview of the gitlab workflow.
 | 
					Figure \ref{fig:gitlab_workflow} gives an overview of the gitlab workflow.
 | 
				
			||||||
The workflow is splitted in different phases:\\
 | 
					The workflow is splitted in different phases:\\
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\begin{itemize}
 | 
					\begin{itemize}
 | 
				
			||||||
	\item Implementation phase
 | 
						\item Implementation phase
 | 
				
			||||||
	\item Code freeze
 | 
						\item Code freeze
 | 
				
			||||||
	\item Release phase
 | 
						\item Release phase
 | 
				
			||||||
\end{itemize}
 | 
					\end{itemize}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
For these different phases The continuous integration/delivery system
 | 
					For these different phases The continuous integration/delivery system
 | 
				
			||||||
triggers different build stages. For further details please refer to
 | 
					triggers different build stages. For further details please refer to
 | 
				
			||||||
section \ref{sec:ci}.
 | 
					section \ref{sec:ci}.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\subsection{Implementation phase}
 | 
					\subsection{Implementation phase}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
While in implementation phase every implementation for the next release is
 | 
					While in implementation phase every implementation for the next release is
 | 
				
			||||||
done. Every implementation has to be done on a seperate branch. After
 | 
					done. Every implementation has to be done on a seperate branch. After
 | 
				
			||||||
finishing an implementation the branch it was made on has to be merged back
 | 
					finishing an implementation the branch it was made on has to be merged back
 | 
				
			||||||
to the master branch. As defined an implementation could be one of:\\
 | 
					to the master branch. As defined an implementation could be one of:\\
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\begin{itemize}
 | 
					\begin{itemize}
 | 
				
			||||||
	\item Feature
 | 
						\item Feature
 | 
				
			||||||
	\item Fix
 | 
						\item Fix
 | 
				
			||||||
\end{itemize}
 | 
					\end{itemize}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\subsubsection{Feature implementation}
 | 
					\subsubsection{Feature implementation}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
A feature is a a new piece of code that implements new functionality into
 | 
					A feature is a a new piece of code that implements new functionality into
 | 
				
			||||||
the system.
 | 
					the system.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\subsubsection{Fix implementation}
 | 
					\subsubsection{Fix implementation}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
If in any testing phase an issue is detected these issue can be fixed with
 | 
					If in any testing phase an issue is detected these issue can be fixed with
 | 
				
			||||||
a fix implementation.
 | 
					a fix implementation.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\subsubsection{Further kinds of implementation}
 | 
					\subsubsection{Further kinds of implementation}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Beside these defined implementations any other kind of implementation is
 | 
					Beside these defined implementations any other kind of implementation is
 | 
				
			||||||
possible but has to be made also on a seperate branch.
 | 
					possible but has to be made also on a seperate branch.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\subsection{Code freeze}
 | 
					\subsection{Code freeze}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
The transition between implementation phase and release phase is called
 | 
					The transition between implementation phase and release phase is called
 | 
				
			||||||
code freeze. Code freeze means each for the upcoming release planned
 | 
					code freeze. Code freeze means each for the upcoming release planned
 | 
				
			||||||
feature is implemented and merged to the main branch (normally master) of
 | 
					feature is implemented and merged to the main branch (normally master) of
 | 
				
			||||||
@@ -43,27 +58,37 @@ the upcoming release a "\texttt{release/...}" named branch is created.
 | 
				
			|||||||
For a proper release configuration it is necessary to configure the ci
 | 
					For a proper release configuration it is necessary to configure the ci
 | 
				
			||||||
build job before creating the release branch (see section \ref{sec:ci_conf})
 | 
					build job before creating the release branch (see section \ref{sec:ci_conf})
 | 
				
			||||||
.
 | 
					.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\subsection{Release phase}
 | 
					\subsection{Release phase}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Any release relevant issue that is detected while release phase has to be
 | 
					Any release relevant issue that is detected while release phase has to be
 | 
				
			||||||
fixed at the release branch. The release phase is splitted into different
 | 
					fixed at the release branch. The release phase is splitted into different
 | 
				
			||||||
stages:
 | 
					stages:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\begin{itemize}
 | 
					\begin{itemize}
 | 
				
			||||||
	\item Internal release(s)
 | 
						\item Internal release(s)
 | 
				
			||||||
	\item External release
 | 
						\item External release
 | 
				
			||||||
\end{itemize}
 | 
					\end{itemize}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\subsubsection{Internal release(s)}
 | 
					\subsubsection{Internal release(s)}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Each push to a release branch triggers the creation of an internal release.
 | 
					Each push to a release branch triggers the creation of an internal release.
 | 
				
			||||||
Only internal releases must be used to system test the release branch. For
 | 
					Only internal releases must be used to system test the release branch. For
 | 
				
			||||||
details please refer to section \ref{sec:ci_int}.
 | 
					details please refer to section \ref{sec:ci_int}.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\subsubsection{External release}
 | 
					\subsubsection{External release}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
If no further release relevant issues could be found (or are accepted as
 | 
					If no further release relevant issues could be found (or are accepted as
 | 
				
			||||||
known issues) an external release is created by tagging the commit which
 | 
					known issues) an external release is created by tagging the commit which
 | 
				
			||||||
should be delivered to the customer. For details please refer to section
 | 
					should be delivered to the customer. For details please refer to section
 | 
				
			||||||
\ref{sec:ci_ext}.
 | 
					\ref{sec:ci_ext}.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\section{Continuous integration/delivery} \label{sec:ci}
 | 
					\section{Continuous integration/delivery} \label{sec:ci}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
As continuous integration system the gitlab built in ci-system
 | 
					As continuous integration system the gitlab built in ci-system
 | 
				
			||||||
\textit{gitlab-ci} is used. Beside the most important task of ci, ensure
 | 
					\textit{gitlab-ci} is used. Beside the most important task of ci, ensure
 | 
				
			||||||
constant high code quality, the ci system is used for various tasks:
 | 
					constant high code quality, the ci system is used for various tasks:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\begin{itemize}
 | 
					\begin{itemize}
 | 
				
			||||||
	\item Automated static code analysis
 | 
						\item Automated static code analysis
 | 
				
			||||||
	\item Automated build
 | 
						\item Automated build
 | 
				
			||||||
@@ -72,10 +97,23 @@ constant high code quality, the ci system is used for various tasks:
 | 
				
			|||||||
	\item External release deployment
 | 
						\item External release deployment
 | 
				
			||||||
	\item Automated release note generation (not implemented yet)
 | 
						\item Automated release note generation (not implemented yet)
 | 
				
			||||||
\end{itemize}
 | 
					\end{itemize}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\subsection{Internal release deployment} \label{sec:ci_int}
 | 
					\subsection{Internal release deployment} \label{sec:ci_int}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					\FloatBarrier
 | 
				
			||||||
 | 
					\begin{figure}
 | 
				
			||||||
 | 
						\begin{center}
 | 
				
			||||||
 | 
							\input{img_deploy.tex}
 | 
				
			||||||
 | 
							\caption{Deployment of release candidats and releases}
 | 
				
			||||||
 | 
							\label{fig:deployment}
 | 
				
			||||||
 | 
						\end{center}
 | 
				
			||||||
 | 
					\end{figure}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
For a branch named \texttt{release/...} the creation of a release candidate
 | 
					For a branch named \texttt{release/...} the creation of a release candidate
 | 
				
			||||||
is triggered automatically. The internal release is processing the following
 | 
					is triggered automatically. Figure \ref{fig:deployment} illustrates the
 | 
				
			||||||
steps:\\
 | 
					deployment process. The internal release is processing the following steps:
 | 
				
			||||||
 | 
					\\
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\begin{enumerate}
 | 
					\begin{enumerate}
 | 
				
			||||||
	\item Build project variant specific configuration
 | 
						\item Build project variant specific configuration
 | 
				
			||||||
	\item Static code analysis of project variant specific configuration
 | 
						\item Static code analysis of project variant specific configuration
 | 
				
			||||||
@@ -84,12 +122,15 @@ steps:\\
 | 
				
			|||||||
	\item Deploy the release to the project's release candidate deploy
 | 
						\item Deploy the release to the project's release candidate deploy
 | 
				
			||||||
location
 | 
					location
 | 
				
			||||||
\end{enumerate}
 | 
					\end{enumerate}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\subsection{External release deployment} \label{sec:ci_ext}
 | 
					\subsection{External release deployment} \label{sec:ci_ext}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
To create an external release the commit to be released must be tagged
 | 
					To create an external release the commit to be released must be tagged
 | 
				
			||||||
using the following naming convention:\\
 | 
					using the following naming convention:\\
 | 
				
			||||||
\texttt{release/<project\_specific\_name>}.\\
 | 
					\texttt{release/<project\_specific\_name>}.\\
 | 
				
			||||||
The project specific naming convention for Agricola ruby is:\\
 | 
					The project specific naming convention for Agricola ruby is:\\
 | 
				
			||||||
\texttt{release/174\_AG*}.\\
 | 
					\texttt{release/174\_AG*}.\\
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\begin{enumerate}
 | 
					\begin{enumerate}
 | 
				
			||||||
	\item Build project variant specific configuration
 | 
						\item Build project variant specific configuration
 | 
				
			||||||
	\item Static code analysis of project variant specific configuration
 | 
						\item Static code analysis of project variant specific configuration
 | 
				
			||||||
@@ -97,22 +138,28 @@ The project specific naming convention for Agricola ruby is:\\
 | 
				
			|||||||
	\item Build release notes for the release
 | 
						\item Build release notes for the release
 | 
				
			||||||
	\item Deploy the release to the project's release deploy location
 | 
						\item Deploy the release to the project's release deploy location
 | 
				
			||||||
\end{enumerate}
 | 
					\end{enumerate}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\subsection{Configuring the build jobs} \label{sec:ci_conf}
 | 
					\subsection{Configuring the build jobs} \label{sec:ci_conf}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
The configuration of gitlab-ci is made in the \texttt{.gitlab-ci.yml} file
 | 
					The configuration of gitlab-ci is made in the \texttt{.gitlab-ci.yml} file
 | 
				
			||||||
in the root directory of the project's repository. The certain build stages
 | 
					in the root directory of the project's repository. The certain build stages
 | 
				
			||||||
are using variables to customize the build. These variables are defined in
 | 
					are using variables to customize the build. These variables are defined in
 | 
				
			||||||
the \texttt{variables} section of the config file.\\\\
 | 
					the \texttt{variables} section of the config file. Table \ref{tab:conf_var}
 | 
				
			||||||
\begin{tabular}{l l}
 | 
					and listing \ref{lst:ag_cfg} gives an overview about customizing a release
 | 
				
			||||||
	\cellcolor{black}\color{white}variable & \cellcolor{black}\color{white}meaning\\
 | 
					phase.
 | 
				
			||||||
	PRODUCT\_NAME & Short of the product name\\
 | 
					
 | 
				
			||||||
	PRODUCT\_VARIANT & Short of the product variant\\
 | 
					\captionof{table}{Variables to customize a release phase}
 | 
				
			||||||
	PROJECT\_VERSION & ??\\
 | 
					\label{tab:conf_var}
 | 
				
			||||||
	SW\_MAJOR & Software major number\\
 | 
					\begin{tabular}{l l l}
 | 
				
			||||||
	SW\_MINOR & Software minor number\\\\
 | 
						\cellcolor{black}\color{white}variable & \cellcolor{black}\color{white}meaning & \cellcolor{black}\color{white}example\\
 | 
				
			||||||
 | 
						PRODUCT\_NAME & Short of the product name & AG\\
 | 
				
			||||||
 | 
						PRODUCT\_VARIANT & Short of the product variant & NA\\
 | 
				
			||||||
 | 
						PROJECT\_VERSION & ?? & 10\\
 | 
				
			||||||
 | 
						SW\_MAJOR & Software major number & 1\\
 | 
				
			||||||
 | 
						SW\_MINOR & Software minor number & 2\\\\
 | 
				
			||||||
\end{tabular}
 | 
					\end{tabular}
 | 
				
			||||||
\newline
 | 
					\newline
 | 
				
			||||||
In listing \ref{lst:ag_cfg} an example configuration for an Agricola North
 | 
					
 | 
				
			||||||
America variant release is shown.
 | 
					 | 
				
			||||||
\lstsetbash
 | 
					\lstsetbash
 | 
				
			||||||
\begin{lstlisting}[caption=variables configuration, label=lst:ag_cfg]
 | 
					\begin{lstlisting}[caption=variables configuration, label=lst:ag_cfg]
 | 
				
			||||||
variables:
 | 
					variables:
 | 
				
			||||||
@@ -122,6 +169,7 @@ variables:
 | 
				
			|||||||
  SW_MAJOR: "1"
 | 
					  SW_MAJOR: "1"
 | 
				
			||||||
  SW_MINOR: "2"
 | 
					  SW_MINOR: "2"
 | 
				
			||||||
\end{lstlisting}
 | 
					\end{lstlisting}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
\textbf{Remember}, it is a good idea to change these values before creating
 | 
					\textbf{Remember}, it is a good idea to change these values before creating
 | 
				
			||||||
the release branch, creating (and pushing) the branch triggers the build of
 | 
					the release branch, creating (and pushing) the branch triggers the build of
 | 
				
			||||||
a release candidate.
 | 
					a release candidate.
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user