Merge branch 'master' of disconnected-by-peer.at:go-opsi/devtools
This commit is contained in:
commit
1704cc8fcf
@ -39,7 +39,6 @@ builder_controller() {
|
|||||||
####################
|
####################
|
||||||
# Main
|
# Main
|
||||||
####################
|
####################
|
||||||
|
|
||||||
# get the 'real' directory this program stored in (resolve symbolic links)
|
# get the 'real' directory this program stored in (resolve symbolic links)
|
||||||
PRG=$(readlink -f $0)
|
PRG=$(readlink -f $0)
|
||||||
BASEDIR=`dirname "$PRG"`
|
BASEDIR=`dirname "$PRG"`
|
||||||
|
@ -24,9 +24,10 @@ STATUS="integration"
|
|||||||
# STATUS_INTEGRATION_RELEASE - automatically created release number,
|
# STATUS_INTEGRATION_RELEASE - automatically created release number,
|
||||||
# if STATUS is set to "integration". Valid values: anything, default value: "`date +%Y%m%d%H%M`"
|
# if STATUS is set to "integration". Valid values: anything, default value: "`date +%Y%m%d%H%M`"
|
||||||
# Samples:
|
# Samples:
|
||||||
# "`date +%Y%m%d%H%M`"
|
# "func:inc1" - build-in function "inc1": search the opsi-repository for the latested release and increment 1
|
||||||
# "$BUILD_NUMBER" - jenkins https://wiki.jenkins-ci.org/display/JENKINS/Building+a+software+project#Buildingasoftwareproject-JenkinsSetEnvironmentVariables
|
# "`date +%Y%m%d%H%M`" - command output, e.g. the date format YYMMDD-HHMM
|
||||||
STATUS_INTEGRATION_RELEASE="`date +%Y%m%d%H%M`"
|
# "$BUILD_NUMBER" - Environment variables, jenkins https://wiki.jenkins-ci.org/display/JENKINS/Building+a+software+project#Buildingasoftwareproject-JenkinsSetEnvironmentVariables
|
||||||
|
STATUS_INTEGRATION_RELEASE="func:inc1"
|
||||||
|
|
||||||
# CHECKSUM_AUTOCREATE - Every downloaded file is checked using SHA1 algorithm
|
# CHECKSUM_AUTOCREATE - Every downloaded file is checked using SHA1 algorithm
|
||||||
# against a checksum file, if this file ist not available, it will be created
|
# against a checksum file, if this file ist not available, it will be created
|
||||||
@ -51,7 +52,7 @@ CREATOR_EMAIL="your-email@domain.de"
|
|||||||
# OPSI repository settings
|
# OPSI repository settings
|
||||||
#################################
|
#################################
|
||||||
# Basedirectory storing OPSI-packages after building
|
# Basedirectory storing OPSI-packages after building
|
||||||
OPSI_REPOS_BASE_DIR=$HOME/.opsi-repository
|
OPSI_REPOS_BASE_DIR=$HOME/opsi-repository
|
||||||
|
|
||||||
# Directory- and filename pattern
|
# Directory- and filename pattern
|
||||||
OPSI_REPOS_PRODUCT_DIR=${OPSI_REPOS_BASE_DIR}/${STATUS}/${VENDOR}/${PN}/${VERSION}-${CREATOR_TAG}${RELEASE}
|
OPSI_REPOS_PRODUCT_DIR=${OPSI_REPOS_BASE_DIR}/${STATUS}/${VENDOR}/${PN}/${VERSION}-${CREATOR_TAG}${RELEASE}
|
||||||
@ -74,7 +75,7 @@ OPSI_REPOS_FILE_PATTERN=${PN}_${VERSION}-${CREATOR_TAG}${RELEASE}
|
|||||||
# You must be member of the unix group pcpatch&opsiadmin
|
# You must be member of the unix group pcpatch&opsiadmin
|
||||||
OPSI_REPOS_UPLOAD_OPSI=true
|
OPSI_REPOS_UPLOAD_OPSI=true
|
||||||
OPSI_REPOS_UPLOAD_OPSI_ZSYNC=false
|
OPSI_REPOS_UPLOAD_OPSI_ZSYNC=false
|
||||||
OPSI_REPOS_UPLOAD_SOURCE=true
|
OPSI_REPOS_UPLOAD_SOURCE=false
|
||||||
OPSI_REPOS_UPLOAD_BIN=false
|
OPSI_REPOS_UPLOAD_BIN=false
|
||||||
OPSI_REPOS_OPSIMANAGER_INSTALL=false
|
OPSI_REPOS_OPSIMANAGER_INSTALL=false
|
||||||
|
|
||||||
@ -83,6 +84,11 @@ OPSI_REPOS_OPSIMANAGER_INSTALL=false
|
|||||||
# Valid values: true|false
|
# Valid values: true|false
|
||||||
OPSI_REPOS_PURGE=false
|
OPSI_REPOS_PURGE=false
|
||||||
|
|
||||||
|
# Only purge projects using the defined STATUS
|
||||||
|
# ValidValues: integration|testing|release
|
||||||
|
# Defaut: integration
|
||||||
|
OPSI_REPOS_PURGE_STATUS=integration
|
||||||
|
|
||||||
# defines the max. instances of published versions per product
|
# defines the max. instances of published versions per product
|
||||||
# Valid values: 0...n, 0: disable autocleanup
|
# Valid values: 0...n, 0: disable autocleanup
|
||||||
OPSI_REPOS_PURGE_LIMIT=3
|
OPSI_REPOS_PURGE_LIMIT=3
|
||||||
|
@ -18,6 +18,7 @@ builder_config() {
|
|||||||
CMD_identify="`which identify`" ; builder_check_error "Command 'identify' (ImageMagick) not installed"
|
CMD_identify="`which identify`" ; builder_check_error "Command 'identify' (ImageMagick) not installed"
|
||||||
CMD_zsyncmake="`which zsyncmake`" ; builder_check_error "Command 'zsyncmake' not installed"
|
CMD_zsyncmake="`which zsyncmake`" ; builder_check_error "Command 'zsyncmake' not installed"
|
||||||
CMD_comm="`which comm`" ; builder_check_error "Command 'comm' not installed"
|
CMD_comm="`which comm`" ; builder_check_error "Command 'comm' not installed"
|
||||||
|
CMD_sha1sum="`which sha1sum`" ; builder_check_error "Command 'sha1sum' not installed"
|
||||||
|
|
||||||
# Check temp dir
|
# Check temp dir
|
||||||
test -d ${TMP_DIR}
|
test -d ${TMP_DIR}
|
||||||
@ -45,8 +46,13 @@ builder_config() {
|
|||||||
# change some variable from the builder-product.cfg dynamically:
|
# change some variable from the builder-product.cfg dynamically:
|
||||||
# autogenerate release number, if we are in status "integration"
|
# autogenerate release number, if we are in status "integration"
|
||||||
if [ "$STATUS" = "integration" ] ; then
|
if [ "$STATUS" = "integration" ] ; then
|
||||||
# OPSI/control:RELEASE is limited to max 16 chars - take care in regards to the CREATOR_TAG
|
if [ "${STATUS_INTEGRATION_RELEASE}" = "func:inc1" ] ; then
|
||||||
RELEASE="${STATUS_INTEGRATION_RELEASE}"
|
. ${config}
|
||||||
|
calc_release
|
||||||
|
else
|
||||||
|
# OPSI/control:RELEASE is limited to max 16 chars - take care in regards to the CREATOR_TAG
|
||||||
|
RELEASE="${STATUS_INTEGRATION_RELEASE}"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Read configurationfile
|
# Read configurationfile
|
||||||
@ -85,7 +91,7 @@ builder_prepare() {
|
|||||||
log_debug "Distribution directory: $DIST_CACHE_DIR"
|
log_debug "Distribution directory: $DIST_CACHE_DIR"
|
||||||
|
|
||||||
# setup work directory
|
# setup work directory
|
||||||
OUTPUT_DIR=$TMP_DIR/opsi-builder.`date +%Y%m%d-%H%M%S`
|
OUTPUT_DIR="$TMP_DIR/opsi-builder.`date +%Y%m%d-%H%M%S`.$$"
|
||||||
mkdir -p ${OUTPUT_DIR}
|
mkdir -p ${OUTPUT_DIR}
|
||||||
builder_check_error "Cannot create temp directory ${OUTPUT_DIR}"
|
builder_check_error "Cannot create temp directory ${OUTPUT_DIR}"
|
||||||
|
|
||||||
@ -140,14 +146,16 @@ builder_retrieve() {
|
|||||||
|
|
||||||
# Check sha1
|
# Check sha1
|
||||||
if [ ! -e "${PRODUCT_DIR}/${basename}.sha1sum" ] && [ "$CHECKSUM_AUTOCREATE" == "true" ] ; then
|
if [ ! -e "${PRODUCT_DIR}/${basename}.sha1sum" ] && [ "$CHECKSUM_AUTOCREATE" == "true" ] ; then
|
||||||
sha1sum ${DL_DIST_FILE[$i]} > ${PRODUCT_DIR}/${basename}.sha1sum
|
$CMD_sha1sum ${DL_DIST_FILE[$i]} > ${PRODUCT_DIR}/${basename}.sha1sum
|
||||||
downloaded=1
|
downloaded=1
|
||||||
echo " WARNING: SHA1 checksum (${DL_DIST_FILE[$i]}.sha1sum) was created dynamically because auf CHECKSUM_AUTOCREATE=$CHECKSUM_AUTOCREATE"
|
echo " WARNING: SHA1 checksum (${DL_DIST_FILE[$i]}.sha1sum) was created dynamically because auf CHECKSUM_AUTOCREATE=$CHECKSUM_AUTOCREATE"
|
||||||
else
|
else
|
||||||
# testing the checksum of the downloaded files
|
# testing the checksum of the downloaded files
|
||||||
local sha1sum_val=`cat ${PRODUCT_DIR}/${basename}.sha1sum | cut -d " " -f1`
|
local sha1sum_val=`cat ${PRODUCT_DIR}/${basename}.sha1sum | cut -d " " -f1`
|
||||||
local checksum_val=`sha1sum ${DL_DIST_FILE[$i]} | cut -d " " -f1`
|
local checksum_val=`sha1sum ${DL_DIST_FILE[$i]} | cut -d " " -f1`
|
||||||
if [ "$checksum_val" == "$sha1sum_val" ] ; then
|
echo sha1sum_val: $sha1sum_val
|
||||||
|
echo checksum_val: $checksum_val
|
||||||
|
if [ "$checksum_val" = "$sha1sum_val" ] ; then
|
||||||
downloaded=1
|
downloaded=1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@ -248,9 +256,10 @@ builder_package() {
|
|||||||
builder_check_error "can't move file ${OUTPUT_DIR}/${opsi_file} ${OUTPUT_DIR}/${OPSI_REPOS_FILE_PATTERN}.opsi"
|
builder_check_error "can't move file ${OUTPUT_DIR}/${opsi_file} ${OUTPUT_DIR}/${OPSI_REPOS_FILE_PATTERN}.opsi"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# --exclude \*/.git\*
|
||||||
# create source- and binary package package
|
# create source- and binary package package
|
||||||
test "${OPSI_REPOS_UPLOAD_BIN}" = "true" && $CMD_zip -r ${OUTPUT_DIR}/${OPSI_REPOS_FILE_PATTERN}.zip $INST_DIR
|
test "${OPSI_REPOS_UPLOAD_BIN}" = "true" && $CMD_zip --exclude \*/.git\* @ -r ${OUTPUT_DIR}/${OPSI_REPOS_FILE_PATTERN}.zip $INST_DIR
|
||||||
test "${OPSI_REPOS_UPLOAD_SOURCE}" = "true" && $CMD_zip -r ${OUTPUT_DIR}/${OPSI_REPOS_FILE_PATTERN}-src.zip ${PRODUCT_DIR}
|
test "${OPSI_REPOS_UPLOAD_SOURCE}" = "true" && $CMD_zip --exclude \*/.git\* @ -r ${OUTPUT_DIR}/${OPSI_REPOS_FILE_PATTERN}-src.zip ${PRODUCT_DIR}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -298,43 +307,60 @@ builder_publish() {
|
|||||||
# Create revision file for this
|
# Create revision file for this
|
||||||
local rev_file=${OPSI_REPOS_PRODUCT_DIR}/${PN}-${VERSION}-${CREATOR_TAG}${RELEASE}.cfg
|
local rev_file=${OPSI_REPOS_PRODUCT_DIR}/${PN}-${VERSION}-${CREATOR_TAG}${RELEASE}.cfg
|
||||||
cat > $rev_file <<EOF
|
cat > $rev_file <<EOF
|
||||||
|
REV_VENDOR=${VENDOR}
|
||||||
REV_PN=${PN}
|
REV_PN=${PN}
|
||||||
REV_TIMESTAMP=`date +"%s"`
|
|
||||||
REV_VERSION=${VERSION}
|
REV_VERSION=${VERSION}
|
||||||
REV_RELEASE=${RELEASE}
|
REV_RELEASE=${RELEASE}
|
||||||
|
REV_TYPE=${TYPE}
|
||||||
|
REV_STATUS=${STATUS}
|
||||||
|
REV_TIMESTAMP=`date +"%s"`
|
||||||
REV_CREATOR_TAG=${CREATOR_TAG}
|
REV_CREATOR_TAG=${CREATOR_TAG}
|
||||||
REV_OPSI_REPOS_FILE_PATTERN=${OPSI_REPOS_FILE_PATTERN}
|
REV_OPSI_REPOS_FILE_PATTERN=${OPSI_REPOS_FILE_PATTERN}
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
|
||||||
# Purge old product versions - defined by limit OPSI_REPOS_PURGE_LIMIT
|
# Purge old product versions - defined by limit OPSI_REPOS_PURGE_LIMIT
|
||||||
if [ "${OPSI_REPOS_PURGE}" = "true" ] && [ ! -z "${OPSI_REPOS_PURGE_LIMIT}" ] && [ "${OPSI_REPOS_PURGE_LIMIT}" > 0 ] ; then
|
if [ "${OPSI_REPOS_PURGE}" = "true" ] && [ ! -z "${OPSI_REPOS_PURGE_LIMIT}" ] && [ "${OPSI_REPOS_PURGE_LIMIT}" > 0 ] && [ "${STATUS}" = "${OPSI_REPOS_PURGE_STATUS}" ] ; then
|
||||||
echo "Autopurging enabled"
|
echo "Autopurging enabled"
|
||||||
|
|
||||||
|
# determinte max version to delete
|
||||||
local limit
|
local limit
|
||||||
eval "`echo limit=\\$\\{OPSI_REPOS_PURGE_LIMIT_${PN}\\}`"
|
eval "`echo limit=\\$\\{OPSI_REPOS_PURGE_LIMIT_${PN}\\}`"
|
||||||
if [ -z "$limit" ] || [ ! `expr $limit + 1 2> /dev/null` ] ; then
|
if [ -z "$limit" ] || [ ! `expr $limit + 1 2>/dev/null` ] ; then
|
||||||
limit=${OPSI_REPOS_PURGE_LIMIT}
|
limit=${OPSI_REPOS_PURGE_LIMIT}
|
||||||
fi
|
fi
|
||||||
echo " Purging, max. number of versions: $limit"
|
echo " Purging, max. number of versions: $limit"
|
||||||
|
|
||||||
# Find all revision files
|
# Find all revision files and sort them
|
||||||
local file_list=${OUTPUT_DIR}/product-file-list.txt
|
local file_list=${OUTPUT_DIR}/product-file-list.txt
|
||||||
find ${OPSI_REPOS_BASE_DIR} -name "${PN}-${VERSION}-${CREATOR_TAG}*.cfg" -exec echo {} \; | sort > ${file_list}
|
local file_sort_list=${OUTPUT_DIR}/product-file-sort-list.txt
|
||||||
for cfg_file in `tail -${limit} ${file_list} | ${CMD_comm} -13 - ${file_list}` ; do
|
rm -f ${file_list}
|
||||||
dir_base=`dirname ${cfg_file}`
|
for cfg_file in `find ${OPSI_REPOS_BASE_DIR} -name "${PN}-${VERSION}-${CREATOR_TAG}*.cfg" -print ` ; do
|
||||||
. ${cfg_file}
|
. ${cfg_file}
|
||||||
|
printf "%08d;$cfg_file\n" $REV_RELEASE >> ${file_list}
|
||||||
|
done
|
||||||
|
sort -n ${file_list} > ${file_sort_list}
|
||||||
|
|
||||||
|
# Delete the oldest files
|
||||||
|
log_debug "base list for calculate purge:"
|
||||||
|
for cfg_sort_file in `tail -${limit} ${file_sort_list} | ${CMD_comm} -13 - ${file_sort_list}` ; do
|
||||||
|
|
||||||
|
local cfg_file=`echo $cfg_sort_file | cut -f 2 -d ";"`
|
||||||
|
. ${cfg_file}
|
||||||
|
if [ "${REV_STATUS}" != "${OPSI_REPOS_PURGE_STATUS}" ] ; then continue; fi
|
||||||
|
|
||||||
|
dir_base=`dirname ${cfg_file}`
|
||||||
product_file="${dir_base}/${REV_OPSI_REPOS_FILE_PATTERN}"
|
product_file="${dir_base}/${REV_OPSI_REPOS_FILE_PATTERN}"
|
||||||
echo " Purging product version: $product_file.*"
|
echo " Purging product version: $product_file*"
|
||||||
|
|
||||||
# Paranoid ... check the files to delete first
|
# Paranoid ... check the files to delete first
|
||||||
if [ ! -z "${dir_base}" ] && [ -d "${OPSI_REPOS_BASE_DIR}" ] ; then
|
if [ ! -z "${dir_base}" ] && [ -d "${OPSI_REPOS_BASE_DIR}" ] && [ ! -z "$product_file" ] ; then
|
||||||
rm -f ${product_file}.* ${cfg_file}
|
rm -f ${product_file}* ${cfg_file}
|
||||||
fi
|
|
||||||
|
|
||||||
# remove directory - if it's empty
|
# remove directory - if it's empty
|
||||||
if [ $(ls -1A ${dir_base} | wc -l) -eq 0 ]; then
|
if [ $(ls -1A ${dir_base} | wc -l) -eq 0 ]; then
|
||||||
rmdir ${dir_base}
|
rmdir ${dir_base}
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
@ -227,3 +227,36 @@ create_winst_varfile() {
|
|||||||
|
|
||||||
echo >>$var_file
|
echo >>$var_file
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#####################
|
||||||
|
# void calc_release()
|
||||||
|
#
|
||||||
|
# Description:
|
||||||
|
# Calculate new release based on
|
||||||
|
# the latest one found in the repository.
|
||||||
|
#
|
||||||
|
# $RELEASE is set to the calculated release.
|
||||||
|
#
|
||||||
|
####################
|
||||||
|
function calc_release() {
|
||||||
|
|
||||||
|
# Find all revision files and sort them
|
||||||
|
local file_list=`mktemp /tmp/opsi-builder.calc_release.XXXXXXXXXXX`
|
||||||
|
for cfg_file in `find ${OPSI_REPOS_BASE_DIR} -name "${PN}-${VERSION}-${CREATOR_TAG}*.cfg" -print ` ; do
|
||||||
|
. ${cfg_file}
|
||||||
|
printf "%08d;$cfg_file\n" $REV_RELEASE >> ${file_list}
|
||||||
|
done
|
||||||
|
local oldest_cfg=`sort -n ${file_list} | cut -f 2 -d ";" | tail -1`
|
||||||
|
rm -f ${file_list}
|
||||||
|
|
||||||
|
if [ ! -f "${oldest_cfg}" ] ; then
|
||||||
|
echo "Warning: no cfg-file found for this product. RELEASE will be set to 1"
|
||||||
|
RELEASE=1
|
||||||
|
else
|
||||||
|
log_debug "calc_release() oldest_cfg: ${oldest_cfg}"
|
||||||
|
. ${oldest_cfg}
|
||||||
|
log_debug " latest release: $REV_RELEASE"
|
||||||
|
RELEASE=`expr ${REV_RELEASE} + 1 2> /dev/null`
|
||||||
|
builder_check_error "Cannot incrememnt REV_RELEASE from file ${oldest_cfg}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
28
sample/product-template/Testing.txt
Normal file
28
sample/product-template/Testing.txt
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
*** Qualitiymanagement/Testing procedure
|
||||||
|
|
||||||
|
- Product:
|
||||||
|
- Name: productname
|
||||||
|
- Version: xxx
|
||||||
|
- Release: yyyy
|
||||||
|
|
||||||
|
- Environment
|
||||||
|
- OS: Native windows XP-32Bit installation
|
||||||
|
- Preinstalled packages: None (also no aio)
|
||||||
|
- Files used while testing:
|
||||||
|
File1: http://domain.de/file.ext
|
||||||
|
|
||||||
|
- Testing process:
|
||||||
|
OPSI-action:
|
||||||
|
- Installation (without dependencies like AIO/Firefox): ??
|
||||||
|
Result:
|
||||||
|
- File extensions related to program: ??
|
||||||
|
- Start menu entry: ??
|
||||||
|
- Starting/using program: viewer works, File1 is shown correctly: ??
|
||||||
|
|
||||||
|
OPSI-action:
|
||||||
|
- Uninstall
|
||||||
|
Result:
|
||||||
|
- File extensions related to program: unrelated: ??
|
||||||
|
- Start menu entry: none: ??
|
||||||
|
|
||||||
|
|
@ -19,42 +19,7 @@
|
|||||||
#
|
#
|
||||||
##############################################################################
|
##############################################################################
|
||||||
|
|
||||||
#function config() {
|
|
||||||
# echo "Config - doing some commands before calling the builder_config"
|
|
||||||
# builder_config
|
|
||||||
# echo "Config - doing some commands after calling the builder_config"
|
|
||||||
#}
|
|
||||||
|
|
||||||
#function prepare() {
|
|
||||||
# echo "Prepare"
|
|
||||||
# builder_prepare
|
|
||||||
#}
|
|
||||||
|
|
||||||
function retrieve() {
|
|
||||||
echo "Retrieve"
|
|
||||||
builder_retrieve
|
|
||||||
}
|
|
||||||
|
|
||||||
function create() {
|
|
||||||
echo "Create"
|
|
||||||
builder_create
|
|
||||||
}
|
|
||||||
|
|
||||||
function package() {
|
|
||||||
echo "Package"
|
|
||||||
builder_package
|
|
||||||
}
|
|
||||||
|
|
||||||
function publish() {
|
|
||||||
echo "Publish"
|
|
||||||
builder_publish
|
|
||||||
}
|
|
||||||
|
|
||||||
function commit() {
|
|
||||||
echo "Commit"
|
|
||||||
# builder_commit
|
|
||||||
}
|
|
||||||
function cleanup() {
|
function cleanup() {
|
||||||
echo "Cleanup: output_dir: $output_dir"
|
echo "Cleanup"
|
||||||
# builder_cleanup
|
builder_cleanup
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user