From 5fe81eb11d4ff24f3a0533c09165a76b4984da61 Mon Sep 17 00:00:00 2001 From: fuzzyray <fuzzyray@gentoo.org> Date: Tue, 28 Apr 2009 15:45:40 +0000 Subject: [PATCH] Add initial test suite from idl0r svn path=/; revision=551 --- trunk/src/echangelog/test/TEST.pm | 40 ++++ .../src/echangelog/test/templates/test.patch | 6 + .../test/templates/vcstest-0.0.1.ebuild | 16 ++ trunk/src/echangelog/test/test.sh | 192 ++++++++++++++++++ 4 files changed, 254 insertions(+) create mode 100644 trunk/src/echangelog/test/TEST.pm create mode 100644 trunk/src/echangelog/test/templates/test.patch create mode 100644 trunk/src/echangelog/test/templates/vcstest-0.0.1.ebuild create mode 100755 trunk/src/echangelog/test/test.sh diff --git a/trunk/src/echangelog/test/TEST.pm b/trunk/src/echangelog/test/TEST.pm new file mode 100644 index 0000000..21ecfe7 --- /dev/null +++ b/trunk/src/echangelog/test/TEST.pm @@ -0,0 +1,40 @@ +# +#=============================================================================== +# +# FILE: POSIX.pm +# +# DESCRIPTION: +# +# FILES: --- +# BUGS: --- +# NOTES: --- +# AUTHOR: YOUR NAME (), +# COMPANY: +# VERSION: 1.0 +# CREATED: 04/28/2009 01:24:13 PM +# REVISION: --- +#=============================================================================== + +package TEST; + +use strict; +use warnings; + +BEGIN { + use Exporter(); + our ($VERSION, @ISA, @EXPORT, @EXPORT_OK, %EXPORT_TAGS); + + $VERSION = 1.00; + + @ISA = qw(Exporter); + @EXPORT = qw(&strftime); + %EXPORT_TAGS = ( ); + @EXPORT_OK = qw(); +} +our @EXPORT_OK; + +sub strftime { + return "01 Jan 2009"; +} + +1; diff --git a/trunk/src/echangelog/test/templates/test.patch b/trunk/src/echangelog/test/templates/test.patch new file mode 100644 index 0000000..83399ce --- /dev/null +++ b/trunk/src/echangelog/test/templates/test.patch @@ -0,0 +1,6 @@ +--- test.patch2 2009-04-28 14:13:26.171225175 +0200 ++++ test.patch 2009-04-28 14:12:26.246497830 +0200 +@@ -0,0 +1,3 @@ ++This is just an example. ++Its used for serveral echangelog tests. ++ diff --git a/trunk/src/echangelog/test/templates/vcstest-0.0.1.ebuild b/trunk/src/echangelog/test/templates/vcstest-0.0.1.ebuild new file mode 100644 index 0000000..2824b83 --- /dev/null +++ b/trunk/src/echangelog/test/templates/vcstest-0.0.1.ebuild @@ -0,0 +1,16 @@ +# Copyright 1999-2009 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: $ + +DESCRIPTION="echangelog test ebuild" +HOMEPAGE="" +SRC_URI="" + +LICENSE="" +SLOT="0" +KEYWORDS="" +IUSE="" + +DEPEND="" +RDEPEND="" + diff --git a/trunk/src/echangelog/test/test.sh b/trunk/src/echangelog/test/test.sh new file mode 100755 index 0000000..374522f --- /dev/null +++ b/trunk/src/echangelog/test/test.sh @@ -0,0 +1,192 @@ +#!/bin/sh + +source /etc/init.d/functions.sh + +VCSTEST="echangelog-test/vcstest" +_ROOT=$(pwd) + +export ECHANGELOG_USER="Just a test <echangelogtest@gentoo.org>" + +#MD5_INIT="34d54bc2ab1a2154b0c7bd5cdd7f6119" +MD5_INIT="34d54bc2ab1a2154b0c7bd5cdd7f6119" +#MD5_PATCH="d910ab6b76cfb48b68e11ae1f06612bb" +MD5_PATCH="db1ab89bb7374824d0f198078f79a83f" +#MD5_REVBUMP="8e36650a644ba49cc13bcbe93fdb2d2d" +MD5_REVBUMP="31ddfa60d2ae4dd1fccd7e3d2bd2c06c" +#MD5_COPYRIGHT="55a6097d8e3913a9feb0dff250649c00" +MD5_COPYRIGHT="6f39fa409ea14bb6506347c53f6dee50" +#MD5_OBSOLETE="6c30d84f603f5f0e4b09a88d9cfdaaa8" +MD5_OBSOLETE="0aedadf159c6f3add97a3f79fb867221" +#MD5_FINAL="cdd58fea5cfcef5820013d82ccbe0e89" +MD5_FINAL="17eb0df69f501cc6fdaffebd118b7764" + +function md5() { + local fname=$1 + echo $(md5sum ${fname} | awk '{ print $1 }') +} + +function ech() { + local bin=$1 + local msg=$2 + + perl -I$(dirname $(dirname ${bin})) ${bin} "${msg}" +} + +function make_test() { + local root=$1 + local vcs=$2 + + local echangelog="${root}/tmp/echangelog" + local tmp="${root}/tmp/${vcs}" + local template="${root}/templates" + + cd $root + mkdir -p ${tmp} + cd ${tmp} + + [[ "${vcs}" == "cvs" ]] && mkdir -p ${tmp}/cvsroot + [[ "${vcs}" == "svn" ]] && mkdir -p ${tmp}/svnroot + + if [[ "${vcs}" == "git" ]]; + then + git init + touch .gitignore + git add .gitignore + git commit -a -m 'Initial Commit' + elif [[ "${vcs}" == "svn" ]]; + then + svnadmin create svnroot + svn co file://${tmp}/svnroot svn + cd svn + elif [[ "${vcs}" == "cvs" ]]; + then + CVSROOT="${tmp}/cvsroot" cvs init + mkdir cvsroot/cvs + cvs -d:local:${tmp}/cvsroot co cvs + cd cvs + fi + + mkdir -p ${VCSTEST} + + cp ${template}/vcstest-0.0.1.ebuild ${VCSTEST} + ${vcs} add $(dirname ${VCSTEST}) + if [[ "${vcs}" == "cvs" ]]; + then + ${vcs} add ${VCSTEST} + ${vcs} add "${VCSTEST}/vcstest-0.0.1.ebuild" + fi + + cd ${VCSTEST} + ech ${echangelog} 'New ebuild for bug <id>.' + + if [[ "${MD5_INIT}" != "$(md5 ChangeLog)" ]]; + then + eerror "WRONG MD5_INIT!" + fi + + mkdir files + cp ${template}/test.patch files + if [[ "${vcs}" == "cvs" ]]; + then + ${vcs} add files/ + ${vcs} add files/test.patch + else + ${vcs} add files + fi + + ech ${echangelog} "Added adittional patch to fix foo." + + if [[ "${MD5_PATCH}" != "$(md5 ChangeLog)" ]]; + then + eerror "WRONG MD5_PATCH!" + fi + + if [[ "${vcs}" == "svn" ]]; + then + ${vcs} commit -m 'New ebuild for bug <id>.' ../ + else + ${vcs} commit -m 'New ebuild for bug <id>.' + fi + + [[ "${vcs}" == "cvs" ]] && sed -i -e 's:# $Header\: .*$:# $Header\: $:' ChangeLog + + cp vcstest-0.0.1.ebuild vcstest-0.0.1-r1.ebuild + ${vcs} add vcstest-0.0.1-r1.ebuild + + ech ${echangelog} "Revbump..." + + if [[ "${MD5_REVBUMP}" != "$(md5 ChangeLog)" ]]; + then + eerror "WRONG MD5_REVBUMP!" + fi + + sed -i -e 's:# Copyright 1999-2009 Gentoo Foundation:# Copyright 1999-2010 Gentoo Foundation:' vcstest-0.0.1.ebuild + ech ${echangelog} "Revbump...; Just copyright changed." + + if [[ "${MD5_COPYRIGHT}" != "$(md5 ChangeLog)" ]]; + then + eerror "WRONG MD5_COPYRIGHT!" + fi + + if [[ "${vcs}" == "cvs" ]]; + then + rm -f files/test.patch + ${vcs} remove files/test.patch + else + ${vcs} rm files/test.patch + fi + + ech ${echangelog} "Revbump...; Just copyright changed; Removed obsolete patch." + + if [[ "${MD5_OBSOLETE}" != "$(md5 ChangeLog)" ]]; + then + eerror "WRONG MD5_OBSOLETE!" + fi + + echo>>vcstest-0.0.1.ebuild + ech ${echangelog} "Revbump...; Just copyright changed; Removed obsolete patch; Modified more then just the copyright." + + if [[ "${MD5_FINAL}" != "$(md5 ChangeLog)" ]]; + then + eerror "WRONG MD5_FINAL!" + fi +} + +[[ -d "${_ROOT}/tmp" ]] && rm -rf ${_ROOT}/tmp +mkdir -p ${_ROOT}/tmp + +ebegin "Preparing echangelog" + +if [[ -e ../echangelog ]]; +then + cp ../echangelog "${_ROOT}/tmp" || set $? + sed -i -e 's:use POSIX qw.*:use POSIX qw(setlocale getcwd);\nuse TEST qw(strftime);:' "${_ROOT}/tmp/echangelog" || set $? + eend ${1:-0} || exit ${1} +else + eerror "error" + eend ${1:-1} + exit 1 +fi + +if [[ -x $(which git) ]]; +then + ebegin "Starting test with git" + make_test $_ROOT "git" || set $? + eend ${1:-0} +fi + +if [[ -x $(which cvs) ]]; +then + ebegin "Starting test with cvs" + make_test $_ROOT "cvs" || set $? + eend ${1:-0} +fi + +if [[ -x $(which svn) ]]; +then + ebegin "Starting test with svn" + make_test $_ROOT "svn" || set $? + eend ${1:-0} +fi + +rm -rf "${_ROOT}/tmp" -- 2.26.2