wip
This commit is contained in:
parent
417a6966c3
commit
5bb283a6ed
@ -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.
|
||||||
|
Loading…
Reference in New Issue
Block a user